亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? invoke_options_vpi.c

?? pli_handbook_examples_pc verilog hdl 與C的接口的典型例子
?? C
字號:
/**********************************************************************
 * $test_invoke_options example -- PLI application using VPI routines
 *
 * C source to test for aany simulation invocation option, including
 * user-defined options.  The system function will return 1 if an
 * invocation option was present when simulation was invoked, and will
 * return 0 if the option did not exist.
 *
 * Usage: reg flag;
          flag = $test_invoke_options("<invocation_option>");
 *   Where <invocation_option can be any + or - option.
 *
 * Debug tip: Uncomment the line "#define PLIbook_verbose" to enable
 * this application to list all simulation invocation options.
 *
 * For the book, "The Verilog PLI Handbook" by Stuart Sutherland
 *  Book copyright 1999, Kluwer Academic Publishers, Norwell, MA, USA
 *   Contact: www.wkap.il
 *  Example copyright 1998, Sutherland HDL Inc, Portland, Oregon, USA
 *   Contact: www.sutherland.com or (503) 692-0898
 *********************************************************************/

#define PLIbook_verbose 1 /* uncomment to list all invoke options */

#include <stdlib.h>    /* ANSI C standard library */
#include <stdio.h>     /* ANSI C standard input/output library */
#include "vpi_user.h"  /* IEEE 1364 PLI VPI routine library  */

/* prototypes of routines in this PLI application */
int  PLIbook_TestInvokeOptions_calltf(), 
     PLIbook_TestInvokeOptions_compiletf(), 
     PLIbook_TestInvokeOptions_sizetf(),
     PLIbook_GetOptions(); 
void PLIbook_ScanCommandFile();

/**********************************************************************
 * VPI Registration Data
 *********************************************************************/
void PLIbook_TestInvokeOptions_register()
{
  s_vpi_systf_data tf_data;
  tf_data.type        = vpiSysFunc;
  tf_data.sysfunctype = vpiSysFuncSized;
  tf_data.tfname      = "$test_invoke_options";
  tf_data.calltf      = PLIbook_TestInvokeOptions_calltf;
  tf_data.compiletf   = PLIbook_TestInvokeOptions_compiletf;
  tf_data.sizetf      = PLIbook_TestInvokeOptions_sizetf;
  tf_data.user_data   = NULL;
  vpi_register_systf(&tf_data);
}

/**********************************************************************
 * sizetf application
 *********************************************************************/
int PLIbook_TestInvokeOptions_sizetf(char *user_data)
{
  return(1);    /* $test_invoke_options returns 1-bit value */
}

/**********************************************************************
 * calltf routine
 *********************************************************************/
int PLIbook_TestInvokeOptions_calltf(char *user_data)
{
  vpiHandle        systf_h, arg_itr, arg_h;
  char            *option_name;
  s_vpi_value      value_s;
  s_vpi_vlog_info  sim_info;
  int              found;

  vpi_get_vlog_info(&sim_info);

  /* get system function arg--compiletf already verified correctness */
  systf_h = vpi_handle(vpiSysTfCall, NULL);
  arg_itr = vpi_iterate(vpiArgument, systf_h);
  arg_h   = vpi_scan(arg_itr);
  vpi_free_object(arg_itr); /* free iterator -- did not scan to null */

  /* read target option name from first tfarg */
  value_s.format = vpiStringVal;
  vpi_get_value(arg_h, &value_s);
  option_name = value_s.value.str;

  /* test for target option and return true/false to system function */
  found = PLIbook_GetOptions(option_name,sim_info.argc,sim_info.argv);
  value_s.format = vpiIntVal;
  value_s.value.integer = found;
  vpi_put_value(systf_h, &value_s, NULL, vpiNoDelay);
  return(0);
}

int PLIbook_optfound = 0; /* global variable for option found flag */
int PLIbook_indent = 0;   /* global variable to format text indenting */

int PLIbook_GetOptions(char *option, int argc, char **argv)
{
  int i;
  PLIbook_optfound = 0;
  PLIbook_indent = 0;
  for (i=0; i<argc; i++) {
    #ifdef PLIbook_verbose
      vpi_printf("%s\n", *argv); 
    #endif
    if (strcmp(*argv, option) == 0) {
      PLIbook_optfound = 1;
    }
    if (strcmp(*argv, "-f") == 0) {
      argv++;  /* next arg is address to array of strings */
      i++;
      PLIbook_ScanCommandFile(option, (char **)*argv);
    }
    argv++; /* increment to next argument */
  }
  return(PLIbook_optfound);
}

