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

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

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

一位FPGA工程師的工作日常

工程師人生 ? 來源:FPGA之家 ? 作者:FPGA之家 ? 2020-11-30 12:03 ? 次閱讀

在正式開始之前,我們先看看一位FPGA工程師的工作日常:

開始設(shè)計(jì)代碼
開始寫第一個always代碼
發(fā)現(xiàn)要增加一個信號,因此寫第二個always,設(shè)計(jì)這個新增的信號
回到第一個always上,繼續(xù)完善這個代碼
開始寫第三個always代碼
感覺第一個always有情況沒考慮到
一陣重新思考
回去修改第一個always的代碼
寫完后,得了,不檢查代碼了,仿真再說吧。

仿真過程
每個時鐘上升沿一個一個檢查
發(fā)現(xiàn)這時某信號沒有變高
檢查代碼,把BUG補(bǔ)上
繼續(xù)檢查波形,繼續(xù)補(bǔ)BUG
發(fā)現(xiàn)信號A和B時序?qū)Σ积R
思考是打補(bǔ)丁呢還是打補(bǔ)丁呢
是改這個信號呢,還是改那個信號,還是加一個信號
一番折騰后,終于對齊了
修改測試文件,再測試
還是有BUG,繼續(xù)打補(bǔ)丁

該上板調(diào)試了
系統(tǒng)跑一會沒問題,長時間跑就出BUG
用調(diào)試工具各種分析各種定位
一番折騰后,終于找到BUG
一個corner沒想到/粗心大意漏了個條件/
早知道,要沒這BUG,我早就做完了

又出現(xiàn)BUG了,又要來折騰啦。

這個場景是不是覺得很熟悉?還有下面這些情形也許都遇到過:一個項(xiàng)目看上去很簡單,精心設(shè)置了架構(gòu),結(jié)果越做發(fā)現(xiàn)沖突越多,直到整個邏輯完全混亂。本來一天可以的完成的事不知道怎么搞的一個星期還沒有完成;本來只需要做一行更改,結(jié)果卻涉及到N個模塊;出現(xiàn)了一個非常小的BUG打了一個補(bǔ)丁,然后補(bǔ)丁越來越多,到最后無法解決。諸如此類等等情況不一而足,究其原因,總離不開“混亂”兩個字。這些混亂的根源是什么?又該如何解決呢?

一個好的FPGA項(xiàng)目的設(shè)計(jì)作品,不僅依賴于架構(gòu)設(shè)計(jì),優(yōu)秀的代碼也是必不可少的關(guān)鍵因素。而好的代碼最基本的就是清晰整潔。整潔的代碼運(yùn)行穩(wěn)定,也是后期維護(hù)和升級的基礎(chǔ)。正如C++語言發(fā)明者Bjarne Stroustrup說的那樣:“代碼邏輯應(yīng)當(dāng)直截了當(dāng),叫缺陷難以隱藏;盡量減少依賴關(guān)系,使之便于維護(hù);依據(jù)某種分層戰(zhàn)略完善錯誤處理代碼;性能調(diào)至最優(yōu),避免其他人優(yōu)化時不知所措從而出現(xiàn)混亂狀態(tài)。整潔的代碼只做好一件事。”

這段話說得實(shí)在太好了,整潔的代碼只去做好一件事。事實(shí)上,有兩點(diǎn)只要做到了,就可以大大提高自己代碼的整潔度。第一、寫簡單的代碼;第二、把復(fù)雜的代碼簡單化。下面我們通過一個小的實(shí)例來說明一下。我們先來看這樣一組代碼:

always @(posedge clk or negedge rst_n)begin

