久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

專注電子技術學習與研究
當前位置:單片機教程網 >> MCU設計實例 >> 瀏覽文章

“always @(*)”中‘*’所代表的意思

作者:理想   來源:會員整理上傳   點擊數:  更新時間:2014年05月22日   【字體:

在絕大多數變成語言中,'*'都是表示包括所有可能,那么在Verilog中是不是也一樣呢?為此,我用modelsim做了一個實驗。

 

//被測試的電路                                             

module  test(in,en,rst_n,out);

input     [1:0]     in;
input             en;
input     [1:0]     rst_n;
output   [3:0]     out;

reg         [3:0]     out;

always  @(*)begin
  if(!rst_n)
    out=0;
  else
    out=out+in;
end

endmodule

 

//測試電路,testbench

``timescale 10ps/1ps
module  test_tb;

reg   [1:0]   in;
reg           en;
reg   [1:0]   rst_n;
wire  [3:0]   out;

initial begin
  #1  in=1;
  #1  en=0;
  #1  rst_n=1;
  #1  rst_n=0;
  #1  rst_n=1;
  #1  rst_n=2;
  #1  rst_n=3;
  #1  in=1;
  #1  in=2;
  #1  in=3;
end

always  #1  en=~en;

test test_top(in,en,rst_n,out);

endmodule

 

說明:這里,被測試的電路中,輸出out等于其本身加上輸入in,但要在'*'的激發下才能進行;在testbench  電 路中,首先復位并初始化各個信號的值,然后再改變各個信號的值,觀察out值的變化,以此來確定'*'所代表的信號。

 

用modelsim仿真后的波形:



由仿真后的波形中可以看出:(1)當rst_n復位后,也就是從1變成0時,out變成0,而out賦值語句是包含在always @(*)中的,這就說明rst_n的變化激發了always模塊的執行,則rst_n信號是包含在'*'中的。后面,rst_n每變一次值,out都加上in的值,也證明了'*'包括了rst_n信號。(2)之后,in每變一次值,always模塊都執行一次,out都加上了此時的in值,則說明'*'也包括了in信號。(3)再往后,en不停的從0變成1再變成0,但out的值始終沒變,則說明'*'不包括en信號。

 

結論:在Verilog中,'*'只包括該模塊中的所有型號,沒在該模塊中出現的信號不包含于'*'。

關閉窗口

相關文章

主站蜘蛛池模板: 中文字幕一区二区在线播放 | 超碰在线人人 | 成人av一区二区三区在线观看 | 成人福利网站 | 国产主播av | 夜色在线影院 | 亚洲午夜av| 一区二区网站 | 一级黄色网 | 成人免费毛片网站 | 国产激情网站 | 国产51自产区 | 中文日韩欧美 | 日韩av网站在线观看 | 欧美福利视频 | 能看毛片的网站 | 日韩欧美精品一区二区 | 欧美成人一级 | 日韩精品视频免费 | wwwav在线| 特级丰满少妇一级aaaa爱毛片 | 日韩三级一区 | 亚洲欧美在线视频 | 亚洲精品视频免费观看 | 久久91视频| 黄色大片在线免费观看 | 欧美一级在线视频 | 美女无遮挡网站 | 九九在线观看高清免费 | 91污视频在线观看 | 亚洲精品一区二区三区精华液 | 又色又爽又黄18网站 | 国产精品久久久久久亚洲影视 | 五月天久久 | 91久久久久国产一区二区 | 亚洲色在线视频 | 人人爽人人爽人人 | 91精品国产色综合久久不卡98 | www黄色片 | 草草视频在线观看 | 人成在线 |