《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 可編程邏輯 > 業(yè)界動態(tài) > 零基礎(chǔ)教你學(xué)FPGA之Verilog語法基礎(chǔ)(上)

零基礎(chǔ)教你學(xué)FPGA之Verilog語法基礎(chǔ)(上)

2015-02-09
關(guān)鍵詞: FPGA Verilog 基礎(chǔ)

    這幾天復(fù)習(xí)了一下Verilog的語法知識,就借此寫寫我對這些東西的想法吧。感覺呢,是和C語言差不多,具有C語言基礎(chǔ)的朋友學(xué)起來應(yīng)該沒什么問題,和C語言相同的地方就不說了吧,重點說一下不同點吧。

  1、模塊的結(jié)構(gòu)

  模塊呢,是Verilog的基本設(shè)計單元,它主要是由兩部分組成,一個是接口,另一個是邏輯。下面舉一個小例子說明一下:

  module xiaomo (a,b,c,d);

  input a,b;

  output c,d;

  assign c=a|b;

  assign d=a&b;

  endmodule

  所謂接口就是第二,三行,說明了一個模塊的信號流向,很明顯,a,b是輸入,c,d是輸出;第四第五行是邏輯,即輸入和輸出之間的關(guān)系即c的值是a或b的結(jié)果。assign 是連續(xù)賦值語句,這個以后再說。

  第一行是模塊的端口聲明,即說明一個模塊具體有那幾個接口,有多少接口寫多少,直接套模板就可以module(接口1,接口2……);endmodule代表此模塊結(jié)束;

  2、模塊的內(nèi)容

  模塊的內(nèi)容包括3個部分,I/O說明,內(nèi)部信號說明和功能定義。

  關(guān)于I/O說明有三種格式,即輸入、輸出、輸入輸出,第三種格式代表信號可以雙向傳送。在寫I/O說明的時候要注明信號位寬,即由幾位組成,例 如 input [7:0] xiaomo;代表輸入一個8位的信號“小墨”,注意這里要用中括號,第一位是位寬減1,接一個冒號,再接數(shù)字0,再接端口名;

  關(guān)于內(nèi)部信號說明要用到和端口有關(guān)的wire和reg類型變量的聲明。模板和上面類似,關(guān)于reg和wire變量后面再說。

  關(guān)于功能定義是模塊中最重要的部分,有三種方法可在模塊中產(chǎn)生邏輯

  (1)用assign聲明語句,assign 語句主要用于組合邏輯電路

  (2)用實例元件,例如 and #2 u1(q,a,b);(這個我自己概念也有點模糊,不知道怎么解釋)

  (3)用always塊,例如 always @(clk or clr)

  begin

  ………

  end;

  always語句既可以用于描述組合邏輯,也可以描述時序邏輯,但主要以描述時序邏輯電路為主。

  小結(jié)

  在verilog語法中,所有的過程塊(包括initial塊,always塊),連續(xù)賦值語句,實例引用都是并行的,也就是說在一個模塊中遇 到這些語句就是同時執(zhí)行的,而且沒有先后次序。只有連續(xù)賦值語句assign和實例引用語句可以獨立于過程塊存在于模塊的功能定義部分,即這兩種語句可以 不用在那兩個過程塊里執(zhí)行,也可以在模塊的功能定義部分執(zhí)行,例如第一個例子。

  這些和C語言有點不同,對于初學(xué)者來說應(yīng)該都要弄明白。

  3、數(shù)據(jù)類型、變量、常量

  對于初學(xué)者來說,數(shù)據(jù)類型只要掌握好reg,wire,integer和parameter型就夠了,其他類型可以暫時不用去理會。

  (1)常量就不說了,比較基礎(chǔ)。

  (2)參數(shù)型(parameter型)

  parameter是用來定義一個常量的,個人理解和C語言里面的int,float 語句一樣,不一樣的是parameter既可以定義整型,也可以定義浮點型或者是表達式。例如

  

360桌面截圖20140225201109.jpg

 

  (3)變量

  wire型數(shù)據(jù)常用來表示用以assign關(guān)鍵字指定的組合邏輯信號。Verilog程序模塊中輸入、輸出信號類型默認時自動定義成wire型。例子

  

360桌面截圖20140225202514.jpg

 

  reg型數(shù)據(jù)是寄存器變量,常用來表示always塊中的指定信號,常代表觸發(fā)器。注意,在always塊中被賦值 的每一個信號都必須定義為reg型

  。

  

360桌面截圖20140225202921.jpg

 

  

