色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

代碼編寫中verilog的設計規范

ZYNQ ? 來源:ZYNQ ? 作者:ZYNQ ? 2022-11-25 09:26 ? 次閱讀

	

5.2 代碼編寫中容易出現的問題

  • 在for-loop中包括不變的表達式 浪費運算時間
for(i=0;i<4;i=i+1)
begin
Sig1=Sig2;
DataOut[i]=DataIn[i];
end

for-loop中第一條語句始終不變,浪費運算時間.

  • 資源共享問題 條件算子中不存在 資源共享 ,如
z=(cond)?(a+b):(c+d);

必須使用兩個加法器; 而等效的條件if-then-else語句則可以資源共享 如

if(Cond)
z=a+b;
else
z=c+d;

只要加法器的輸入端復用,就可以實現加法器的共享,使用一個加法器實現。

  • 由于組合邏輯的位置不同而引起過多的觸發器綜合 如下面兩個例子
moduleCOUNT(AndBits,Clk,Rst);
OutputAndbits;
InputClk,
Rst;
RegAndBits;
//internalreg

Reg[2:0]Count;
always@(posedgeClk)begin
begin
if(Rst)
Count<=#u_dly0;
else
Count<=?#u_dly?Count?+?1;
End//endif
AndBits<=?#u_dly?&?Count;
?End?//endalways
endmodule

在進程里的變量都綜合成觸發器了,有4個;

moduleCOUNT(AndBits,Clk,Rst);
OutputAndBits;
InputClk,
Rst;
RegAndBits;
//internalreg
Reg[2:0]Count;
always@(posedgeClk)begin//synchronous
if(Rst)
Count<=?#u_dly?0;
else
Count<=?#u_dly?Count?+?1;
End//endalways
always@(Count)begin//asynchronous
AndBits=&Count;
End//endalways
Endmodule//endCOUNT

組合邏輯單開,只有3個觸發器.

  • 謹慎使用異步邏輯
moduleCOUNT(Z,Enable,Clk,Rst);
Output[2:0]Z;
InputRst,
Enable,
Clk;

