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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4506|回復: 0
打印 上一主題 下一主題
收起左側

verilog中的timescale

[復制鏈接]
跳轉到指定樓層
樓主
ID:77367 發表于 2015-4-19 01:29 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
今天看了很多博主寫的關于verilog中的timescale的東西,收獲很多。將大家的東西轉載一下,并加點自己的整理東西。


         在Verilog HDL 模型中,所有時延都用單位時間表述。使用`timescale編譯器指令將時間單位與實際時間相關聯。該指令用于定義時延的單位和時延精度。`timescale編譯器指令格式為:

     imescale time_unit / time_precision

          time_unittime_precision 由值110、和100以及單位smsusnspsfs組成。例如:


    `imescale 1ns/100ps


   表示時延單位為1ns, 時延精度為100ps。`timescale 編譯器指令在模塊說明外部出現, 并且影響后面所有的時延值。例如:


`timescale 1ns/ 100ps

MODULE AndFunc (Z, A, B);

OUTPUT Z;

input A, B;


and # (5.22, 6.17 ) Al (Z, A, B);

//規定了上升及下降時延值。

endMODULE


  編譯器指令定義時延以ns為單位,并且時延精度為1/10 ns(100 ps)。因此,時延值5.22對應5.2 ns, 時延6.17對應6.2 ns。如果用如下的`timescale程序指令代替上例中的編譯器指令,


`timescale 10ns/1ns


那么5.22對應52ns, 6.17對應62ns。


  在編譯過程中,`timescale指令影響這一編譯器指令后面所有模塊中的時延值,直至遇到另一個`timescale指令或`resetall指令。當一個設計中的多個模塊帶有自身的`timescale編譯指令時將發生什么?在這種情況下,模擬器總是定位在所有模塊的最小時延精度上,并且所有時延都相應地換算為最小時延精度。

   

   

    (以下轉自另一篇文章:)

在verilog中是沒有默認timescale的。一個沒有指定timescale的verilog模塊就有可能錯誤的繼承了前面編譯模塊的無效timescale參數

所以在verilog的LRM中推薦“在每個module的前面指定`timescale,并且相應的在最后加一個`resetall來確保timescale的局部有效”


     

在編譯過程中,`timescale指令影響這一編譯器指令后面所有模塊中的時延值,直至遇到另一個`timescale指令或`resetall指令。當一個設計中的多個模塊帶有自身的`timescale編譯指令時將發生什么?在這種情況下,模擬器總是定位在所有模塊的最小時延精度上,并且所有時延都相應地換算為最小時延精度。例如,


`timescale 1ns/ 100ps

MODULE AndFunc (Z, A, B);

OUTPUT Z;

input A, B;


and # (5.22, 6.17 ) Al (Z, A, B);

endMODULE


`timescale 10ns/ 1ns

MODULE TB;

reg PutA, PutB;

WIRE GetO;


initial

begin

PutA = 0;

PutB = 0;

#5.21 PutB = 1;

#10.4 PutA = 1;

#15 PutB = 0;

end

AndFunc AF1(GetO, PutA, PutB);

endMODULE


在這個例子中,每個模塊都有自身的`timescale編譯器指令。`timescale編譯器指令第一次應用于時延。因此,在第一個模塊中,5.22對應5.2 ns, 6.17對應6.2 ns; 在第二個模塊中5.21對應52 ns, 10.4對應104 ns, 15對應150 ns。如果仿真模塊TB,設計中的所有模塊最小時間精度為100 ps。因此,所有延遲(特別是模塊TB中的延遲)將換算成精度為100 ps。延遲52 ns現在對應520*100 ps,104對應1040*100 ps,150對應1500*100 ps。更重要的是,仿真使用100 ps為時間精度。如果仿真模塊AndFunc,由于模塊TB不是模塊AddFunc的子模塊,模塊TB中的`timescale程序指令將不再有效。


        為了確認這種用法,我編寫了一個小小的包含兩個模塊module_a和module_b的testbench,其中module_a,module_b與testbench指定了不同的timescale精度。通過simulation的波形可以發現,Simulator的確在不同的module中使用了不同的times精度。

代碼如下:

文件名:module_a.v

`timescale 100ps/1ps


module module_a (clk) ;

input clk;

wire clk_a ;


assign #5 clk_a = clk;


endmodule


`resetall


文件名:module_b.v

`timescale 10ps/1ps


module module_b (clk) ;

input clk;

wire clk_b ;


assign #5 clk_b = clk;


endmodule


`resetall


文件名:testbench.v

`timescale 1ns/10ps


module tb();

reg clk;


initial begin

clk = 0;

end


initial

begin

$fsdbDumpvars;

#12 $finish;

end



always begin

#1 clk = ~clk;

end


module_a a_inst(clk);

module_b b_inst(clk);


endmodule


針對這三個文件,進行不同的修改,得到不同的波形:

源文件如下:http://space.ednchina.com/Upload ... 1e-60af9aeb0c4d.rar[/url]" target=_blank>

對應源文件生成的波形圖如下:



另: 注意使用timescale時,前面為" ` ",體現在鍵盤上為數字鍵“1”前的按鍵,否則,編譯時會出現以下問題:

** Error: src/counter16_tb.v(6): near "'t": Illegal base specifier in numeric constant.
** Error: src/counter16_tb.v(6): near "'t":  expecting: LIBRARY CONFIG
** Error: src/counter16_tb.v(6): Expecting numeric digits.



分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产情侣激情 | 久久精品日产第一区二区三区 | 日本人做爰大片免费观看一老师 | 久久午夜精品福利一区二区 | 国产真实乱对白精彩久久小说 | 国产一区二区精品在线观看 | 国产精品免费一区二区三区四区 | 欧美一级二级视频 | 99久久精品国产麻豆演员表 | 国产成人一区二区三区 | 国产在线视频在线观看 | 中文字幕国产 | 久久在线 | 日日拍夜夜 | 国产午夜精品一区二区三区四区 | 日韩精品免费视频 | 91精品国产一区二区三区 | 国产欧美一区二区三区久久手机版 | 久久亚洲欧美日韩精品专区 | 日韩精品免费 | 色男人的天堂 | 国产精久久久久久久妇剪断 | 亚洲一区二区中文字幕 | 青青草久久 | 一区二区三区精品视频 | 337p日本欧洲亚洲大胆鲁鲁 | 日韩一区二| 一级a毛片| 成人av鲁丝片一区二区小说 | 午夜免费视频 | 亚洲午夜av久久乱码 | www.中文字幕.com | 欧美在线观看网站 | 亚洲精品乱码8久久久久久日本 | 欧美激情在线精品一区二区三区 | 欧美成人一级 | 日韩精品一区二区三区四区 | 在线欧美视频 | 最近中文字幕在线视频1 | 欧美日韩一 | 国产精久久久 |