if(rst_n==1'b0)begin

shi_ge

end

else if(((set_flag == 1'b1 && set_sel == 4)&& (key_vld == 1 && key_num == 4'b0010)) || shi_ge_add)begin

if(shi_shi ==2 && shi_ge == 3)begin

shi_ge

end

else if((shi_shi == 0 || shi_shi ==1) && shi_ge == 9)begin

shi_ge

end

else begin

shi_ge

end

end

end

這個程序時一個數(shù)字時鐘功能的其中一份關(guān)于小時個位的代碼。小時個位復(fù)位等于0(第3行代碼);設(shè)置的語句(第5行代碼),意思是當(dāng)你選中小時的個位并且按鍵按下去,小時個位+1,或者說正常情況下一個小時+1。這里需要注意的是:首先小時的計(jì)數(shù)方式在0:00——9:00,10:00——19:00,20:00——23:00情況下+1;另外幾個時間點(diǎn)清零。

我們來分析一下,在這份代碼的設(shè)計(jì)中需要考慮到很多因素。第一、需要考慮按鍵;第二、按下去時與正常計(jì)數(shù)的關(guān)系;第三、需要數(shù)多少次清零,比如說9點(diǎn)、19點(diǎn)、23點(diǎn)清零;當(dāng)很多因素混在一起去考慮,特別是格式?jīng)]有被規(guī)范的時候,就容易出現(xiàn)混亂、遺漏點(diǎn)或是相互之間出現(xiàn)沖突,出錯的可能性隨之變大。

接下來我們來看另外一組代碼的思路和操作。

首先,我們建立一個通用的計(jì)數(shù)器模板,命名為jsq。每次遇到計(jì)數(shù)器,只需要輸入JSq,即可調(diào)入該模板。(注:關(guān)于模板的設(shè)置以后章節(jié)介紹)

always @(posedge clk or negedge rst_n)begin

if(!rst_n)begin

cnt

end

else if(add_cnt)begin

if(end_cnt)

cnt

else

cnt

end

end

assign add_cnt = ;

assign end_cnt = add_cnt && cnt== ;

接下來設(shè)置什么時候個位+1,分為兩種情況:1、按鍵按下去;2、自然計(jì)數(shù)+1;(第13行)

采用變量法設(shè)置X-1;即先不用去管數(shù)多少下,反正數(shù)完就清零;(第14行)

最后我們設(shè)置數(shù)多少下。20:00時數(shù)4下;其它時候數(shù)10下;(16~21行)

always @(posedge clk or negedge rst_n)begin

if(!rst_n)begin

cnt

end

else if(add_cnt)begin

if(end_cnt)

cnt

else

cnt

end

end

assign add_cnt =((set_flag == 1'b1 && set_sel == 4)&& (key_vld == 1 && key_num == 4'b0010)) || shi_ge_add ;

assign end_cnt = add_cnt && cnt== x-1 ;

always @(*)begin

if(shi_s == 2)

x = 4 ;

else

x = 10 ;

end

現(xiàn)在我們來回顧一下這段代碼,從中不難發(fā)現(xiàn),設(shè)計(jì)的總體思路有著嚴(yán)密的邏輯和步驟,并采取了便捷工具(模板)來規(guī)范了代碼編寫,減少了設(shè)計(jì)量。最重要的是設(shè)計(jì)者的意圖清晰了然,控制語句直截了當(dāng),代碼之間相互依賴性非常低,作者之外的開發(fā)者閱讀和增補(bǔ)非常輕松。

這一節(jié)我們講到了代碼混亂的根源及解決這個問題的技巧,下一節(jié)我們要講到的是簡單代碼規(guī)則的技巧。

編輯:hfy


聲明:本文內(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)注

    1630

    文章

    21796

    瀏覽量

    605523
  • 工程師
    +關(guān)注

    關(guān)注

    59

    文章

    1571

    瀏覽量

    68612
