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

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

?? port_info_vpi.c

?? pli_handbook_examples_pc verilog hdl 與C的接口的典型例子
?? C
字號:
/**********************************************************************
 * $port_info example -- PLI application using VPI routines
 *
 * C source to print information about module ports.
 *
 * Usage: $port_info(<module_instance_name>);
 *
 * 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
 *********************************************************************/

#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  */
#include "veriuser.h"  /* IEEE 1364 PLI TF routine library    
                          (using TF routines for simulation control) */

/* prototypes of routines in this PLI application */
int   PLIbook_PortInfo_compiletf(), PLIbook_PortInfo_calltf();
char *PLIbook_fetch_type_str_vpi();

/**********************************************************************
 * VPI Registration Data
 *********************************************************************/
void PLIbook_PortInfo_register()
{
  s_vpi_systf_data tf_data;
  tf_data.type      = vpiSysTask;
  tf_data.tfname    = "$port_info";
  tf_data.calltf    = PLIbook_PortInfo_calltf;
  tf_data.compiletf = PLIbook_PortInfo_compiletf;
  tf_data.sizetf    = NULL;

  vpi_register_systf(&tf_data);
}
/*********************************************************************/


/**********************************************************************
 * Compiletf application
 *********************************************************************/
int PLIbook_PortInfo_compiletf(char *user_data)
{
  vpiHandle systf_h, tfarg_itr, tfarg_h;

  systf_h = vpi_handle(vpiSysTfCall, NULL);
  if (systf_h == NULL) {
    vpi_printf("ERROR: list_pathout_ports could not obtain handle to systf call\n");
    tf_dofinish(); /* abort simulation */
    return(0);
  }
  tfarg_itr = vpi_iterate(vpiArgument, systf_h);
  if (systf_h == NULL) {
    vpi_printf("ERROR: list_pathout_ports could not obtain iterator to systf args\n");
    tf_dofinish(); /* abort simulation */
    return(0);
  }
  tfarg_h = vpi_scan(tfarg_itr);
  if (vpi_get(vpiType, tfarg_h) != vpiModule) {
    vpi_printf("ERROR: $list_pathout_ports arg must be module instance\n");
    tf_dofinish(); /* abort simulation */
    return(0);
  }
  if (vpi_scan(tfarg_itr) != NULL) {
    tf_error("ERROR: $list_pathout_ports requires 1 argument\n");
    vpi_free_object(tfarg_itr); /* because not scanning until null */
    tf_dofinish(); /* abort simulation */
    return(0);
  }
  return(0);
}

/**********************************************************************
 * calltf routine
 *********************************************************************/
int PLIbook_PortInfo_calltf(char *user_data) 
{
  vpiHandle systf_h, arg_itr, mod_h,
            port_itr, port_h, lowconn_h, highconn_h;
  int       lowconn_type, highconn_type;

  /* get module handle from first system task argument.  Assume the  */
  /* compiletf routine has already verified correct argument type.   */
  systf_h = vpi_handle(vpiSysTfCall, NULL);
  if (systf_h == NULL) {
    vpi_printf("ERROR: list_pathout_ports could not obtain handle to systf call\n");
    return(0);
  }
  arg_itr = vpi_iterate(vpiArgument, systf_h);
  if (systf_h == NULL) {
    vpi_printf("ERROR: list_pathout_ports could not obtain iterator to systf args\n");
    return(0);
  }
  mod_h = vpi_scan(arg_itr);
  vpi_free_object(arg_itr); /* free itr since did not scan until nul */

  vpi_printf("\nModule %s (instance %s)\n",
             vpi_get_str(vpiDefName, mod_h), 
             vpi_get_str(vpiFullName, mod_h));

  port_itr = vpi_iterate(vpiPort, mod_h);
  if (!port_itr) {
    vpi_printf("   No ports found\n");
    return(0);
  }
  while (port_h = vpi_scan(port_itr)) {
    vpi_printf("  Port name is %s\n", vpi_get_str(vpiName, port_h));
    vpi_printf("    Size is %d\n", vpi_get(vpiSize, port_h));  
    switch (vpi_get(vpiDirection, port_h)) {
      case vpiInput:  vpi_printf("    Direction is input\n");  break;
      case vpiOutput: vpi_printf("    Direction is output\n"); break;
      case vpiInout:  vpi_printf("    Direction is inout\n");  break;
    }

    lowconn_h = vpi_handle(vpiLowConn, port_h);
    lowconn_type = vpi_get(vpiType, lowconn_h);
    vpi_printf("    Low conn data type is %s\n",
               PLIbook_fetch_type_str_vpi(lowconn_type));

    highconn_h = vpi_handle(vpiHighConn, port_h);
    if (!highconn_h) {
      vpi_printf("    No high conn\n");
      return(0);
    }
    highconn_type = vpi_get(vpiType, highconn_h);
    vpi_printf("    High conn data type is %s\n",
               PLIbook_fetch_type_str_vpi(highconn_type));
  }
  return(0);
}

