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

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

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

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

Verilog編碼風(fēng)格

FPGA之家 ? 來源:FPGA之家 ? 作者:FPGA之家 ? 2022-06-26 10:46 ? 次閱讀

一、Verilog 編碼風(fēng)格

(本文的語法高亮因為瀏覽器的緣故,所以不準(zhǔn)確)

1.1 使用“`include編譯器指令”

文件包含“`include編譯器指令”用于在合成過程中將源文件的全部內(nèi)容插入到另一個文件中。它通常用于包括全局項目定義,而無需在多個文件中重復(fù)相同的代碼。另一個用例是將代碼的一部分插入模塊,如以下示例所示:

// file test_bench_top.v
// top-level simulation testbench
module test_bench_top;
`include “test_case.v”
endmodule
// file test_case.v
initialbegin
//…
end
task my_task;
//…
endtask

> include編譯器指令的語法定義為:`include

可以是文件名,還可以包含絕對或相對路徑名:

`include“test_case.v”
`include“../../includes/test_case.v”
`include“/home/myprojects/test/includes/test_case.v”

建議僅在include中使用文件名,而不要使用絕對或相對路徑名。這將使代碼位置獨立,因此更加可移植。另一個建議是保持包含文件簡單而不使用嵌套的include指令。

1.2使用`define編譯器指令,parameter和localparam


`define是文本宏替換編譯器指令。它定義為:`define

可以包含帶有可選參數(shù)列表的單行或多行文本。

