Verilog процедуралық интерфейсі - Verilog Procedural Interface

The Verilog процедуралық интерфейсі (VPI), бастапқыда PLI 2.0 ретінде белгілі, интерфейс, негізінен, арналған C бағдарламалау тілі. Бұл мінез-құлыққа мүмкіндік береді Верилог C функцияларын шақыруға арналған код, ал стандартты Verilog жүйесінің тапсырмаларын орындау үшін C функциялары. Verilog процедуралық интерфейсі IEEE 1364 Бағдарламалау тілінің интерфейсі стандарты; стандарттың ең соңғы басылымы 2005 ж. шыққан. VPI кейде PLI 2 деп те аталады, өйткені ол ескірген Бағдарлама тілінің интерфейсі (PLI).

PLI 1 VPI (а. PLI 2) пайдасына ескірген болса, PLI 1 VPI-де әлі де кең таралған, өйткені көптеген верилогтық анықтамалықтарда сипатталған tf_put, tf_get функционалды интерфейсі кеңінен құжатталған.

C ++ қолдану

C ++ VPI (PLI 2.0) және PLI 1.0-мен C ++ компиляторларына кірістірілген «extern C / C ++» кілт сөзін қолдану арқылы интеграцияланады.

Мысал

Мысал ретінде келесі Verilog код фрагментін қарастырайық:

val = 41; $ increment (val); $ display («$ өсімінен кейін, val =% d», val);

Делік өсім жүйелік тапсырма оның бірінші параметрін біртіндеп арттырады. C және VPI механизмін қолдана отырып, өсім тапсырманы келесідей жүзеге асыруға болады:

// өсім жүйесінің тапсырмасын жүзеге асырадыстатикалық int өсім(char *userdata) {  vpiHandle systfref, args_iter, арғ;  құрылым t_vpi_мән арвал;  int мәні;  // Аргументтер тізімінің тұтқасын алыңыз  systfref = vpi_handle(vpiSysTfCall, ЖОҚ);  args_iter = vpi_аяқтау(vpiArgument, systfref);  // Бірінші аргументтің мәнін алыңыз  арғ = vpi_scan(args_iter);  арвал.формат = vpiIntVal;  vpi_get_value(арғ, &арвал);  мәні = арвал.мәні.бүтін;  vpi_printf(«VPI күнделікті% d алды n", мәні);  // Мәнді көбейтіп, оны бірінші аргумент ретінде салыңыз  арвал.мәні.бүтін = мәні + 1;  vpi_put_value(арғ, &арвал, ЖОҚ, vpiNoDelay);  // Тазарту және қайтару  vpi_free_object(args_iter);  қайту 0;}

Сондай-ақ, осы жүйелік тапсырманы тіркейтін функция қажет. Бұл функция сілтемелерді әзірлеуге немесе шешуге дейін, егер олар сыртқы көрінетін жерде орналасса, шақырылады vlog_startup_routines [] массив.

// Арттыру жүйесінің тапсырмасын тіркейдіжарамсыз тіркелу_осы() {  s_vpi_systf_data деректер = {vpiSysTask, 0, «$ increment», өсім, 0, 0, 0};  vpi_register_systf(&деректер);}// Іске қосу кезінде шақырылуы керек функциялардың нөлдік аяқталатын тізімі баржарамсыз (*vlog_startup_routines[])() = {  тіркелу_осы,  0};

С коды Verilog тренажеры қолданатын ортақ нысанға жинақталған. Бұрын аталған Verilog фрагментін модельдеу келесі нәтижеге әкеледі:

VPI режимі $ 41 өскеннен кейін, val = 42 алды

Сондай-ақ қараңыз

Дереккөздер

Verilog VPI интерфейсінің көздері

Сыртқы сілтемелер