收藏 人收藏

    評論

    相關(guān)推薦

    硬件工程師工作前VS工作后!抱歉!是我想的太簡單了!# #電工 #電子愛好者

    硬件工程師
    MDD辰達(dá)半導(dǎo)體
    發(fā)布于 :2025年01月08日 18:15:18

    硬件工程師工作必備書籍推薦

    硬件工程師工作必備書籍推薦
    的頭像 發(fā)表于 09-24 16:07 ?1016次閱讀
    硬件<b class='flag-5'>工程師</b>找<b class='flag-5'>工作</b>必備書籍推薦

    FPGA算法工程師、邏輯工程師、原型驗(yàn)證工程師有什么區(qū)別?

    邏輯工程師FPGA 原型驗(yàn)證工程師工作重點(diǎn)和職責(zé)上存在定的區(qū)別: FPGA 算法
    發(fā)表于 09-23 18:26

    尋求專業(yè)工程師幫助設(shè)計(jì)USB多口充電器

    嗨, 我正在開發(fā)款USB多口充電器,現(xiàn)尋求一位專業(yè)工程師或產(chǎn)品設(shè)計(jì)的幫助。希望能夠與有經(jīng)驗(yàn)的工程師合作,共同完成產(chǎn)品設(shè)計(jì)。以下是我們的需
    發(fā)表于 08-05 12:03

    嵌入式軟件工程師如何提升自己?

    ,可以為自己的職業(yè)生涯打下堅(jiān)實(shí)的基礎(chǔ),并實(shí)現(xiàn)個人的職業(yè)目標(biāo)。愿每一位嵌入式軟件工程師都能在這個充滿挑戰(zhàn)和機(jī)遇的領(lǐng)域中取得成功!
    發(fā)表于 06-12 11:20

    嵌入式軟件工程師和硬件工程師的區(qū)別?

    和通信協(xié)議,以及熟練掌握種或多種編程語言和開發(fā)工具。 主要負(fù)責(zé)的任務(wù)和領(lǐng)域 嵌入式軟件工程師工作涉及到各種任務(wù),主要包括: * 系統(tǒng)設(shè)計(jì):包括確定系統(tǒng)功能、分配資源、優(yōu)化性能等。 * 軟件編程:包括編程
    發(fā)表于 05-16 11:00

    大廠電子工程師常見面試題#電子工程師 #硬件工程師 #電路知識 #面試題

    電子工程師電路
    安泰小課堂
    發(fā)布于 :2024年04月30日 17:33:15

    為何國外工程師偏愛使用for(;;)來實(shí)現(xiàn)MCU死循環(huán)?

    一位工程師發(fā)現(xiàn),國外工程師在給demo在做死循環(huán)時用的是for(;;),而不是常用的while(1)。這僅僅是個人習(xí)慣的問題,還是有更深層次的含義?
    發(fā)表于 04-01 11:26 ?705次閱讀
    為何國外<b class='flag-5'>工程師</b>偏愛使用for(;;)來實(shí)現(xiàn)MCU死循環(huán)?

    fpga工程師前景如何

    FPGA工程師的前景看起來相當(dāng)積極和廣闊。隨著5G通信、物聯(lián)網(wǎng)、邊緣計(jì)算和人工智能等技術(shù)的快速發(fā)展,FPGA工程師的需求將進(jìn)步增加。
    的頭像 發(fā)表于 03-14 16:32 ?3260次閱讀

    fpga工程師就業(yè)趨勢

    FPGA工程師的就業(yè)趨勢呈現(xiàn)出積極的態(tài)勢。隨著科技的發(fā)展,FPGA(現(xiàn)場可編程門陣列)在通信、汽車、醫(yī)療、航空航天等領(lǐng)域的應(yīng)用越來越廣泛,對FPGA
    的頭像 發(fā)表于 03-14 15:47 ?1668次閱讀

    一位硬件工程師的歷練之路:從入門學(xué)習(xí)理論到... #搞笑 #硬件工程師 #電子工程師 #揚(yáng)興科技

    硬件工程師揚(yáng)興科技
    揚(yáng)興科技
    發(fā)布于 :2024年03月13日 17:50:21