真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯網站制作重慶分公司

如何用VerilogBasics設計一個仲裁器

這篇文章主要介紹“如何用Verilog Basics設計一個仲裁器”,在日常操作中,相信很多人在如何用Verilog Basics設計一個仲裁器問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何用Verilog Basics設計一個仲裁器”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:國際域名空間、網絡空間、營銷軟件、網站建設、簡陽網站維護、網站推廣。

Introduction

每個Verilog初學者的夢想是在一天內理解它,至少到達足夠使用的程度。接下來的Verilog Basics的幾篇文章將會讓這個夢想成為現實。

盡管Verilog是并行地執(zhí)行不同的代碼塊,但它和大多數順序執(zhí)行的編程語言仍有許多相似之處。我們需要的只是一些數字電路的基礎

在Verilog出現之前,電路設計者使用原理圖進行電路設計。無論復雜程度如何,每個設計都是通過原理圖設計的。這使得設計難以驗證并且容易出錯,導致設計...驗證,設計...驗證,設計...驗證,設計...驗證。。。繁瑣的迭代。

當Verilog出現時,我們對數字電路設計有了不同的思維方式。使用Verilog進行數字電路的功能設計周期類似于傳統(tǒng)的程序開發(fā)周期。

  • Specifications (specs)

  • High level design

  • Low level (micro) design

  • RTL coding

  • Verification

  • Synthesis.

首先我們需要一個specifications,列出我們對設計的限制(restrictions)和要求(requirements

本教程,我們將設計一個仲裁器(arbiter),以下是仲裁器的一些規(guī)范。

兩個agent 

異步復位,高有效

固定優(yōu)先級,agent0優(yōu)先于agent1

在我們有了規(guī)范之后,我們就可以繪制框圖,即設計數據流的黑匣子。

Block diagram of arbiter

如何用Verilog Basics設計一個仲裁器

如果沒有Verilog,下一步我們需要開始繪制狀態(tài)機。我們制作一個具有狀態(tài)轉換的真值表,然后繪制卡諾圖并化簡優(yōu)化電路。

如何用Verilog Basics設計一個仲裁器

每個圓圈表示狀態(tài)可能處于的狀態(tài)。每個狀態(tài)都有相對應的輸出。狀態(tài)之間的箭頭是不同事件導致的狀態(tài)轉換。

例如,最左邊的橙色箭頭表示如果機器處于GNT0狀態(tài)(輸出對應于GNT0的信號)并接收到!req_0的輸入,則狀態(tài)機移動到狀態(tài)IDLE并輸出與之對應的信號。 

這種設計方法適用于小型設計,但對于大型設計,這種流程變得復雜且容易出錯。這就是Verilog的用武之地。

Modules

在仲裁塊的框圖中,我們可以看到它有一個名字(“arbiter”)和輸入/輸出端口(req_0,req_1,gnt_0和gnt_1)。

在Verilog中,我們使用module來描述這個具有相同輸入和輸出的黑匣子。

此代碼如下所示。

module arbiter (// Two slashes make a comment line.clock , // clockreset , // Active high, syn resetreq_0 , // Request 0req_1 , // Request 1gnt_0 , // Grant 0gnt_1 // Grant 1);//-------------Input Ports-----------------------------// Note : all commands are semicolon-delimitedinput clock ;input reset ;input req_0 ;input req_1 ;//-------------Output Ports----------------------------output gnt_0 ;output gnt_1 ;

Data Type

在硬件中存在兩種數據類型

1、可以存儲值的數據類型(例如:flip-flop)。

2、無法存儲值的數據類型,但可以連接兩個點(例如:wire)。

第一種類型在Verilog中稱為reg(“register”的縮寫)。第二種數據類型稱為導線(“wire”)。

例如:

wire and_gate_output; reg d_flip_flop_output; reg [7:0] address_bus;

Operators

Verilog中的運算符與其他編程語言幾乎相同。 

Operator Type

Operator Symbol

Operation Performed

Arithmetic

*

Multiply


/

Division


+

Add


-

Subtract


%

Modulus


+

Unary plus


-

Unary minus

Logical

!

Logical negation


&&

Logical and


||

Logical or

Relational

>

Greater than


<

Less than


>=

Greater than or equal


<=

Less than or equal

Equality

==

Equality


!=

inequality

Reduction

~

Bitwise negation


~&

nand


|

or


~|

nor


^

xor


^~

xnor


~^

xnor

Shift

>>

Right shift


<<

Left shift

Concatenation

{ }

Concatenation

Conditional

?

conditional

例如:

a = b + c; a = 1 << 5; a =!b; a = ~b;

到此,關于“如何用Verilog Basics設計一個仲裁器”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注創(chuàng)新互聯網站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
網站欄目:如何用VerilogBasics設計一個仲裁器
瀏覽地址:http://weahome.cn/article/pjesgi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部