色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

握手型接口的同步FIFO實現(xiàn)

冬至子 ? 來源:芯時代青年 ? 作者:尼德蘭的喵 ? 2023-12-04 14:03 ? 次閱讀

按照正常的思路,在前文完成前向時序優(yōu)化和后向時序優(yōu)化后,后面緊跟的應(yīng)該是雙向時序優(yōu)化策略了,不過不急,需要先實現(xiàn)一下握手型同步FIFO。本章所述的FIFO具備以下的特性:

1.寫入與讀出均采用握手型接口
2.支持2的整數(shù)次與非整數(shù)次深度;
3.FIFO寫入數(shù)據(jù)至少一拍后才能讀出,不能bypass;
4.輸出邏輯為寄存器輸出;

接口

握手型同步FIFO,接口如下:

module sync_fifo #(
	parameter DEPTH = 8,
	parameter WIDTH = 32
)(
    input 		clk,
    input 		rst_n,
	
    input  		in_valid,
    input  [WIDTH -1:0] in_data,
    output 		in_ready,
	
    output		out_valid,
    output [WIDTH -1:0] out_data,
    input  		out_ready
);

localparam DP_WD = $clog2(DEPTH);

endmodule

鑒于并非所有的工具和版本都能很好的支持$clog2函數(shù),所以也可以將該函數(shù)展開來寫。

根據(jù)通常的設(shè)計要求,對外輸出的in_ready和out_valid最優(yōu)為寄存器輸出,以保證時序最優(yōu)。out_data雖然理論上要作為寄存器輸出,但是out_data可以接受有mux邏輯。不過這樣在深度較淺時時序會比較好,深度太深mux邏輯帶來的時序則不能忽略。

讀寫計數(shù)器

fifo采用傳統(tǒng)的讀寫兩個計數(shù)器模式,以寫計數(shù)器為例進行說明,代碼如下:

//==================================================================
//寫入計數(shù)器
//==================================================================
reg  [DP_WD   :0]waddr;
wire             wenc;
wire             waddr_d_h;
wire [DP_WD -1:0]waddr_d_l;

