女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

代碼編寫中verilog的設(shè)計(jì)規(guī)范

ZYNQ ? 來源:ZYNQ ? 作者:ZYNQ ? 2022-11-25 09:26 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群


	

5.2 代碼編寫中容易出現(xiàn)的問題

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

for-loop中第一條語句始終不變,浪費(fèi)運(yùn)算時(shí)間.

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

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

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

只要加法器的輸入端復(fù)用,就可以實(shí)現(xiàn)加法器的共享,使用一個(gè)加法器實(shí)現(xiàn)。

  • 由于組合邏輯的位置不同而引起過多的觸發(fā)器綜合 如下面兩個(gè)例子
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

在進(jìn)程里的變量都綜合成觸發(fā)器了,有4個(gè);

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個(gè)觸發(fā)器.

  • 謹(jǐn)慎使用異步邏輯
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

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

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
  • 對(duì)組合邏輯的描述有多種方式 其綜合結(jié)果是等效的
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];
可以選擇簡潔的寫法.
  • 考慮綜合的執(zhí)行時(shí)間
通常會(huì)推薦將模塊劃分得越小越好, 事實(shí)上要從實(shí)際的設(shè)計(jì)目標(biāo), 面積和時(shí)序要求出發(fā)。好的時(shí)序規(guī)劃和合適的約束條件要比電路的大小對(duì)綜合時(shí)間的影響要大。要依照設(shè)計(jì)的目標(biāo)來劃分模塊, 對(duì)該模塊綜合約束的scripts也可以集中在該特性上。要選擇合適的約束條件, 過分的約束將導(dǎo)致漫長的綜合時(shí)間。最好在設(shè)計(jì)階段就做好時(shí)序規(guī)劃 。通過綜合的約束scripts來滿足時(shí)序規(guī)劃。這樣就能獲得既滿足性能的結(jié)果 ,又使得綜合時(shí)間最省 。從代碼設(shè)計(jì)講 ,500~5000行的長度是合適的。
  • 避免點(diǎn)到點(diǎn)的例外
所謂點(diǎn)到點(diǎn)例外 Point-to-point exception ,就是從一個(gè)寄存器的輸出到另一個(gè)寄存器的輸入的路徑不能在一個(gè)周期內(nèi)完成。多周期路徑就是其典型情況 。多周期路徑比較麻煩, 在靜態(tài)時(shí)序分析中要標(biāo)注為例外, 這樣可能會(huì)因?yàn)槿藶橐蛩貙⑵渌窂藉e(cuò)誤地標(biāo)注為例外, 從而對(duì)該路徑?jīng)]有分析, 造成隱患。避免使用多周期路徑, 如果確實(shí)要用 ,應(yīng)將它放在單獨(dú)一個(gè)模塊, 并且在代碼中加以注釋。
  • 避免偽路徑(False path)
偽路徑是那些靜態(tài)時(shí)序分析 STA 認(rèn)為是時(shí)序失敗, 而設(shè)計(jì)者認(rèn)為是正確的路徑。通常會(huì)人為忽略這些warning ,但如果數(shù)量較多時(shí) ,就可能將其他真正的問題錯(cuò)過了。
  • 避免使用Latch
使用Latch必須有所記錄, 可以用All_registers -level_sensitive來報(bào)告設(shè)計(jì)中用到的Latch 。不希望使用Latch時(shí) ,應(yīng)該對(duì)所有輸入情況都對(duì)輸出賦值, 或者將條件賦值語 句寫全, 如在if語句最后加一個(gè)else, case語句加defaults。
  • 當(dāng)你必須使用Latch時(shí) ,為了提高可測(cè)性, 需要加入測(cè)試邏輯。
不完整的if和case語句導(dǎo)致不必要的latch的產(chǎn)生, 下面的語句中 DataOut會(huì)被綜合成鎖存器 。如果不希望在電路中使用鎖存器, 它就是錯(cuò)誤。
always@(Cond)
begin
if(Cond)
DataOut<=DataInend
  • 避免使用門控時(shí)鐘

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

  • 避免使用內(nèi)部產(chǎn)生的時(shí)鐘

在設(shè)計(jì)中最好使用同步設(shè)計(jì)。如果要使用內(nèi)部時(shí)鐘 ,可以考慮使用多個(gè)時(shí)鐘。因?yàn)槭褂脙?nèi)部時(shí)鐘的電路要加到掃描鏈中比較麻煩,降低了可測(cè)性, 也不利于使用約束條件來綜合。

模塊中所有的寄存器最好同時(shí)復(fù)位。如果要使用內(nèi)部復(fù)位, 最好將其相關(guān)邏輯放在單獨(dú)的模塊中, 這樣可以提高可閱讀性。

  • 如果確實(shí)要使用內(nèi)部時(shí)鐘, 門控時(shí)鐘 ,或內(nèi)部的復(fù)位信號(hào) ,將它們放在頂層。

將這些信號(hào)的產(chǎn)生放在頂層的一個(gè)獨(dú)立模塊, 這樣所有的子模塊分別使用單一的時(shí)鐘和復(fù)位信號(hào)。一般情況下內(nèi)部門控時(shí)鐘可以用同步置數(shù)替代。

6 附錄

6.1 Module 編寫示例