reg[2:0]Z;
always@(posedgeClk)begin
if(Rst)begin
Z<=#u_dly1'b0;
end
elseif(Enable==1'b1)begin
If(Z==3'd7)begin
Z<=#u_dly1'b0;
End
elsebegin
Z<=?#u_dly?Z?+?1'b1;
end
End
Else;
End//endalways
Endmodule//endCOUNT

是同步邏輯,而下例則使用了組合邏輯作時鐘,以及異步復位.實際的運用中要加以避免.

moduleCOUNT(Z,Enable,Clk,Rst);
Output[2:0]Z;
InputRst,
Enable,
Clk;
Reg[2:0]Z;
//internalwire
wireGATED_Clk=Clk&Enable;
always@(posedgeGATED_ClkorposedgeRst)begin
if(Rst)begin
Z<=#u_dly1'b0;
end
elsebegin
if(Z==3'd7)begin
Z<=#u_dly1'b0;
end
elsebegin
Z<=?#u_dly?Z?+?1'b1;
end
End//endif
End//endalways
Endmodule//endmodule
  • 對組合邏輯的描述有多種方式 其綜合結果是等效的
c=a&b;
等效于
c[3:0]=a[3:0]&b[3:0];
等效于
c[3]=a[3]&b[3];
c[2]=a[2]&b[2];
c[1]=a[1]&b[1];
c[0]=a[0]&b[0];
等效于
for(i=0;i<=3;i=i+1)
c[i]=a[i]&b[i];
可以選擇簡潔的寫法.
  • 考慮綜合的執行時間
通常會推薦將模塊劃分得越小越好, 事實上要從實際的設計目標, 面積和時序要求出發。好的時序規劃和合適的約束條件要比電路的大小對綜合時間的影響要大。要依照設計的目標來劃分模塊, 對該模塊綜合約束的scripts也可以集中在該特性上。要選擇合適的約束條件, 過分的約束將導致漫長的綜合時間。最好在設計階段就做好時序規劃 。通過綜合的約束scripts來滿足時序規劃。這樣就能獲得既滿足性能的結果 ,又使得綜合時間最省 。從代碼設計講 ,500~5000行的長度是合適的。
  • 避免點到點的例外
所謂點到點例外 Point-to-point exception ,就是從一個寄存器的輸出到另一個寄存器的輸入的路徑不能在一個周期內完成。多周期路徑就是其典型情況 。多周期路徑比較麻煩, 在靜態時序分析中要標注為例外, 這樣可能會因為人為因素將其他路徑錯誤地標注為例外, 從而對該路徑沒有分析, 造成隱患。避免使用多周期路徑, 如果確實要用 ,應將它放在單獨一個模塊, 并且在代碼中加以注釋。
  • 避免偽路徑(False path)
偽路徑是那些靜態時序分析 STA 認為是時序失敗, 而設計者認為是正確的路徑。通常會人為忽略這些warning ,但如果數量較多時 ,就可能將其他真正的問題錯過了。
  • 避免使用Latch
使用Latch必須有所記錄, 可以用All_registers -level_sensitive來報告設計中用到的Latch 。不希望使用Latch時 ,應該對所有輸入情況都對輸出賦值, 或者將條件賦值語 句寫全, 如在if語句最后加一個else, case語句加defaults。
  • 當你必須使用Latch時 ,為了提高可測性, 需要加入測試邏輯。
不完整的if和case語句導致不必要的latch的產生, 下面的語句中 DataOut會被綜合成鎖存器 。如果不希望在電路中使用鎖存器, 它就是錯誤。
always@(Cond)
begin
if(Cond)
DataOut<=DataInend
  • 避免使用門控時鐘

使用門控時鐘(Gated clock)不利于移植 ,可能引起毛刺, 帶來時序問題 ,同時對掃描鏈的形成帶來問題。門控鐘在低功耗設計中要用到 ,但通常不要在模塊級代碼中使用 。可以借助于Power compiler來生成 ,或者在頂層產生。

  • 避免使用內部產生的時鐘

在設計中最好使用同步設計。如果要使用內部時鐘 ,可以考慮使用多個時鐘。因為使用內部時鐘的電路要加到掃描鏈中比較麻煩,降低了可測性, 也不利于使用約束條件來綜合。

  • 避免使用內部復位信號

模塊中所有的寄存器最好同時復位。如果要使用內部復位, 最好將其相關邏輯放在單獨的模塊中, 這樣可以提高可閱讀性。

  • 如果確實要使用內部時鐘, 門控時鐘 ,或內部的復位信號 ,將它們放在頂層。

將這些信號的產生放在頂層的一個獨立模塊, 這樣所有的子模塊分別使用單一的時鐘和復位信號。一般情況下內部門控時鐘可以用同步置數替代。

6 附錄

6.1 Module 編寫示例

/**
Filename﹕
Author﹕
Description﹕
Calledby﹕
RevisionHistory﹕mm/dd/yy
Revision1.0
Email﹕M@sz.huawei.com.cn
Company﹕HuaweiTechnology.Inc
Copyright(c)1999,HuaweiTechnologyInc,Allrightreserved
**/
Modulemodule_name(
Output_ports,//comment;portdescription
Input_ports,//comment;portdescription
Io_ports,//comment;portdescripttion
Clk_port,//comment;portdescription
Rst_port//comment;portdescription
);

//portdeclarations
Output[31:;0]Dataout;
Input[31:0]Datain;
InoutBi_dir_signal;
Inputinput1,
Input2;

//interrnalwire/regdeclarations
Wire[31:0]internal_data;
Regoutput_enable;

//moduleinstantiations,Self-buildmodule
Module_name1Uinstance_name1(...);
Module_name2Uinstance_name2(...);

//TSC4000cell
DTC12V1(.Clk(Clk),.CLRZ(Clr),.D(Data),.Q(Qout));

//continuousassignment
AssignData_out=out_enable?Internal_data:32’hz;

//alwaysblock
Always@(input2)
Begin
...
End
//functionandtaskdefinitions
Functiom[function_type]function_name;
Declarations_of_inputs;
[declarations_of_local_variables];
Begin
Behavirol_statement;
Function_name=function_express;
End
Endfunction//endfunction_name
Endmodule//endmodule_name

6.2 testbench編寫示例

下面是一個格雷碼的測試模塊,
moduleTB_GRAY;
regClock;
regReset;
wire[7:0]Qout;
integerfout;//輸出文件指針
parameterCYC=20;

GRAYDUT(.Clock(Clock),.Reset(Reset),.Qout(Qout));

initial
begin
Clock=1'b0;
Reset=1'b1;
#(5*CYC)Reset=1'b0;
#(5*CYC)Reset=1'b1;
#(5000*CYC)
$fclose(fout);
$finish;
end

initial
begin
$shm_open("GRAY.shm");
$shm_probe("AS");
fout=$fopen("gray.dat");
end

always#CYCClock=~Clock;


//輸出數據到文件gray.dat
always@(posedgeClock)
begin
$fwrite(fout,"%d%b
",Qout,Qout);
end

endmodule
  1. 在testbench中避免使用絕對的時間,如#20,#15或#(CYC+15)等,應該在文件前面使用parameter定義一些常量,使得時間的定義象#(CYC+OFF0)的形式,便于修改。

  2. 觀測結果可以輸出到波形文件GRAY.shm ,或數據文件gray.dat 。生成波形文件可以用simwave觀測結果 ,比較直觀。而生成數據文件則既可以快速定位 ,也可以通過編寫的小程序工具對它進行進一步的處理。

  3. 對大的設計的頂層仿真 ,一般不要對所有信號跟蹤, 波形文件會很大, 仿真時間延長,可以有選擇的觀測一些信號。

審核編輯:郭婷


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • Verilog
    +關注

    關注

    28

    文章

    1351

    瀏覽量

    110129
  • 代碼
    +關注

    關注

    30

    文章

    4791

    瀏覽量

    68677

原文標題:【華為】verilog語言編寫規范(三)

文章出處:【微信號:ZYNQ,微信公眾號:ZYNQ】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Verilog 與 ASIC 設計的關系 Verilog 代碼優化技巧

    Verilog與ASIC設計的關系 Verilog作為一種硬件描述語言(HDL),在ASIC設計扮演著至關重要的角色。ASIC(Application Specific Integrated
    的頭像 發表于 12-17 09:52 ?134次閱讀

    Verilog 測試平臺設計方法 Verilog FPGA開發指南

    Verilog測試平臺設計方法是Verilog FPGA開發的重要環節,它用于驗證Verilog設計的正確性和性能。以下是一個詳細的Verilog
    的頭像 發表于 12-17 09:50 ?230次閱讀

    Verilog與VHDL的比較 Verilog HDL編程技巧

    Verilog 與 VHDL 比較 1. 語法和風格 VerilogVerilog 的語法更接近于 C 語言,對于有 C 語言背景的工程師來說,學習曲線較平緩。它支持結構化編程,代碼
    的頭像 發表于 12-17 09:44 ?172次閱讀

    如何自動生成verilog代碼

    介紹幾種自動生成verilog代碼的方法。
    的頭像 發表于 11-05 11:45 ?332次閱讀
    如何自動生成<b class='flag-5'>verilog</b><b class='flag-5'>代碼</b>

    Verilog硬件描述語言參考手冊

    一. 關于 IEEE 1364 標準二. Verilog簡介三. 語法總結四. 編寫Verilog HDL源代碼的標準五. 設計流程
    發表于 11-04 10:12 ?1次下載

    Verilog語法運算符的用法

    verilog語法中使用以下兩個運算符可以簡化我們的位選擇代碼
    的頭像 發表于 10-25 15:17 ?841次閱讀
    <b class='flag-5'>Verilog</b>語法<b class='flag-5'>中</b>運算符的用法

    110kv變電站設計規范

    110kV變電站設計規范涉及多個方面,包括選址、電氣設計、設備選擇、安全保護等。以下是根據相關規范和標準整理的一些主要設計規范: 一、總則 目的與范圍 :規范適用于電壓為35~110k
    的頭像 發表于 09-26 09:32 ?2162次閱讀

    怎么樣提高verilog代碼編寫水平?

    ,共同進步。 歡迎加入FPGA技術微信交流群14群! 交流問題(一) Q:怎么樣提高verilog代碼編寫水平?Cpu 從事DFT工作。目前僅限于寫一些簡單模塊。自學的話如何提高verilog
    發表于 09-25 20:05

    pcb設計中有哪些常用設計規范

    在PCB(Printed Circuit Board,印刷電路板)設計,常用的設計規范涉及多個方面,以確保電路板的性能、可靠性、可制造性和可維護性。以下是一些主要的設計規范: 一、電氣設計規
    的頭像 發表于 09-02 14:51 ?1060次閱讀

    嵌入式系統C語言的編寫規范

    最重要的一條規則 編寫代碼時最重要的一條規則是:檢查周圍的代碼并嘗試模仿它。 作為維護人員,如果收到的補丁明顯與周圍代碼的編碼風格不同,這是令人沮喪的。這是不尊重人的,就像某人穿著泥濘
    的頭像 發表于 05-11 08:49 ?1151次閱讀

    代碼檢查的方式有三種

    等方面的問題。那么在代碼檢查服務,提到的編程規范,規則集,規則,規則用例(場景、誤報、檢出)分別代表什么意思呢? 編程規范 在 SAST 靜態代碼
    的頭像 發表于 02-25 10:08 ?863次閱讀
    <b class='flag-5'>代碼</b>檢查的方式有三種

    PCB layout在布線上的設計規范有哪些?

    一站式PCBA智造廠家今天為大家講講pcb layout設計需要注意哪些細節?pcb layout設計規范。Printed Circuit Board (PCB)是一種電子零件,它是連接電子器件,如
    的頭像 發表于 02-23 09:19 ?878次閱讀

    verilog function函數的用法

    Verilog 是一種硬件描述語言 (HDL),主要用于描述數字電子電路的行為和結構。在 Verilog ,函數 (Function) 是一種用于執行特定任務并返回一個值的可重用代碼
    的頭像 發表于 02-22 15:49 ?5772次閱讀

    verilog函數和任務對比

    verilog,函數和任務均用來描述共同的代碼段,并且在模式內任意位置被調用,提高代碼效率,讓代碼更加的直觀,提高
    的頭像 發表于 02-12 18:43 ?893次閱讀

    怎么用emac實現Verilog自動連線呢?

    我們在編寫一些比較復雜的Verilog代碼時,通常需要進行大量的手動連線工作,這種工作十分容易出錯,并且在代碼模塊的嵌套層級較多時,更改里層的一個
    的頭像 發表于 01-24 10:03 ?1396次閱讀
    主站蜘蛛池模板: 欧美午夜免费观看福利片| 精品免费在线视频| 超碰久久国产vs| 中字幕久久久人妻熟女天美传媒| 中文字幕亚洲无线码高清不卡| 亚洲精品国偷拍电影自产在线| 亚洲国产成人久久一区www妖精| 在线观看日本免费| 偷偷要色偷偷| 欧美老妇与zozoz0交| 龙腾亚洲人成电影网站| 欧美乱子YELLOWVIDEO| 视频三区 国产盗摄| 亚洲久久少妇中文字幕| 98久久人妻无码精品系列蜜桃| 国产精品自在自线亚洲| 国产色精品久久人妻无码看片软件 | 97人人碰免费视频公开| 国产成人啪精品视频免费网| 久久精品热99看| 神马电影院午 夜理论| 最新快播网站| 国产一区二区在线观看免费| 青草国产在线视频免费| 伊人久久国产免费观看视频| 亚洲伊人成综合人影院| 20岁αsrian男同志免费| 国产精品高清在线观看93| 美女张开腿露出尿口扒开来摸动漫| 先锋影音 av| 办公室中文BD| 巨大乳hdbbw| 肉多荤文高h羞耻校园| 亚洲av欧美在我| 啊灬啊别停灬用力啊老师| 久久精品观看影院2828| 偷偷鲁青春草原视频| xxx在线播放| 美国一级大黄一片免费的网站| 亚洲精品乱码久久久久久v| 富婆找黑人老外泻火在线播放|