assign wenc      = in_valid && in_ready;
assign waddr_d_h = (waddr[DP_WD-1:0] == DEPTH-1) ? ~waddr[DP_WD] : waddr[DP_WD];
assign waddr_d_l = (waddr[DP_WD-1:0] == DEPTH-1) ? {DP_WD{1'b0}} : waddr[DP_WD-1:0] + 1'b1;

always @(posedge clk or negedge rst_n)begin
	if(~rst_n)    waddr <= 0;
	else if(wenc) waddr <= {waddr_d_h, waddr_d_l};
end

地址指針waddr和raddr均比實際地址多一位,最高位用來指示套圈情況。當waddr和raddr的最高位相同時,fifo_cnt = waddr - raddr;當waddr和raddr的最高位相反時,fifo_cnt = DEPTH + waddr[ADDR_WIDTH-1:0] - raddr[ADDR_WIDTH-1:0]。

注意很多示意代碼會讓waddr一直累加翻轉(zhuǎn),這樣的做法對于2^N深度的FIFO是沒有問題的,而如果配置深度為非2^N深度則會出現(xiàn)跳轉(zhuǎn)錯誤,因此在本代碼中將addr區(qū)分為H和L兩個區(qū)間,低位區(qū)間累加至DEPTH-1時高位區(qū)間翻轉(zhuǎn)。

讀出計數(shù)器的代碼同樣如此:

//==================================================================
//讀出計數(shù)器
//==================================================================
reg  [DP_WD   :0]raddr;
wire             renc;
wire             raddr_d_h;
wire [DP_WD -1:0]raddr_d_l;
assign renc = out_valid && out_ready;
assign raddr_d_h = (raddr[DP_WD-1:0] == DEPTH-1) ? ~raddr[DP_WD] : raddr[DP_WD];
assign raddr_d_l = (raddr[DP_WD-1:0] == DEPTH-1) ? {DP_WD{1'b0}} : raddr[DP_WD-1:0] + 1'b1;
always @(posedge clk or negedge rst_n)begin
	if(~rst_n)    raddr <= 0;
	else if(renc) raddr <= {raddr_d_h, raddr_d_l};
end

深度計數(shù)器

通常FIFO的深度計數(shù)是通過waddr和raddr計算得到的,不過本文因為希望關(guān)鍵輸出為寄存器輸出需要用到fifo_cnt_d,因此做了一個深度計數(shù)器:

//==================================================================
//深度計數(shù)器
//==================================================================
reg  [DP_WD :0]fifo_cnt_q;

wire [DP_WD :0]waddr_d = wenc ? {waddr_d_h, waddr_d_l} : waddr;
wire [DP_WD :0]raddr_d = renc ? {raddr_d_h, raddr_d_l} : raddr;
wire [DP_WD :0]fifo_cnt_d = (waddr_d[DP_WD] == raddr_d[DP_WD]) ? (waddr_d[DP_WD-1:0] - raddr_d[DP_WD-1:0]):
															     (waddr_d[DP_WD-1:0] + DEPTH - raddr_d[DP_WD-1:0]);
wire fifo_cnt_en = (wenc ^ renc);
always @(posedge clk or negedge rst_n)begin
	if(~rst_n)    fifo_cnt_q <= 0;
	else if(fifo_cnt_en) fifo_cnt_q <= fifo_cnt_d;
end

數(shù)據(jù)寄存

數(shù)據(jù)寄存采用無復(fù)位寄存器以降低功耗,當然也可以使用sram實現(xiàn),但是如果通過sram實現(xiàn)的話就需要考慮ram輸出的多一拍延遲了,如果深度不是很深的話,建議直接通過寄存器實現(xiàn)吧。

//==================================================================
//數(shù)據(jù)寄存
//==================================================================
reg [WIDTH -1:0]data[DEPTH];
always @(posedge clk or negedge rst_n)begin
	if(wenc) data[waddr[DP_WD-1:0]] <= in_data;
end
assign out_data = data[raddr[DP_WD-1:0]];

對外邏輯

in_ready實際就是常用FIFO的full信號取反,out_valid就是empty的取反,因此單純做邏輯是不難的。但是為了實現(xiàn)寄存器輸出,最后選擇了這樣的邏輯:

//==================================================================
//對外邏輯
//==================================================================
//assign in_ready  = (fifo_cnt_q < DEPTH);
//assign out_valid = (fifo_cnt_q > {DP_WD{1'b0}});
wire in_ready_en;
wire in_ready_d;
reg  in_ready_q;
assign in_ready_en = (out_valid && out_ready) || in_ready;
assign in_ready_d  = (fifo_cnt_d < DEPTH);
always @(posedge clk or negedge rst_n)begin
	if(~rst_n)          in_ready_q <= 1;
	else if(in_ready_en)in_ready_q <= in_ready_d;
end

wire out_valid_en;
wire out_valid_d;
reg  out_valid_q;
assign out_valid_en = (in_valid && in_ready) || out_valid;
assign out_valid_d  = (fifo_cnt_d > {DP_WD{1'b0}});
always @(posedge clk or negedge rst_n)begin
	if(~rst_n)           out_valid_q <= 0;
	else if(out_valid_en)out_valid_q <= out_valid_d;
end

assign in_ready  = in_ready_q;
assign out_valid = out_valid_q;

好的所有代碼就是這些,auto_testbench的結(jié)果:

圖片

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

    關(guān)注

    31

    文章

    5363

    瀏覽量

    120955
  • RAM
    RAM
    +關(guān)注

    關(guān)注

    8

    文章

    1369

    瀏覽量

    114901
  • 計數(shù)器
    +關(guān)注

    關(guān)注

    32

    文章

    2261

    瀏覽量

    94878
  • Mux
    Mux
    +關(guān)注

    關(guān)注

    0

    文章

    38

    瀏覽量

    23440
  • FIFO電路
    +關(guān)注

    關(guān)注

    1

    文章

    4

    瀏覽量

    4924
收藏 人收藏

    評論

    相關(guān)推薦

    同步FIFO設(shè)計詳解及代碼分享

    FIFO (先入先出, First In First Out )存儲器,在 FPGA 和數(shù)字 IC 設(shè)計中非常常用。 根據(jù)接入的時鐘信號,可以分為同步 FIFO 和異步 FIFO
    發(fā)表于 06-27 10:24 ?2191次閱讀
    <b class='flag-5'>同步</b><b class='flag-5'>FIFO</b>設(shè)計詳解及代碼分享

    采用CPLD實現(xiàn)ADS8323與高速FIFO接口電路

    FIFO芯片。芯片的存儲空間是2K×9 bit,讀寫時間最小是10ns。其主要的控制管腳功能如表1所示。3.接口電路的CPLD實現(xiàn)通過上面的介紹,可以大致歸納出接口電路需要
    發(fā)表于 05-23 05:01

    基于PCI接口芯片外擴FIFO的FPGA實現(xiàn)

    介紹了PCI 9054 接口芯片的性能及數(shù)據(jù)傳輸特點,提出了一種基于PCI 9054 外擴異步FIFO(先進先出)的FPGA(現(xiàn)場可編程門陣列)實現(xiàn)方法。由于PCI 9054 內(nèi)部FIFO
    發(fā)表于 01-06 15:20 ?44次下載

    人和機器人握手同步控制

    摘要:為實現(xiàn)人和機器人握手運動的同步,提出基于神經(jīng)振動子同步控制的方法,并將此方法應(yīng)用于人和機器人握手的研究中。在現(xiàn)有神經(jīng)振動子的基礎(chǔ)上,設(shè)
    發(fā)表于 07-12 10:20 ?29次下載

    Camera Link接口的異步FIFO設(shè)計與實現(xiàn)

    介紹了異步FIFO在Camera Link接口中的應(yīng)用,將Camera Link接口中的幀有效信號FVAL和行有效信號LVAL引入到異步FIFO的設(shè)計中。分析了FPGA中設(shè)計異步
    發(fā)表于 07-28 16:08 ?32次下載

    基于VHDL和FPGA的非對稱同步FIFO設(shè)計實現(xiàn)

    本文采用VHDL描述語言,充分利用Xilinx公司Spartan II FPGA的系統(tǒng)資源,設(shè)計實現(xiàn)了一種非對稱同步FIFO,它不僅提供數(shù)據(jù)緩沖,而且能進行數(shù)據(jù)總線寬度的轉(zhuǎn)換。
    發(fā)表于 01-13 11:33 ?1979次閱讀

    自定義fifo接口控制器

    自定義fifo接口控制器,利用sopc builder實現(xiàn)
    發(fā)表于 03-22 14:09 ?1次下載

    同步FIFO之Verilog實現(xiàn)

    FIFO的分類根均FIFO工作的時鐘域,可以將FIFO分為同步FIFO和異步FIFO
    的頭像 發(fā)表于 11-01 09:57 ?2044次閱讀

    異步FIFO之Verilog代碼實現(xiàn)案例

    同步FIFO的意思是說FIFO的讀寫時鐘是同一個時鐘,不同于異步FIFO,異步FIFO的讀寫時鐘是完全異步的。
    發(fā)表于 11-01 09:58 ?1716次閱讀

    FIFO設(shè)計—同步FIFO

    FIFO是異步數(shù)據(jù)傳輸時常用的存儲器,多bit數(shù)據(jù)異步傳輸時,無論是從快時鐘域到慢時鐘域,還是從慢時鐘域到快時鐘域,都可以使用FIFO處理。
    發(fā)表于 05-26 16:12 ?1548次閱讀
    <b class='flag-5'>FIFO</b>設(shè)計—<b class='flag-5'>同步</b><b class='flag-5'>FIFO</b>

    一個簡單的RTL同步FIFO設(shè)計

    FIFO 是FPGA設(shè)計中最有用的模塊之一。FIFO 在模塊之間提供簡單的握手同步機制,是設(shè)計人員將數(shù)據(jù)從一個模塊傳輸?shù)搅硪粋€模塊的常用選擇。
    發(fā)表于 06-14 08:59 ?475次閱讀

    基于寄存器的同步FIFO

    ? FIFO 是FPGA設(shè)計中最有用的模塊之一。FIFO 在模塊之間提供簡單的握手同步機制,是設(shè)計人員將數(shù)據(jù)從一個模塊傳輸?shù)搅硪粋€模塊的常用選擇。 在這篇文章中,展示了一個簡單的 R
    的頭像 發(fā)表于 06-14 09:02 ?793次閱讀

    基于Verilog的同步FIFO的設(shè)計方法

    同步FIFO的設(shè)計主要包括讀寫地址的產(chǎn)生、數(shù)據(jù)的讀寫、以及狀態(tài)的控制。下面我們將分別介紹這三個方面的設(shè)計。
    發(fā)表于 08-31 12:53 ?910次閱讀

    同步FIFO設(shè)計分析

    模塊雖小但是要有新意,首先寫一個同步FIFO,這是一個爛大街的入門級項目,但是我肯定不會寫的那么簡單
    的頭像 發(fā)表于 09-11 17:11 ?668次閱讀
    <b class='flag-5'>同步</b><b class='flag-5'>FIFO</b>設(shè)計分析

    同步FIFO和異步FIFO的區(qū)別 同步FIFO和異步FIFO各在什么情況下應(yīng)用

    簡單的一種,其特點是輸入和輸出都與時鐘信號同步,當時鐘到來時,數(shù)據(jù)總是處于穩(wěn)定狀態(tài),因此容易實現(xiàn)數(shù)據(jù)的傳輸和存儲。 而異步FIFO則是在波形的上升沿和下降沿上進行處理,在輸入輸出端口處分別增加輸入和輸出指針,用于管理數(shù)據(jù)的讀寫。
    的頭像 發(fā)表于 10-18 15:23 ?1750次閱讀
    主站蜘蛛池模板: AV亚洲精品少妇毛片无码 | 穿白丝袜边走边尿白丝袜 | 又黄又爽又无遮挡在线观看免费 | 免费99精品国产人妻自在线 | 亚洲色图在线视频 | 国产成人精品在视频 | 日日噜噜夜夜狠狠扒开双腿 | 亚洲精品中文字幕一二三四区 | 动漫美女无衣 | 亚洲精品国产自在在线观看 | 国精产品一区一区三区有限 | 久久成人免费观看草草影院 | 小小水蜜桃视频高清在线播放 | 久久精品国产清白在天天线 | 熟妇内谢69XXXXXA片 | 精品蜜臀AV在线天堂 | 高跟丝袜岳第一次 | 日日操夜夜摸 | 大香网伊人久久综合观看 | 久久毛片网站 | 天天操天天干天天爽 | 国产 日韩 欧美 综合 激情 | 啦啦啦影院视频在线看高清... | OLDMAN老头456 TUBE | 中文无码有码亚洲 欧美 | 人妻夜夜爽天天爽三区麻豆AV网站 | 欧美黄色精品 | 少妇无码太爽了视频在线播放 | 99久久国产综合色 | 国产精品久久人妻无码网站一区L | 亚洲三级黄色片 | 亚洲中字幕永久在线观看 | 99欧美精品 | 久久精麻豆亚洲AV国产品 | 亚洲欧洲日本天天堂在线观看 | 果冻传媒视频在线观看完整版免费 | 青青青青久久久久国产的 | 嫩草影院地址一二三 | adc高清在线观看 | 狠狠色丁香久久婷婷综合_中 | 中文在线观看免费网站 |