/**********************************************************************
 * PLIbook_fetch_type_str_vpi()
 * Return the string name of a VPI constant.
 *********************************************************************/
char *PLIbook_fetch_type_str_vpi(int type)
{
  switch (type) {
    case  vpiNet            : return("vpiNet");
    case  vpiNetBit         : return("vpiNetBit");
    case  vpiReg            : return("vpiReg");
    case  vpiRegBit         : return("vpiRegBit");
    case  vpiPartSelect     : return("vpiPartSelect");
    case  vpiIntegerVar     : return("vpiIntegerVar");
    case  vpiTimeVar        : return("vpiTimeVar");
    case  vpiMemoryWord     : return("vpiMemoryWord");
    case  vpiVarSelect      : return("vpiVarSelect");
    case  vpiConstant       : return("vpiConstant");
    case  vpiParameter      : return("vpiParameter");
    case  vpiFuncCall       : return("vpiFuncCall");
    case  vpiSysFuncCall    : return("vpiSysFuncCall");
    case  vpiOperation      : return("vpiOperation");
    default                 : return("UNDEFINED TYPE");
  }
}
/*********************************************************************/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲综合视频网| 亚洲综合区在线| 欧美精品1区2区| 色女孩综合影院| 在线视频国内自拍亚洲视频| 91网上在线视频| 99久久免费精品高清特色大片| 国产成人精品网址| 粉嫩av亚洲一区二区图片| 成人蜜臀av电影| 成人av在线网| 欧美在线一区二区| 欧美剧在线免费观看网站| 欧美自拍偷拍午夜视频| 在线成人小视频| 欧美zozozo| 国产婷婷色一区二区三区| 国产精品每日更新在线播放网址| 国产精品卡一卡二卡三| 伊人夜夜躁av伊人久久| 日韩精品一二区| 国产成人精品亚洲777人妖| av在线免费不卡| 欧美性大战久久久| 精品久久久久久无| 中文字幕欧美一区| 亚洲va在线va天堂| 国产剧情一区二区| 91在线国产观看| 91精品国产全国免费观看| 日本一区二区视频在线| 亚洲一区影音先锋| 国产乱国产乱300精品| 色综合一区二区| 日韩写真欧美这视频| 精品精品国产高清a毛片牛牛| 国产精品全国免费观看高清| 亚洲免费av高清| 精品一区精品二区高清| 91无套直看片红桃| 欧美成人艳星乳罩| 亚洲黄色小视频| 国产精一区二区三区| 欧美午夜不卡在线观看免费| 国产亚洲欧美日韩日本| 国产精品一线二线三线精华| 91在线观看一区二区| 日韩视频不卡中文| 夜夜精品视频一区二区| 国产精品综合视频| 欧美精品欧美精品系列| 成人欧美一区二区三区白人 | 国产视频一区在线播放| 亚洲永久精品国产| youjizz国产精品| 日韩欧美一区在线| 亚洲不卡av一区二区三区| 播五月开心婷婷综合| 久久综合狠狠综合久久激情 | 精品日韩欧美在线| 亚洲精品免费播放| 欧美亚洲一区二区三区四区| 日本一区二区三区高清不卡| 美女视频黄免费的久久 | 国产欧美日韩精品在线| 日韩专区中文字幕一区二区| 91丝袜高跟美女视频| 国产精品午夜免费| 国产精一品亚洲二区在线视频| 欧美一区二区精品| 午夜欧美在线一二页| 日本电影亚洲天堂一区| 亚洲欧美怡红院| 99久久夜色精品国产网站| 国产精品久久久久精k8| 成人一道本在线| 国产精品三级av在线播放| 国产传媒欧美日韩成人| 久久精品一区二区三区av| 韩国一区二区在线观看| 久久综合国产精品| 国产不卡视频在线播放| 中文文精品字幕一区二区| 丁香六月久久综合狠狠色| 欧美国产精品中文字幕| 精品日韩在线观看| 国产成人综合自拍| 国产精品盗摄一区二区三区| 99综合电影在线视频| 亚洲品质自拍视频| 欧美无乱码久久久免费午夜一区| 亚洲国产日韩在线一区模特| 欧美伦理视频网站| 精品一区二区影视| 国产精品三级av| 色拍拍在线精品视频8848| 亚洲一级电影视频| 日韩免费性生活视频播放| 国产白丝精品91爽爽久久| 国产精品热久久久久夜色精品三区| 99久久亚洲一区二区三区青草| 亚洲高清免费观看| 精品裸体舞一区二区三区| 99久久精品国产毛片| 午夜精品一区二区三区免费视频| 欧美一区二区成人| 成人美女视频在线看| 天涯成人国产亚洲精品一区av| 精品国精品国产| 色综合久久66| 久久99国产精品久久99果冻传媒| 国产精品乱子久久久久| 欧美另类z0zxhd电影| 成人av电影在线| 午夜成人免费视频| 国产精品日日摸夜夜摸av| 777久久久精品| 91一区二区三区在线播放| 日韩国产精品大片| 一区在线观看免费| 精品国产欧美一区二区| 一本色道久久综合亚洲aⅴ蜜桃 | 中文字幕一区av| 欧美人与性动xxxx| www.欧美.com| 免费国产亚洲视频| 一片黄亚洲嫩模| 国产精品三级久久久久三级| 欧美大片在线观看一区| 欧美在线观看18| 99精品国产99久久久久久白柏| 老司机精品视频线观看86| 亚洲另类春色校园小说| 国产日韩在线不卡| 日韩欧美一二区| 欧美精品 日韩| 欧美体内she精视频| aaa亚洲精品| 国产91综合一区在线观看| 捆绑紧缚一区二区三区视频| 亚洲一区二区偷拍精品| 亚洲色图清纯唯美| 国产精品乱码久久久久久| 久久婷婷综合激情| 26uuu亚洲综合色欧美| 91精品国产色综合久久不卡蜜臀 | 欧美一区二区高清| 欧美日韩成人在线一区| 欧美优质美女网站| 色悠悠久久综合| 色综合天天做天天爱| av中文一区二区三区| 不卡的电视剧免费网站有什么| 国产激情一区二区三区四区 | 亚洲电影一区二区| 亚洲精品乱码久久久久久久久| 国产精品久久久久aaaa樱花| 中文在线资源观看网站视频免费不卡 | 国产剧情av麻豆香蕉精品| 激情深爱一区二区| 久久se这里有精品| 国产乱人伦偷精品视频不卡| 国产一区二区91| 国产成人啪免费观看软件| 福利一区二区在线观看| 不卡在线视频中文字幕| 91丨porny丨最新| 欧美三级中文字幕| 91精品国产色综合久久不卡蜜臀| 日韩精品一区二区三区四区| 久久综合色8888| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 亚洲精品国产精华液| 亚洲一区二区三区中文字幕| 亚洲丶国产丶欧美一区二区三区| 天天影视网天天综合色在线播放| 免费看精品久久片| 国产精品一区二区无线| 99久久婷婷国产精品综合| 欧美日韩一区 二区 三区 久久精品 | 成人网男人的天堂| 欧美最猛性xxxxx直播| 精品国产青草久久久久福利| 国产精品情趣视频| 日日夜夜免费精品视频| 懂色av一区二区三区蜜臀| 欧洲一区在线电影| 精品国产髙清在线看国产毛片| 国产精品私人影院| 日韩精品欧美精品| 不卡视频在线看| 日韩一区二区三区在线观看 | 亚洲人成精品久久久久久 | 国产精品一级片| 一本久久精品一区二区| 日韩一区二区三区视频在线观看| 欧美国产日韩a欧美在线观看| 亚洲风情在线资源站| 成人精品亚洲人成在线| 91精品在线麻豆|