360桌面截圖20140225203249.jpg

 

  上面這句話表示不理解,求大神解釋...先放這兒吧..

  memory型

  由于Verilog中沒有多維數(shù)組的存在,memory數(shù)據(jù)就是通過擴展reg型數(shù)據(jù)的地址范圍來生成的,他的格式為

  reg[n-1:0] 存儲器名[m-1:0];

  我舉個例子,比如我定義 reg[7:0] xiaomo[255:0];

  這句話的意思是說,我定義了一個名叫“小墨”的存儲器,這個存儲器中有256個8位reg型寄存器,只要理解了這句話,就差不多了。注意,當沒有中括號時代表的是一位,例如

  reg xiaomo[m-1:0];代表一個名為“小墨”的存儲器,里面有m個1位的reg型寄存器。

 還有個地方我感覺不太明白,見下圖,誰知道這句話上面意思...求大神解釋...

 

  

360桌面截圖20140225204415.jpg

 

  下面這幾句話需要注意

  

360桌面截圖20140225204900.jpg

 

  4、運算符及表達式

  這里和C語言幾乎一樣,就不做過多解釋了吧。就說一下位拼接運算符和位減運算符,這里C語言里面沒有。

  直接看個例子就可以

  

360桌面截圖20140225205538.jpg

 

  

360桌面截圖20140225205844.jpg

 

  5、賦值語句

  賦值語句共有兩種,即非阻塞賦值,和阻塞賦值。

  (1)非阻塞賦值

  非阻塞賦值方式所賦值的變量不能立即就為下面語句所用,只有當塊結(jié)束后才能得到上一次所附的值,這種賦值方式是編寫可綜合的時序邏輯時常用的賦值方式。例如

  

360桌面截圖20140225211312.jpg

 

  這個例子的意思是,當時鐘上升沿到來時,a的值給b,b的值給c,但是只有當塊結(jié)束時才完成賦值,這么說吧,假如原來a=1,b=2那么當時鐘上升沿到來時a=1,b=2,c=2;當塊結(jié)束時,a=b=c=1;

  這么理解對嗎?求大神指點...

  

360桌面截圖20140225211856.jpg

 

  (2)阻塞賦值

  與非阻塞賦值不同,賦值語句執(zhí)行完后塊才結(jié)束,b 的值在賦值語句結(jié)束后立刻改變,但是在時序邏輯電路中可能會出問題。

  always @(clk or clr);

  begin

  b=a;

  c=b;

  end

  假如開始a=1;當當時鐘上升沿到來時,a=b=c=1;然后塊結(jié)束

  