/**
Filename﹕
Author﹕
Description﹕
Calledby﹕
RevisionHistory﹕mm/dd/yy
Revision1.0
Email﹕[email protected]
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編寫示例

下面是一個(gè)格雷碼的測(cè)試模塊,
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;


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

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

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

  3. 對(duì)大的設(shè)計(jì)的頂層仿真 ,一般不要對(duì)所有信號(hào)跟蹤, 波形文件會(huì)很大, 仿真時(shí)間延長,可以有選擇的觀測(cè)一些信號(hào)。

審核編輯:郭婷


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Verilog
    +關(guān)注

    關(guān)注

    29

    文章

    1366

    瀏覽量

    112059
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4894

    瀏覽量

    70452

原文標(biāo)題:【華為】verilog語言編寫規(guī)范(三)

文章出處:【微信號(hào):ZYNQ,微信公眾號(hào):ZYNQ】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    技術(shù)資訊 I 面向初級(jí)工程師的 PCB 設(shè)計(jì)規(guī)范

    工程師和電路板設(shè)計(jì)新手而言,掌握PCB設(shè)計(jì)規(guī)范至關(guān)重要。本文將深入解析常見的PCB設(shè)計(jì)規(guī)范和制造商要求,并概括介紹PCB設(shè)計(jì)規(guī)范的關(guān)鍵基礎(chǔ)知識(shí)。線距和線寬是實(shí)現(xiàn)
    的頭像 發(fā)表于 06-13 16:28 ?507次閱讀
    技術(shù)資訊 I 面向初級(jí)工程師的 PCB <b class='flag-5'>設(shè)計(jì)規(guī)范</b>

    技術(shù)資料—PCB設(shè)計(jì)規(guī)范

    本 PCB 設(shè)計(jì)規(guī)范包括:PCB 布線與布局、電路設(shè)計(jì)、機(jī)殼、器件選型、系統(tǒng)、線纜與接插件。 按部位分類 技術(shù)規(guī)范內(nèi)容 1 PCB 布線與布局 PCB 布線與布局隔離準(zhǔn)則:強(qiáng)弱電流隔離、大小
    發(fā)表于 04-25 17:24

    133條原理圖設(shè)計(jì)規(guī)范checklist

    原理圖設(shè)計(jì)是產(chǎn)品設(shè)計(jì)的理論基礎(chǔ),設(shè)計(jì)一份規(guī)范的原理圖對(duì)設(shè)計(jì)PCB、跟機(jī)、做客戶資料具有指導(dǎo)性意義,是做好一款產(chǎn)品的基礎(chǔ)。原理圖設(shè)計(jì)基本要求: 規(guī)范、清晰、準(zhǔn)確、易讀。 因此制定《原理圖設(shè)計(jì)規(guī)范
    發(fā)表于 04-11 10:50

    268條PCB Layout設(shè)計(jì)規(guī)范(免積分下載)

    本文總結(jié)了PCB布線與布局和電路設(shè)計(jì)總共268條設(shè)計(jì)規(guī)范,供大家參考學(xué)習(xí)。 獲取完整資料可下載附件哦!!!!
    發(fā)表于 03-05 16:26

    中興通訊的PCB設(shè)計(jì)規(guī)范

    中興通訊的PCB設(shè)計(jì)規(guī)范
    發(fā)表于 02-08 15:31 ?7次下載

    GB/T 50034-2024 建設(shè)照明設(shè)計(jì)規(guī)范

    當(dāng)前有效的建筑照明設(shè)計(jì)規(guī)范
    發(fā)表于 02-07 15:20 ?15次下載

    華為支付接入規(guī)范

    為了確保用戶獲得良好的支付體驗(yàn),Payment Kit制定了相關(guān)接入設(shè)計(jì)規(guī)范,請(qǐng)開發(fā)者遵照?qǐng)?zhí)行,具體要求(非強(qiáng)制性)如下: 一、支付方式呈現(xiàn) 涉及支付公司名稱,請(qǐng)統(tǒng)一使用:花瓣支付(深圳)有限公司
    發(fā)表于 01-23 09:27

    Verilog 與 ASIC 設(shè)計(jì)的關(guān)系 Verilog 代碼優(yōu)化技巧

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

    Verilog 測(cè)試平臺(tái)設(shè)計(jì)方法 Verilog FPGA開發(fā)指南

    Verilog測(cè)試平臺(tái)設(shè)計(jì)方法是Verilog FPGA開發(fā)的重要環(huán)節(jié),它用于驗(yàn)證Verilog設(shè)計(jì)的正確性和性能。以下是一個(gè)詳細(xì)的Verilog
    的頭像 發(fā)表于 12-17 09:50 ?1083次閱讀

    如何自動(dòng)生成verilog代碼

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

    Verilog硬件描述語言參考手冊(cè)

    一. 關(guān)于 IEEE 1364 標(biāo)準(zhǔn)二. Verilog簡介三. 語法總結(jié)四. 編寫Verilog HDL源代碼的標(biāo)準(zhǔn)五. 設(shè)計(jì)流程
    發(fā)表于 11-04 10:12 ?4次下載

    Verilog語法運(yùn)算符的用法

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

    110kv變電站設(shè)計(jì)規(guī)范

    110kV變電站設(shè)計(jì)規(guī)范涉及多個(gè)方面,包括選址、電氣設(shè)計(jì)、設(shè)備選擇、安全保護(hù)等。以下是根據(jù)相關(guān)規(guī)范和標(biāo)準(zhǔn)整理的一些主要設(shè)計(jì)規(guī)范: 一、總則 目的與范圍 :規(guī)范適用于電壓為35~110k
    的頭像 發(fā)表于 09-26 09:32 ?5305次閱讀

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

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

    pcb設(shè)計(jì)中有哪些常用設(shè)計(jì)規(guī)范

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