Verilog Prosedür Arayüzü - Verilog Procedural Interface

Verilog Prosedür Arayüzü Başlangıçta PLI 2.0 olarak bilinen (VPI), öncelikle C Programlama dili. Davranışsal Verilog C işlevlerini çağırmak için kod ve standart Verilog sistem görevlerini çağırmak için C işlevleri. Verilog Prosedür Arayüzü, IEEE 1364 Programlama Dili Arayüzü standardı; standardın en son baskısı 2005 yılına aittir. VPI bazen PLI 2 olarak da anılır, çünkü kullanımdan kaldırıldı Program Dili Arayüzü (PLI).

PLI 1, VPI (diğer adıyla PLI 2) lehine kullanımdan kaldırılmış olsa da, PLI 1, birçok verilog referans kitabında açıklanan çok daha geniş bir şekilde belgelenmiş tf_put, tf_get fonksiyon arayüzü nedeniyle VPI üzerinde hala yaygın olarak kullanılmaktadır.

C ++ kullanımı

C ++, C ++ derleyicilerinde yerleşik "extern C / C ++" anahtar sözcüğü kullanılarak VPI (PLI 2.0) ve PLI 1.0 ile entegre edilebilir.

Misal

Örnek olarak, aşağıdaki Verilog kod parçasını göz önünde bulundurun:

val = 41; $ artış (val); $ display ("$ artıştan sonra, val =% d", val);

Varsayalım artış sistem görevi, ilk parametresini birer birer artırır. C ve VPI mekanizmasını kullanarak, artış görev aşağıdaki gibi uygulanabilir:

// Arttırma sistemi görevini uygularstatik int artış(kömür *Kullanıcı bilgisi) {  vpiHandle systfref, args_iter, argh;  yapı t_vpi_value argval;  int değer;  // Argüman listesi için bir tutamaç elde edin  systfref = vpi_handle(vpiSysTfCall, BOŞ);  args_iter = vpi_iterate(vpiArgument, systfref);  // İlk argümanın değerini alın  argh = vpi_scan(args_iter);  argval.biçim = vpiIntVal;  vpi_get_value(argh, &argval);  değer = argval.değer.tamsayı;  vpi_printf("VPI rutini% d aldı n", değer);  // Değeri artırın ve ilk bağımsız değişken olarak geri koyun  argval.değer.tamsayı = değer + 1;  vpi_put_value(argh, &argval, BOŞ, vpiNoDelay);  // Temizle ve geri dön  vpi_free_object(args_iter);  dönüş 0;}

Ayrıca, bu sistem görevini kaydeden bir işlev gereklidir. Bu işlev, harici olarak görülebilir alana yerleştirildiğinde referansların detaylandırılmasından veya çözümlenmesinden önce çağrılır. vlog_startup_routines [] dizi.

// Arttırma sistemi görevini kaydedergeçersiz register_increment() {  s_vpi_systf_data veri = {vpiSysTask, 0, "$ artış", artış, 0, 0, 0};  vpi_register_systf(&veri);}// Başlangıçta çağrılması gereken sıfır sonlu bir işlevler listesi içerirgeçersiz (*vlog_startup_routines[])() = {  register_increment,  0};

C kodu, Verilog simülatörü tarafından kullanılacak paylaşılan bir nesnede derlenir. Daha önce bahsedilen Verilog parçasının bir simülasyonu artık aşağıdaki çıktıyla sonuçlanacaktır:

VPI rutini $ artıştan sonra 41 aldı, val = 42

Ayrıca bakınız

Kaynaklar

Verilog VPI arayüzü kaynakları

Dış bağlantılar