वेरिलॉग प्रक्रियात्मक इंटरफ़ेस

From Vigyanwiki
Revision as of 20:28, 18 June 2023 by alpha>Indicwiki (Created page with "{{Short description|Software interface between C and Verilog}} Verilog प्रक्रियात्मक इंटरफ़ेस (VPI), जिसे मूल र...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Verilog प्रक्रियात्मक इंटरफ़ेस (VPI), जिसे मूल रूप से PLI 2.0 के रूप में जाना जाता है, मुख्य रूप से C (प्रोग्रामिंग भाषा) प्रोग्रामिंग भाषा के लिए अभिप्रेत एक इंटरफ़ेस है। यह व्यावहारिक Verilog कोड को C फ़ंक्शंस, और C फ़ंक्शंस को मानक Verilog सिस्टम कार्यों को प्रारंभ करने की अनुमति देता है। Verilog प्रक्रियात्मक इंटरफ़ेस IEEE सी (प्रोग्रामिंग भाषा) इंटरफ़ेस मानक का हिस्सा है; मानक का नवीनतम संस्करण 2005 से है। वीपीआई को कभी-कभी पीएलआई 2 के रूप में भी जाना जाता है, क्योंकि यह पदावनत वेरिलोग#प्रोग्राम लैंग्वेज इंटरफेस (पीएलआई) | प्रोग्राम लैंग्वेज इंटरफेस (पीएलआई) को प्रतिस्थापित करता है।

जबकि पीएलआई 1 को वीपीआई (उर्फ पीएलआई 2) के पक्ष में बहिष्कृत किया गया था, पीएलआई 1 अभी भी आमतौर पर वीपीआई पर उपयोग किया जाता है क्योंकि इसके अधिक व्यापक रूप से प्रलेखित tf_put, tf_get फ़ंक्शन इंटरफ़ेस है जो कई वेरिलॉग संदर्भ पुस्तकों में वर्णित है।

== सी ++ == का प्रयोग करें सी ++ कंपाइलर्स में निर्मित बाहरी सी/सी ++ कीवर्ड का उपयोग करके सी ++ वीपीआई (पीएलआई 2.0) और पीएलआई 1.0 के साथ पूर्णांक है।

उदाहरण

एक उदाहरण के रूप में, निम्नलिखित Verilog कोड खंड पर विचार करें:

val = 41;
$increment(val);
$display("After $increment, val=%d", val);

मान लीजिए increment सिस्टम टास्क इसके पहले पैरामीटर को एक से बढ़ाता है। C और VPI तंत्र का उपयोग करते हुए, increment कार्य को निम्नानुसार कार्यान्वित किया जा सकता है:

// Implements the increment system task
static int increment(char *userdata) {
  vpiHandle systfref, args_iter, argh;
  struct t_vpi_value argval;
  int value;

  // Obtain a handle to the argument list
  systfref = vpi_handle(vpiSysTfCall, NULL);
  args_iter = vpi_iterate(vpiArgument, systfref);

  // Grab the value of the first argument
  argh = vpi_scan(args_iter);
  argval.format = vpiIntVal;
  vpi_get_value(argh, &argval);
  value = argval.value.integer;
  vpi_printf("VPI routine received %d\n", value);

  // Increment the value and put it back as first argument
  argval.value.integer = value + 1;
  vpi_put_value(argh, &argval, NULL, vpiNoDelay);

  // Cleanup and return
  vpi_free_object(args_iter);
  return 0;
}

साथ ही, इस सिस्टम कार्य को पंजीकृत करने वाला एक फ़ंक्शन आवश्यक है। यह फ़ंक्शन विस्तार या संदर्भों के संकल्प से पहले लागू किया जाता है जब इसे बाह्य रूप से दृश्यमान में रखा जाता है vlog_startup_routines[] सरणी।

// Registers the increment system task
void register_increment() {
  s_vpi_systf_data data = {vpiSysTask, 0, "$increment", increment, 0, 0, 0};
  vpi_register_systf(&data);
}

// Contains a zero-terminated list of functions that have to be called at startup
void (*vlog_startup_routines[])() = {
  register_increment,
  0
};

सी कोड को एक साझा वस्तु में संकलित किया गया है जिसका उपयोग वेरिलॉग सिम्युलेटर द्वारा किया जाएगा। पहले उल्लेखित Verilog अंश का अनुकरण अब निम्नलिखित आउटपुट में परिणाम देगा:

<पूर्व> वीपीआई रूटीन को 41 मिले $ वृद्धि के बाद, वैल = 42 </पूर्व>

यह भी देखें

स्रोत

वेरिलोग वीपीआई इंटरफ़ेस के लिए स्रोत

बाहरी संबंध