360桌面截圖20140225212539.jpg

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經(jīng)濟損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
一本一本久久a久久精品牛牛影视| 欧美一区亚洲二区| 国产亚洲精品久久久久婷婷瑜伽 | 欧美视频中文一区二区三区在线观看 | 亚洲视频中文| 999在线观看精品免费不卡网站| 亚洲高清精品中出| 影音先锋中文字幕一区| 一区二区三区在线免费播放| 国产一区视频在线观看免费| 国产欧美婷婷中文| 国产日产亚洲精品| 国产一区二区高清不卡| 国产在线拍偷自揄拍精品| 国产视频一区在线观看一区免费| 国产欧美欧美| 国产亚洲电影| 韩国一区电影| 亚洲国产精品一区制服丝袜| 亚洲激情综合| 亚洲精品美女在线观看播放| 日韩视频精品在线观看| 一区二区三区www| 亚洲午夜久久久久久久久电影网| 亚洲一级黄色| 欧美一级免费视频| 亚洲高清精品中出| 亚洲人成网站色ww在线| 亚洲美女福利视频网站| 亚洲午夜精品一区二区三区他趣 | 国产精品一区毛片| 国产三级欧美三级| 精品99一区二区| 91久久亚洲| 亚洲天堂av在线免费| 先锋影音网一区二区| 亚洲国产高潮在线观看| 亚洲美女av网站| 亚洲欧美日韩一区二区三区在线观看 | 久久亚洲综合色| 久久色在线播放| 美女视频黄免费的久久| 欧美好骚综合网| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 欧美制服丝袜| 亚洲精品视频一区| 一本久久综合| 欧美一区二区三区日韩| 久久综合导航| 欧美午夜大胆人体| 国内精品美女在线观看| 亚洲另类春色国产| 欧美亚洲视频在线观看| 亚洲人成在线播放| 亚洲欧美日韩一区在线| 久久综合久久久久88| 欧美日韩另类丝袜其他| 国产视频在线观看一区二区| 亚洲国产高清自拍| 亚洲一区尤物| 亚洲精品国精品久久99热一| 午夜精品久久久久| 欧美顶级大胆免费视频| 国产精品国产自产拍高清av| 狠狠色丁香婷综合久久| 99热这里只有成人精品国产| 新片速递亚洲合集欧美合集| 亚洲免费电影在线| 久久精品99| 欧美日韩亚洲一区二区| 激情小说另类小说亚洲欧美 | 亚洲第一精品夜夜躁人人爽| 亚洲少妇中出一区| 久久综合狠狠综合久久激情| 国产精品成人一区二区| 亚洲国产日韩一级| 久久成人精品| 亚洲欧美国产精品va在线观看| 欧美777四色影视在线| 国产精品一区毛片| 亚洲精品孕妇| 最新亚洲电影| 欧美怡红院视频| 欧美少妇一区二区| 在线欧美视频| 欧美亚洲免费在线| 亚洲综合999| 欧美精品国产精品| 激情综合网激情| 亚洲欧美日韩在线不卡| 日韩午夜剧场| 免费高清在线视频一区·| 国产欧美日韩综合| 亚洲视频久久| 中文一区二区| 欧美精品福利视频| 亚洲国产成人精品女人久久久| 性亚洲最疯狂xxxx高清| 亚洲欧美日韩在线播放| 欧美日韩一区二区视频在线 | 欧美阿v一级看视频| 国产一区二区三区在线免费观看| 中文精品视频一区二区在线观看| 亚洲精品一二区| 欧美99久久| 亚洲第一狼人社区| 亚洲高清免费视频| 久久婷婷国产综合精品青草| 国产日韩欧美不卡| 亚洲欧美日韩一区二区| 亚洲欧美一区二区精品久久久| 欧美日韩中文字幕在线| 亚洲精品在线免费| 亚洲免费精品| 欧美国产在线观看| 亚洲国产高清在线| 亚洲精品人人| 欧美精品综合| 亚洲人成网站在线观看播放| 亚洲精品一品区二品区三品区| 男人的天堂亚洲| 亚洲黄色在线视频| 亚洲精选久久| 欧美日韩的一区二区| 亚洲麻豆国产自偷在线| 一二三区精品福利视频| 欧美日韩18| 一本色道久久综合狠狠躁篇的优点 | 亚洲精品日韩一| 一区二区三区精品| 欧美日韩国产探花| 夜夜嗨av一区二区三区四季av| 一区二区三区四区蜜桃| 欧美日韩亚洲综合| 亚洲一卡二卡三卡四卡五卡| 香蕉乱码成人久久天堂爱免费 | 欧美一区二区三区电影在线观看| 久久久精品一区| 伊人婷婷久久| 99国内精品| 欧美深夜福利| 亚洲免费伊人电影在线观看av| 欧美影片第一页| 国产真实乱子伦精品视频| 亚洲黄色免费| 欧美日韩国产影片| 亚洲午夜精品福利| 久久精品在线| 亚洲国产你懂的| 亚洲性夜色噜噜噜7777| 国产精品视频网站| 久久国产精品亚洲va麻豆| 欧美成人第一页| 99精品免费视频| 久久精品国产亚洲一区二区三区| 尤物99国产成人精品视频| 一本色道久久综合狠狠躁篇的优点| 国产精品久久久久久久久借妻| 欧美在线一区二区| 欧美日本免费| 香蕉精品999视频一区二区| 免费久久精品视频| 一区二区三区精密机械公司| 欧美一区二区私人影院日本| 影音先锋另类| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 国产欧美一区二区三区在线老狼 | 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲日本中文字幕免费在线不卡| 亚洲综合电影| 影音先锋久久久| 亚洲欧美日韩区| 亚洲国内自拍| 久久国内精品视频| 日韩一级黄色av| 巨乳诱惑日韩免费av| 中文欧美在线视频| 久久综合网hezyo| 亚洲视频欧美视频| 欧美99在线视频观看| 亚洲综合色噜噜狠狠| 欧美成人免费在线| 欧美一区二区黄| 欧美日韩国产精品一区| 久久成人人人人精品欧| 欧美日韩视频免费播放| 久久不射网站| 国产精品人成在线观看免费| 最新国产成人在线观看| 国产精品免费一区二区三区观看| 亚洲欧洲久久| 国产一区二区三区久久久| 在线视频精品一区| 尤物网精品视频| 久久国产福利| 亚洲午夜在线观看视频在线| 欧美精品18| 亚洲激情在线视频| 国产综合欧美| 欧美影院久久久|