91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

如何為FPGA編寫可綜合的代碼?

FPGA之家 ? 來源:AriesOpenFPGA ? 作者:0Aries0 ? 2021-05-23 14:51 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、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中使用文件名,而不要使用絕對或相對路徑名。這將使代碼位置獨(dú)立,因此更加可移植。另一個建議是保持包含文件簡單而不使用嵌套的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)美,但可讀性不高。下面的簡單示例說明了這一點(diǎn):

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中使用嵌套三元運(yùn)算符和兩個賦值語句不太透明,并且與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、對所有異步信號實行正確同步

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

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

責(zé)任編輯:haq

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

    關(guān)注

    1660

    文章

    22415

    瀏覽量

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

    關(guān)注

    30

    文章

    4968

    瀏覽量

    73999

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

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

    智能光伏時代:&quot;四&quot;技術(shù)如何提升電站綜合價值

    ,“可觀、測、可控、可調(diào)”的“四”技術(shù),西格電力光伏四裝置咨詢:1.3.7-5.0.0.4-6.2.0.0,憑借對電站全生命周期的智能化賦能,成為提升
    的頭像 發(fā)表于 11-28 16:35 ?2039次閱讀
    智能光伏時代:&quot;四<b class='flag-5'>可</b>&quot;技術(shù)如何提升電站<b class='flag-5'>綜合</b>價值

    AMD利用重構(gòu)FPGA設(shè)備Moku實現(xiàn)自定義激光探測解決方案

    摘要本文介紹了AdvancedMicroDevices,AMD公司如何基于重構(gòu)FPGA設(shè)備自定義激光探測解決方案,替代傳統(tǒng)的儀器配置,通過靈活且定制的FPGA設(shè)備Moku提供更高效
    的頭像 發(fā)表于 11-20 17:28 ?1711次閱讀
    AMD利用<b class='flag-5'>可</b>重構(gòu)<b class='flag-5'>FPGA</b>設(shè)備Moku實現(xiàn)自定義激光探測解決方案

    開源RISC-V處理器(蜂鳥E203)學(xué)習(xí)(二)修改FPGA綜合環(huán)境(移植到自己的Xilinx FPGA板卡)

    移植到自己的板卡上。 2.運(yùn)行原FPGA工程 進(jìn)入到FPGA目錄下; gvim打開“README.md”文件,下面就是FPGA綜合的命令。 這里以最后一個:artydevkit
    發(fā)表于 10-31 08:46

    FPGA開發(fā)板vivado綜合、下載程序問題匯總

    在做vivado綜合時和FPGA下載程序時,我們碰到以下問題,并找出了對應(yīng)的解決方案。 1.could not open include file”e203_defines.v”問題 在做
    發(fā)表于 10-24 07:12

    E203軟件仿真下改變DTCM和ICTM容量的方法

    隊伍編號:CICC1304 系統(tǒng):Ubuntu20.04iverilog:12.0 E203內(nèi)核的DTCM和ICTM的默認(rèn)配置為64KB的大小。然而,我們自己編寫的應(yīng)用程序可能因為代碼量或者數(shù)據(jù)量
    發(fā)表于 10-20 12:22

    基于FPGA開發(fā)板TSP的串口通信設(shè)計

    本文詳細(xì)介紹基于Terasic FPGA開發(fā)板TSP(又名C5P和OSK)和其板載CP2102N USB-UART橋接芯片的串口通信系統(tǒng)設(shè)計與實現(xiàn)。系統(tǒng)采用Verilog HDL編寫UART收發(fā)控制器,通過CP2102N實現(xiàn)FPGA
    的頭像 發(fā)表于 10-15 11:05 ?4469次閱讀
    基于<b class='flag-5'>FPGA</b>開發(fā)板TSP的串口通信設(shè)計

    利用英特爾Agilex FPGA應(yīng)對PQC與CRA挑戰(zhàn)

    當(dāng)下,半導(dǎo)體行業(yè)的安全需求正經(jīng)歷深刻演變,后量子密碼學(xué)(PQC)與 《網(wǎng)絡(luò)彈性法案》(CRA)成為繞不開的重要議題。跟隨本文一起,深入剖析這兩大趨勢帶來的挑戰(zhàn),并詳解 Altera Agilex 3、Agilex 5 FPGA 及 SoC 的全新功能,如何為行業(yè)構(gòu)建面向未
    的頭像 發(fā)表于 08-08 17:11 ?4333次閱讀
    利用英特爾Agilex <b class='flag-5'>FPGA</b>應(yīng)對PQC與CRA挑戰(zhàn)

    RTOS SDK的canmv_net_mgmt網(wǎng)絡(luò)模塊如何編寫連接代碼?

    從最近源碼更新了一次后,以前的可執(zhí)行文件使用出錯了,請問有沒有大哥知道新一版源碼怎么編寫代碼進(jìn)行操作網(wǎng)絡(luò)模塊canmv_net_mgmt。 或者是操作canmv_net_mgmt的頭文件都是哪些,可以參考些什么
    發(fā)表于 07-25 08:14

    基于FPGA的壓縮算法加速實現(xiàn)

    法的速度。我們將首先使用C語言進(jìn)行代碼實現(xiàn),然后在Vivado HLS中綜合實現(xiàn),并最終在FPGA板(pynq-z2)上進(jìn)行硬件實現(xiàn),同時于jupyter notebook中使用python來進(jìn)行功能驗證。
    的頭像 發(fā)表于 07-10 11:09 ?2400次閱讀
    基于<b class='flag-5'>FPGA</b>的壓縮算法加速實現(xiàn)

    何為 Android 操作系統(tǒng)/設(shè)備生成 APK ?

    何為 Android 操作系統(tǒng)/設(shè)備生成 APK ?
    發(fā)表于 06-30 07:12

    【經(jīng)驗分享】玩轉(zhuǎn)FPGA串口通信:從“幻覺調(diào)試”到代碼解析

    FPGA開發(fā),思路先行!玩FPGA板子,讀代碼是基本功!尤其對從C語言轉(zhuǎn)戰(zhàn)FPGA的“寶貝們”來說,適應(yīng)流水線(pipeline)編程可能需要點(diǎn)時間。上篇點(diǎn)燈
    的頭像 發(fā)表于 06-05 08:05 ?1111次閱讀
    【經(jīng)驗分享】玩轉(zhuǎn)<b class='flag-5'>FPGA</b>串口通信:從“幻覺調(diào)試”到<b class='flag-5'>代碼</b>解析

    RAKsmart企業(yè)服務(wù)器上部署DeepSeek編寫運(yùn)行代碼

    在RAKsmart企業(yè)服務(wù)器上部署并運(yùn)行DeepSeek模型的代碼示例和詳細(xì)步驟。假設(shè)使用 Python + Transformers庫 + FastAPI實現(xiàn)一個基礎(chǔ)的AI服務(wù)。主機(jī)推薦小編為您整理發(fā)布RAKsmart企業(yè)服務(wù)器上部署DeepSeek編寫運(yùn)行
    的頭像 發(fā)表于 03-25 10:39 ?708次閱讀

    MCXN947使用ADC并編寫代碼,總是報警告是怎么回事?

    我使用 MCXN947,我想使用 ADC 并編寫代碼,但警告總是發(fā)生。然后我創(chuàng)建了一個新項目進(jìn)行調(diào)試,它仍然發(fā)生了。 我試著打掃,但還是沒用。 警告:無法將 \'main\' 從主機(jī)編碼 (CP1252) 轉(zhuǎn)換為 UTF-32。 這通常不會發(fā)生,請?zhí)峤?bug 報告。
    發(fā)表于 03-20 08:17

    27個FPGA實例源代碼

    本資料收集匯總了27個FPGA實例源代碼,有需要的可以下載學(xué)習(xí)! 獲取完整文檔資料可下載附件哦!?。。∪绻麅?nèi)容有幫助可以關(guān)注、點(diǎn)贊、評論支持一下哦~
    發(fā)表于 03-14 17:31

    何為micropython添加自己的C代碼庫?

    部分代碼需要更高效的效率 如何為micropython添加自己的C代碼庫? 是否有教程? 如果可以的話是否可以提供一個實現(xiàn)實例?
    發(fā)表于 03-11 07:03