`define具有全局范圍。一旦定義了文本宏名稱,就可以在項目中的任何地方使用它。文本宏通常是用于定義狀態(tài)名稱,常量或字符串的簡單標(biāo)識符。

parameter關(guān)鍵字定義模塊特定的參數(shù),該參數(shù)在特定模塊實例的范圍生效。參數(shù)用于為模塊實例提供不同的自定義,例如,輸入或輸出端口的寬度。以下是使用parameter關(guān)鍵字的示例:

module adder #(parameter WIDTH = 8) (
input[WIDTH-1:0] a,b, output [WIDTH-1:0] sum );
assign sum = a+ b;
endmodule // adder
// aninstance of adder module
adder # (16) adder1 (.a(a[15:0]),.b(b[15:0]),.sum(sum[15:0]));

localparam關(guān)鍵字與parameter相似。它被分配了一個常量表達(dá)式,并在特定模塊內(nèi)具有作用域。它定義為:

1.3 使用函數(shù)

以下是執(zhí)行XOR操作的Verilog函數(shù)的簡單示例:

module function_example( inputa,b, output func_out);
functionfunc_xor;
inputa, b;
begin
func_xor = a^ b;
end
endfunction
assign func_out = func_xor(a,b);
endmodule // function_example

建議使用Verilog函數(shù)來實現(xiàn)組合邏輯和其他不需要非阻塞分配的操作,例如同步邏輯。使用函數(shù)可以編寫更緊湊和模塊化的代碼。所有綜合工具均支持Verilog函數(shù)。

1.4使用 generate塊

在Verilog-2001中引入了generate塊,以使對同一模塊,函數(shù),變量,網(wǎng)絡(luò)和連續(xù)分配的多個實例的實例化變得容易。以下是使用generate的兩個示例:

// aconditional instantiation of modules
parameter COND1 = 1;
generate
if(COND1) begin : my_module1_inst
my_module1 inst (.clk(clk), .di(di), .do(do));
end
elsebegin : my_module2_inst
my_module2 inst (.clk(clk), .di(di), .do(do));
end
endgenerate

// using forloop in generate block
genvar ii;
generate
for(ii = 0; ii < 32; ii = ii+1) begin: for_loop
my_module1 inst (.clk(clk), .di(di[ii]), .do(do[ii]));
end
end
endgenerate

1.5 開發(fā)簡單的代碼

始終努力開發(fā)簡單的代碼。與每種編程語言一樣,Verilog允許編寫詳細(xì)的語句,從功能的角度來看,這些語句很優(yōu)美,但可讀性不高。下面的簡單示例說明了這一點:

reg [5:0] sel;
reg [3:0] result1,result2,a,b;
always @(*) begin
result1 = sel[0] ? a + b : sel[1] ? a - b :
sel[2] ? a & b : sel[3] ? a ^ b :
sel[4] ? ~a : ~ b;
if(~|sel)
result1 = 4'b0;
end// always

reg [5:0] sel;
reg [3:0] result1,result2,a,b;
always @(*) begin
casex(sel)
6'bxxxxx1: result2 = a + b;
6'bxxxx10: result2 = a - b;
6'bxxx100: result2 = a & b;
6'bxx1000: result2 = a ^+ b;
6'bx10000: result2 = ~a;
6'b100000: result2 = ~b;
default: result2 = 4'b0;
endcase
end // always

實現(xiàn)result1和result2的邏輯在功能上是等效的。但是,在result1中使用嵌套三元運算符和兩個賦值語句不太透明,并且與result2邏輯的更清晰的case語句相比,需要花更多的精力來理解。

通常,代碼清晰度高容易實現(xiàn)高效率。同一段代碼能在其生命周期內(nèi)被多個開發(fā)人員讀取。編寫更清晰的代碼更容易調(diào)試,并且一般不容易包含錯誤。

二、為FPGA編寫可綜合的代碼

2.1考慮資源

Verilog語言參考手冊(LRM)提供了豐富的功能來描述硬件。但是,只有一部分語言可以為FPGA綜和。即使有些特定的語言結(jié)構(gòu)是可綜合的,也不能保證該代碼能在特定FPGA上實現(xiàn)物理電路。考慮以下示例:

reg [7:0] memory[1:2**22];
initial begin
memory[1] = 8’h1;
memory[2] = 8’h2;
end

該示例能正確模擬出來,但會導(dǎo)致FPGA物理實現(xiàn)失敗。該代碼需要4 MB的內(nèi)存,這是一些FPGA所沒有的。此外,綜合工具將忽略初始塊,該塊將初始化內(nèi)存的最低兩個字節(jié)。

該技巧提供了一些指導(dǎo)方針和建議,以幫助編寫用于FPGA的可綜合代碼。

2.2 遵循同步設(shè)計原則

建議開發(fā)人員遵守FPGA同步設(shè)計的原則,其中包括以下內(nèi)容:

1、使用同步復(fù)位。后續(xù)會詳細(xì)討論,同步,異步復(fù)位的問題

2、避免使用鎖存

3、避免使用門控,派生或分頻時鐘

4、使用時鐘使能而不是多個時鐘

5、對所有異步信號實行正確同步

審核編輯 :李倩

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

    關(guān)注

    1629

    文章

    21754

    瀏覽量

    604236
  • Verilog
    +關(guān)注

    關(guān)注

    28

    文章

    1351

    瀏覽量

    110154

原文標(biāo)題:學(xué)習(xí)FPGA的小Tips(一)

文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

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

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

    Verilog 測試平臺設(shè)計方法 Verilog FPGA開發(fā)指南

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

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

    Verilog 與 VHDL 比較 1. 語法和風(fēng)格 VerilogVerilog 的語法更接近于 C 語言,對于有 C 語言背景的工程師來說,學(xué)習(xí)曲線較平緩。它支持結(jié)構(gòu)化編程,代
    的頭像 發(fā)表于 12-17 09:44 ?212次閱讀

    FPGA編碼風(fēng)格介紹

    組合邏輯環(huán)路(Combinational Loops):指組合邏輯的輸出信號不經(jīng)過任何時序邏輯電路(FF等),而直接反饋到輸入節(jié)點,從而構(gòu)成的電路環(huán)路。
    的頭像 發(fā)表于 11-15 10:49 ?247次閱讀
    FPGA<b class='flag-5'>編碼</b><b class='flag-5'>風(fēng)格</b>介紹

    如何自動生成verilog代碼

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

    Verilog硬件描述語言參考手冊

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

    system verilog語言簡介

    ICer需要System Verilog語言得加成,這是ICer深度的表現(xiàn)。
    發(fā)表于 11-01 10:44 ?0次下載

    如何利用Verilog-A開發(fā)器件模型

    Verilog-A對緊湊型模型的支持逐步完善,在模型的實現(xiàn)上扮演越來越重要的角色,已經(jīng)成為緊湊模型開發(fā)的新標(biāo)準(zhǔn)。而且Verilog-A能夠在抽象級別和應(yīng)用領(lǐng)域中擴(kuò)展SPICE建模和仿真功能,因此學(xué)會
    的頭像 發(fā)表于 10-18 14:16 ?520次閱讀
    如何利用<b class='flag-5'>Verilog</b>-A開發(fā)器件模型

    Verilog的版本有哪些

    電子發(fā)燒友網(wǎng)站提供《Verilog的版本有哪些.docx》資料免費下載
    發(fā)表于 05-31 11:29 ?0次下載

    8b10b編碼verilog實現(xiàn)

    8b/10b編碼是一種用于減少數(shù)據(jù)線上的低效能時鐘信號傳輸?shù)募夹g(shù),通過在數(shù)據(jù)流中插入特殊的控制字符,來同步數(shù)據(jù)和時鐘。在Verilog中實現(xiàn)8b/10b編碼器可以通過以下步驟完成: 定義8b/10b
    發(fā)表于 03-26 07:55

    verilog與其他編程語言的接口機制

    Verilog是一種硬件描述語言,用于描述數(shù)字電路的行為和結(jié)構(gòu)。與其他編程語言相比,Verilog具有與硬件緊密結(jié)合的特點,因此其接口機制也有一些與眾不同之處。本文將詳細(xì)介紹Verilog與其他編程
    的頭像 發(fā)表于 02-23 10:22 ?721次閱讀

    verilog調(diào)用模塊端口對應(yīng)方式

    Verilog是一種硬件描述語言(HDL),廣泛應(yīng)用于數(shù)字電路設(shè)計和硬件驗證。在Verilog中,模塊是構(gòu)建電路的基本單元,而模塊端口對應(yīng)方式則用于描述模塊之間信號傳遞的方式。本文將介紹
    的頭像 發(fā)表于 02-23 10:20 ?1838次閱讀

    verilog雙向端口的使用

    Verilog硬件描述語言中,端口是指連接模塊(Module)與其他模塊、寄存器或是物理設(shè)備的輸入或輸出接口。單向端口可以作為輸入或輸出使用,而雙向端口具有雙重作用,既可以接收輸入信號,又可以輸出
    的頭像 發(fā)表于 02-23 10:18 ?1462次閱讀

    verilog function函數(shù)的用法

    Verilog 是一種硬件描述語言 (HDL),主要用于描述數(shù)字電子電路的行為和結(jié)構(gòu)。在 Verilog 中,函數(shù) (Function) 是一種用于執(zhí)行特定任務(wù)并返回一個值的可重用代碼塊。函數(shù)在
    的頭像 發(fā)表于 02-22 15:49 ?5836次閱讀

    verilog的135個經(jīng)典實例

    verilog的135個經(jīng)典實例
    發(fā)表于 02-02 10:17 ?14次下載
    主站蜘蛛池模板: 国产精品久久大陆| 97在线免费观看| 男生插女生下体| 精品久久99麻豆蜜桃666| 国产噜噜噜精品免费| 国产 交换 丝雨 巅峰| 成人免费观看国产高清| 99热久久久无码国产精品性麻豆 | 亚洲 色 欧美 爱 视频 日韩| 乳色吐息在线观看全集免费观看| 欧美最猛性XXXXX肛交| 欧美性最猛xxxx在线观看视频| 欧美00后rapper潮水| 欧美精品XXXXBBBB| 欧美性色生活片天天看99顶级| 青柠在线视频| 日本免费一区二区三区四区五六区| 热中文热国产热综合| 日本熟妇乱妇熟色在线电影| 色婷婷我要去我去也| 午夜福利免费0948视频| 亚洲精品久久7777777| 亚洲三级在线看| 孕妇bbwbbwbbwbbw超清| 748亚洲大胆国模人体| a视频在线免费观看| 高清毛片一区二区三区| 国产精品人妻无码久久久蜜桃臀| 国家产午夜精品无人区| 精品国产成人AV在线看| 久久国产精品永久免费网站| 龙广在线收听| 欧美性猛交XXXX乱大交极品| 乳色吐息在线观看全集免费观看| 无限资源好看片2019免费观看| 亚洲爆乳无码精品AAA片蜜桃| 一个人的HD高清在线观看| 97豆奶视频国产| 大胸美女洗澡扒奶衣挤奶| 国产美熟女乱又伦AV| 久久99热只有频精品|