




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
一個(gè)簡單的RTL同步FIFO設(shè)計(jì)FIFO是FPGA設(shè)計(jì)中最有用的模塊之一。FIFO在模塊之間提供簡單的握手和同步機(jī)制,是設(shè)計(jì)人員將數(shù)據(jù)從一個(gè)模塊傳輸?shù)搅硪粋€(gè)模塊的常用選擇。在這篇文章中,展示了一個(gè)簡單的RTL同步FIFO,可以直接在自己的設(shè)計(jì)中配置和使用它,該設(shè)計(jì)是完全可綜合的。為什么要自己設(shè)計(jì)FIFO那么,為什么呢?網(wǎng)上有很多關(guān)于FIFO的Verilog/VHDL代碼的資源,過去,我自己也使用過其中的一些。但令人沮喪的是,它們中的大多數(shù)都存在問題,尤其是在上溢出和下溢出條件下。所以想一勞永逸地解決這些問題。FIFO規(guī)格性能同步,單時(shí)鐘?;诩拇嫫鞯腇IFO,適用于中小型FIFO。Full、Empty、Almost-full、Almost-empty標(biāo)志。完全可配置的數(shù)據(jù)寬度、深度和標(biāo)志。完全可綜合的系統(tǒng)Verilog代碼。
/*===============================================================================================================================
Design
:
Single-clock
Synchronous
FIFO
Description
:
Fully
synthesisable,
configurable
Single-clock
Synchronous
FIFO
based
on
registers.
-
Configurable
Data
width.
-
Configurable
Depth.
-
Configurable
Almost-full
and
Almost-empty
signals.
===============================================================================================================================*/module
my_fifo
#(
parameter
DATA_W
=
4
,
//
Data
width
parameter
DEPTH
=
8
,
//
Depth
of
FIFO
parameter
UPP_TH
=
4
,
//
Upper
threshold
to
generate
Almost-full
parameter
LOW_TH
=
2
//
Lower
threshold
to
generate
Almost-empty
)
(
input
clk
,
//
Clock
input
rstn
,
//
Active-low
Synchronous
Reset
input
i_wren
,
//
Write
Enable
input
[DATA_W
-
1
:
0]
i_wrdata
,
//
Write-data
output
o_alm_full
,
//
Almost-full
signal
output
o_full
,
//
Full
signal
input
i_rden
,
//
Read
Enable
output
[DATA_W
-
1
:
0]
o_rddata
,
//
Read-data
output
o_alm_empty
,
//
Almost-empty
signal
output
o_empty
//
Empty
signal
);/*-------------------------------------------------------------------------------------------------------------------------------
Internal
Registers/Signals-------------------------------------------------------------------------------------------------------------------------------*/logic
[DATA_W
-
1
:
0]
data_rg
[DEPTH]
;
//
Data
arraylogic
[$clog2(DEPTH)
-
1
:
0]
wrptr_rg
;
//
Write
pointerlogic
[$clog2(DEPTH)
-
1
:
0]
rdptr_rg
;
//
Read
pointerlogic
[$clog2(DEPTH)
:
0]
dcount_rg
;
//
Data
counter
logic
wren_s
;
//
Write
Enable
signal
generated
iff
FIFO
is
not
fulllogic
rden_s
;
//
Read
Enable
signal
generated
iff
FIFO
is
not
emptylogic
full_s
;
//
Full
signallogic
empty_s
;
//
Empty
signal/*-------------------------------------------------------------------------------------------------------------------------------
Synchronous
logic
to
write
to
and
read
from
FIFO-------------------------------------------------------------------------------------------------------------------------------*/always
@
(posedge
clk)
begin
if
(!rstn)
begin
data_rg
<=
'{default:
'0}
;
wrptr_rg
<=
0
;
rdptr_rg
<=
0
;
dcount_rg
<=
0
;
end
else
begin
ready_rg
<=
1'b1
;
/*
FIFO
write
logic
*/
if
(wren_s)
begin
data_rg
[wrptr_rg]
<=
i_wrdata
;
//
Data
written
to
FIFO
if
(wrptr_rg
==
DEPTH
-
1)
begin
wrptr_rg
<=
0
;
//
Reset
write
pointer
end
else
begin
wrptr_rg
<=
wrptr_rg
+
1
;
//
Increment
write
pointer
end
end
/*
FIFO
read
logic
*/
if
(rden_s)
begin
if
(rdptr_rg
==
DEPTH
-
1)
begin
rdptr_rg
<=
0
;
//
Reset
read
pointer
end
else
begin
rdptr_rg
<=
rdptr_rg
+
1
;
//
Increment
read
pointer
end
end
/*
FIFO
data
counter
update
logic
*/
if
(wren_s
&&
!rden_s)
begin
//
Write
operation
dcount_rg
<=
dcount_rg
+
1
;
end
else
if
(!wren_s
&&
rden_s)
begin
//
Read
operation
dcount_rg
<=
dcount_rg
-
1
;
end
endend/*-------------------------------------------------------------------------------------------------------------------------------
Continuous
Assignments-------------------------------------------------------------------------------------------------------------------------------*///
Full
and
Empty
internalassign
full_s
=
(dcount_rg
==
DEPTH)
?
1'b1
:
0
;assign
empty_s
=
(dcount_rg
==
0
)
?
1'b1
:
0
;//
Write
and
Read
Enables
internalassign
wren_s
=
i_wren
&
!full_s
;
assign
rden_s
=
i_rden
&
!empty_s
;//
Full
and
Empty
to
outputassign
o_full
=
full_s
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2021-2026年中國廢氣處理行業(yè)市場深度分析及投資戰(zhàn)略研究報(bào)告
- 中國咖啡壺行業(yè)市場深度評估及投資戰(zhàn)略規(guī)劃報(bào)告
- 2024-2025學(xué)年高中英語Module5CloningSectionⅤ知能演練輕松闖關(guān)含解析外研版選修6
- 2021-2026年中國教育機(jī)器人行業(yè)市場供需格局及行業(yè)前景展望報(bào)告
- 2024-2025學(xué)年高中語文第三單元第8課咬文嚼字練習(xí)含解析新人教版必修5
- 2024-2025學(xué)年高中地理課下能力提升九旅游規(guī)劃含解析新人教版選修3
- 2025年淋浴房項(xiàng)目可行性研究報(bào)告
- 年產(chǎn)3600噸橡膠骨架材料技改項(xiàng)目環(huán)境影響報(bào)告表
- 2021-2026年中國補(bǔ)中益氣丸市場全面調(diào)研及行業(yè)投資潛力預(yù)測報(bào)告
- 中國女式上衣大衣項(xiàng)目投資可行性研究報(bào)告
- 2025年人教版英語五年級下冊教學(xué)進(jìn)度安排表
- 氮?dú)庵舷⑹鹿拾咐?jīng)驗(yàn)分享
- 國家安全人人有責(zé)國家安全主題教育PPT模板
- BowTieXP風(fēng)險(xiǎn)與管理軟件介紹
- 污水管網(wǎng)計(jì)算說明書
- 原子雜化軌道理論
- 充填開采之 矸石充填術(shù)
- 文化產(chǎn)業(yè)園項(xiàng)目建議書范文
- 互聯(lián)網(wǎng)銷售卷煙(煙草)案件的分析
- 公務(wù)員考察政審表樣本
- 白菜花生長過程記錄
評論
0/150
提交評論