void PLIbook_ScanCommandFile(char *option, char **arg)
{
  int i;

  #ifdef PLIbook_verbose
    PLIbook_indent += 4; /* increase text indentation */
  #endif
  while ( *arg != NULL ) { /* loop until null termination */
    #ifdef PLIbook_verbose
      for (i=0; i<=PLIbook_indent; i++)
        vpi_printf(" ");
      vpi_printf("%s\n", *arg); 
    #endif
    if (strcmp(*arg, option) == 0) {
      PLIbook_optfound = 1;
    }
    if (strcmp(*arg, "-f") == 0) {
      arg++;  /* next arg is address to array of strings */
      PLIbook_ScanCommandFile(option, (char **)*arg);
    }
    arg++;
  }
  #ifdef PLIbook_verbose
    PLIbook_indent -= 4; /* decrease text indentation */
  #endif
  return;
}

/**********************************************************************
 * compiletf routine
 *********************************************************************/
int PLIbook_TestInvokeOptions_compiletf(char *user_data)
{
  vpiHandle   systf_h, arg_itr, arg_h;
  int         err = 0;
  
  systf_h = vpi_handle(vpiSysTfCall, NULL);
  arg_itr = vpi_iterate(vpiArgument, systf_h);
  if (arg_itr == NULL) {
    vpi_printf("ERROR: $test_invoke_options requires 1 argument\n");
    tf_dofinish();
    return(0);
  }
  arg_h = vpi_scan(arg_itr);  /* get handle for first tfarg */
  if (vpi_get(vpiType, arg_h) != vpiConstant) {
    vpi_printf("$test_invoke_options arg must be a quoted name\n");
    err = 1;
  }
  else if (vpi_get(vpiConstType, arg_h) != vpiStringConst) {
    vpi_printf("$test_invoke_options arg must be a string\n");
    err = 1;
  }
  if (vpi_scan(arg_itr) != NULL) {
    vpi_printf("test_invoke_options requires only 1 argument\n");
    vpi_free_object(arg_itr);
    err = 1;
  }
  if (err)
    tf_dofinish();

  return(0);
}

