天堂888-欧美黄色小说-熟睡侵犯の奶水授乳在线-初尝情欲h名器av-亚洲天堂免费视频-日韩五十路-免费在线国产-国产又大又黄又粗-久草导航-色播导航-亚洲免费资源-熟女一区二区三区视频-亚洲美女视频在线-亚洲成人福利视频-婷婷精品在线-亚洲综合p-中文字幕 日本-亚洲骚片-亚洲自拍偷拍网-国产农村妇女精品一区二区-午夜中出-久久精品国产精品亚洲毛片-91精品毛片-99爱视频在线-狠狠操亚洲-美女让人操-里番本子纯肉侵犯肉全彩无码-999偷拍

淺析基于Modelsim FLI接口的協同仿真[3]

交換技術與網絡管控 責任編輯:hack0r 2012-01-11

摘要:4.2動態鏈接庫的程序結構利用modelsim仿真時,可根據VHDL文件的聲明,調用DLL文件(如sim.dll)。在VHDL文件中已經給出了調用文件(sim.dll)和初始化函數名(如sim_init),modelsim根據這些信息,調用sim.dll中的sim_init函數,完成初始化工作。初始化包括:①初始化全局變量;②設置VHDL輸入輸出信號與c程序變量的對應關系;③

  4.2 動態鏈接庫的程序結構

  利用modelsim仿真時,可根據VHDL文件的聲明,調用DLL文件(如sim.dll)。在VHDL文件中已經給出了調用文件(sim.dll)和初始化函數名(如sim_init),modelsim根據這些信息,調用sim.dll中的sim_init函數,完成初始化工作。初始化包括:

  ①初始化全局變量;

  ②設置VHDL輸入輸出信號與c程序變量的對應關系;

  ③設置輸出信號的一些初始狀態(mti_ScheduleDriver);

  ④設置在仿真器重新仿真(restart)和仿真器退出仿真(quit)等情況下執行的一些函數(mti_AddRestartCB和mti_AddQuitCB等),如釋放動態申請內存等;

  ⑤設置敏感表,給出在某些信號發生變化(如時鐘上升沿等)時執行的函數。

  ⑥其它。

  C程序的設計步驟如下:

  (1)包含頭文件,包括c程序常用的一些頭文件和modelsim給出的外部語言接口頭文件mti.h。Modelsim給出的外部接口函數說明、類型定義等都在mti.h中。

  (2)定義自己的結構體,這一點主要是為了編程方便,例如輸入輸出信號對應的變量在各函數中基本上都會用到,可以把這些變量定義成一個結構,便于參數傳遞。

  (3)編寫初始化函數

  初始化函數的定義為:

  init_func(mtiReginoIdT region,char *param,

  mtiInterfaceListT *generics,mtiInterfaceListT *ports)

  各參數的意義可以參閱modelsim用戶手冊。

  下面結合上面給出的初始化函數要完成的任務進行詳細說明。

  a.初始化全局變量(略)

  b.設置VHDL輸入輸出信號與c程序變量的對應關系。這是通過調用mti_FindPort函數實現的。mti_FindPort函數定義為:

  mfiSignalIdT mti_FindPort(mtiInterfaceListT *list,char *name);

  例如,定義輸入輸出信號對應的結構ip:

  PortStruct ip;

  就可以用:

  ip_in1=mti_FindPort(ports,“in1”);

  來實現輸入信號in1與變量in1的對應關系。

  對輸出信號來說,它的目的是產生驅動。因此,這些變量(out1和out2)除了要找到對應的輸出信號外,還要驅動這些信號。對信號的驅動可以通過調用mti_CreateDriver函數來實現。該函數的定義為:

  mtiDriverIdT mti_CreateDriver(mtiSignalIdT sig);

  由于這些變量一般只用于對外驅動,因此可以簡單寫成下面的形式:

  ip.out1 = mti+ CreateDriver(mti_FindPort(ports,“out1”));

[1]  [2]  [3]  [4]  

更多資料
更多課程
更多真題
溫馨提示:因考試政策、內容不斷變化與調整,本網站提供的以上信息僅供參考,如有異議,請考生以權威部門公布的內容為準!

通信工程師備考資料免費領取

去領取

專注在線職業教育25年

信息系統項目管理師

信息系統項目管理師

信息系統項目管理師

!
咨詢在線老師!