/*********************************************************************/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕中文字幕在线一区| 亚洲综合一区在线| 亚洲美女视频一区| 狠狠狠色丁香婷婷综合激情| 91福利国产精品| 国产日韩欧美不卡| 久久99精品国产麻豆婷婷| 在线看日韩精品电影| 国产日韩欧美精品在线| 蜜臀91精品一区二区三区| 色婷婷av一区二区| 中文久久乱码一区二区| 久久99精品国产麻豆婷婷| 欧美老女人第四色| 夜夜嗨av一区二区三区| www.欧美精品一二区| 久久九九久精品国产免费直播| 午夜电影久久久| 91高清视频在线| 又紧又大又爽精品一区二区| 高清国产一区二区三区| 久久欧美一区二区| 国产在线视频不卡二| 欧美大片顶级少妇| 日本v片在线高清不卡在线观看| 91电影在线观看| 亚洲欧美激情插| 色偷偷一区二区三区| 亚洲欧美在线观看| 99这里只有精品| 成人免费在线视频观看| 99久久99久久精品免费看蜜桃| 久久久www成人免费毛片麻豆| 精品无人区卡一卡二卡三乱码免费卡| 欧美精品亚洲一区二区在线播放| 亚洲午夜激情网站| 欧美久久久久久久久| 日韩在线一区二区三区| 91精品国产美女浴室洗澡无遮挡| 日韩国产精品91| 日韩一本二本av| 韩国毛片一区二区三区| 国产三级精品视频| 99精品国产视频| 亚洲精品高清在线| 欧美日韩成人综合天天影院| 午夜欧美在线一二页| 欧美一区三区四区| 国产一区二区电影| 国产精品乱人伦中文| 色综合久久88色综合天天6| 一区二区在线观看免费视频播放| 欧美三区在线观看| 麻豆国产91在线播放| 欧美激情综合在线| 一本大道av伊人久久综合| 天堂蜜桃91精品| 日韩免费一区二区| av欧美精品.com| 亚洲成人av资源| ww亚洲ww在线观看国产| eeuss鲁片一区二区三区 | 国产91清纯白嫩初高中在线观看 | 九色综合狠狠综合久久| 日本一区二区三区dvd视频在线| 夫妻av一区二区| 亚洲国产欧美在线| 久久精品日产第一区二区三区高清版| 成人福利电影精品一区二区在线观看 | 中文字幕免费不卡| 欧美亚男人的天堂| 国产剧情在线观看一区二区| 亚洲欧美视频在线观看| 日韩欧美一区二区免费| 99re这里只有精品视频首页| 日韩 欧美一区二区三区| 国产精品区一区二区三| 欧美一区二区免费| 91网站最新地址| 国产一区二区电影| 五月激情六月综合| 自拍偷拍亚洲综合| 久久先锋影音av| 欧美日本韩国一区二区三区视频| 国产一区二区影院| 天堂va蜜桃一区二区三区 | 一区二区三区久久久| 久久久精品免费观看| 欧美日本韩国一区| 色婷婷综合久久久久中文| 国产麻豆精品95视频| 日韩专区欧美专区| 亚洲自拍都市欧美小说| 中文字幕免费观看一区| 欧美精品一区二区三区蜜臀| 欧美日韩精品福利| 色婷婷久久久亚洲一区二区三区| 国产精品白丝av| 精品一区二区三区在线播放| 日韩不卡免费视频| 亚洲第一激情av| 夜夜精品浪潮av一区二区三区| 国产目拍亚洲精品99久久精品| 欧美岛国在线观看| 9191国产精品| 欧美色精品天天在线观看视频| 97久久超碰国产精品| 成人免费毛片app| 国产高清一区日本| 国产黄色成人av| 国产一区二区精品久久99 | 亚洲中国最大av网站| 亚洲欧美日韩综合aⅴ视频| 国产精品久久久久久久久搜平片| 国产亚洲一区二区三区四区| 久久久久久久久岛国免费| 久久综合国产精品| 久久久久久久精| 国产精品免费av| 自拍av一区二区三区| 亚洲黄色性网站| 五月天激情综合| 免费人成黄页网站在线一区二区| 蜜臂av日日欢夜夜爽一区| 蜜臀av一级做a爰片久久| 九九精品视频在线看| 精品一区二区免费视频| 国产精品白丝av| www.亚洲色图.com| 欧美色精品在线视频| 欧美一区二区久久| 久久综合网色—综合色88| 国产网站一区二区| 亚洲丝袜另类动漫二区| 一区二区国产盗摄色噜噜| 午夜不卡在线视频| 国产精品一二三区| 91视频www| 欧美一区二区三区电影| 国产人成亚洲第一网站在线播放| 国产精品二三区| 午夜伊人狠狠久久| 狠狠狠色丁香婷婷综合久久五月| 成人晚上爱看视频| 欧美日韩在线观看一区二区| 日韩精品专区在线影院重磅| 国产区在线观看成人精品| 伊人色综合久久天天人手人婷| 五月天精品一区二区三区| 国产乱码一区二区三区| 色网综合在线观看| 精品国产网站在线观看| 亚洲图片激情小说| 久久国产精品第一页| 91亚洲精华国产精华精华液| 欧美一区二区三区在线观看| 中文字幕巨乱亚洲| 日韩精品亚洲一区| 91在线观看美女| 亚洲精品在线三区| 亚洲123区在线观看| 成人性生交大片免费看视频在线| 91成人免费在线| 国产亚洲一本大道中文在线| 亚洲成av人片观看| 成人黄色av电影| 日韩你懂的电影在线观看| 一区二区成人在线视频| 国产剧情在线观看一区二区| 欧美精品自拍偷拍| 亚洲欧美色图小说| 国产aⅴ综合色| 日韩一级免费观看| 亚洲国产视频一区二区| www.av精品| 欧美国产综合一区二区| 久久精品国内一区二区三区| 欧美视频一区在线观看| 最好看的中文字幕久久| 国产精品99久| 亚洲精品一区二区三区香蕉| 日韩精品久久理论片| 色屁屁一区二区| 中文字幕亚洲成人| 成人h精品动漫一区二区三区| 日韩女优制服丝袜电影| 日韩高清不卡在线| 欧美性猛交xxxx黑人交| 一区二区在线观看视频| 97精品超碰一区二区三区| 欧美国产精品一区| 国产a久久麻豆| 国产欧美日韩在线视频| 国产精品一区二区免费不卡 | 秋霞电影网一区二区| 欧美日韩亚洲不卡| 亚洲va欧美va天堂v国产综合| 一本色道久久加勒比精品| 自拍偷拍欧美精品| 色欧美片视频在线观看在线视频|