来源:http://www.cnblogs.com/oomusou/archive/2009/06/15/verilog_dly_n_clk.html

 /*
(C) OOMusou 2009 http://oomusou.cnblogs.com Filename : delay_3t.v
Compiler : NC-Verilog 5.4
Description : delay 3t method 1
Release : 06/15/2009 1.0
*/ module delay_3t (
clk,
rst_n,
d,
q
); input clk;
input rst_n;
input d;
output q; reg d_dly_1t;
reg d_dly_2t;
reg d_dly_3t; assign q = d_dly_3t; always@(posedge clk or negedge rst_n) begin
if (!rst_n) begin
d_dly_1t <= ;
d_dly_2t <= ;
d_dly_3t <= ;
end
else begin
d_dly_1t <= d;
d_dly_2t <= d_dly_1t;
d_dly_3t <= d_dly_2t;
end
end endmodule
 /*
(C) OOMusou 2009 http://oomusou.cnblogs.com Filename : delay_3t.v
Compiler : NC-Verilog 5.4
Description : delay 3t method 2
Release : 06/15/2009 1.0
*/ module delay_3t (
clk,
rst_n,
d,
q
); input clk;
input rst_n;
input d;
output q; reg d_dly_1t;
reg d_dly_2t;
reg d_dly_3t; assign q = d_dly_3t; always@(posedge clk or negedge rst_n) begin
if (!rst_n)
{d_dly_3t, d_dly_2t, d_dly_1t} <= ;
else
{d_dly_3t, d_dly_2t, d_dly_1t} <= {d_dly_2t, d_dly_1t, d};
end endmodule
 /*
(C) OOMusou 2009 http://oomusou.cnblogs.com Filename : delay_nt.v
Compiler : NC-Verilog 5.4
Description : delay 3t method 3
Release : 06/15/2009 1.0
*/ module delay_nt (
clk,
rst_n,
d,
q
); parameter n = ; input clk;
input rst_n;
input d;
output q; reg [n-:] r; assign q = r[n-]; integer i; always@(posedge clk or negedge rst_n) begin
if (!rst_n)
r <= ;
else begin
for(i=; i<n-; i=i+)
r[i+] <= r[i]; r[] <= d;
end
end endmodule
 /*
(C) OOMusou 2009 http://oomusou.cnblogs.com Filename : delay_nt.v
Compiler : NC-Verilog 5.4
Description : delay 3t method 4
Release : 06/15/2009 1.0
*/ module delay_nt (
clk,
rst_n,
d,
q
); parameter n = ; input clk;
input rst_n;
input d;
output q; reg [n-:] r; assign q = r[n-]; always@(posedge clk or negedge rst_n) begin
if (!rst_n)
r <= ;
else
r <= {r, d};
end endmodule

{}写法是Verilog的独门绝技,这样就不再需要for,这也是为什么Verilog宁愿从C语言抢走{}换来begin, end,因为{}这种合并的写法非常的好用。Testbench与模拟波型图也与Method 1与Method 2一样,再次省略。这种写法使用了parameter,无论要delay几个clk,只需修改n即可,而且与Quartus II优化后的硬件一样,我们再次将编译过的RTL Viewer打开做验证。

Conclusion
这4种写法最后合出来的硬件都一样,表示现在的合成器都够聪明,差别只是在哪种coding style较好,将来比较好维护。另外也是开开眼界,若将来阅读其他人的code,马上就知道对方想表达的意思。

(转帖) 如何將值delay n個clock? (SOC) (Verilog)的更多相关文章

  1. (转帖) 有限狀態機FSM coding style整理 (SOC) (Verilog)

    来源:http://www.codesoso.net/Record/101092_95120_21.html 来源:http://www.cnblogs.com/oomusou/archive/201 ...

  2. 如何使用SignalTap II觀察reg與wire值? (SOC) (Verilog) (Quartus II) (SignalTap II)

    Abstract撰寫Verilog時,雖然每個module都會先用ModelSim或Quartus II自帶的simulator仿真過,但真的將每個module合併時,一些不可預期的『run-time ...

  3. 在 Swift 專案中使用 Javascript:編寫一個將 Markdown 轉為 HTML 的編輯器

    原文:Using JavaScript in Swift Projects: Building a Markdown to HTML Editor 作者:GABRIEL THEODOROPOULOS ...

  4. JavaFX結合 JDBC, Servlet, Swing, Google Map及動態產生比例圖 (3):部署設定及應用 (转帖)

    說明:這一篇主要是說明如何將程式部署到Application Server,以及程式如何運作,產生的檔案置於何處,以及如何以瀏覽器呈現(Applet),或是當成桌面應用程式,或是 桌面Applet,這 ...

  5. [转]用Linq取CheckBoxList選取項目的值

    本文转自:http://www.dotblogs.com.tw/hatelove/archive/2011/11/17/linq-checkboxlist-items-selected-values. ...

  6. button属性值

    AccessibilityObject 取得指定給控制項的 AccessibleObject. (繼承自 Control). AccessibleDefaultActionDescription 取得 ...

  7. [Xamarin] 透過StartActivityForResult傳值回來(转贴)

    上一篇文章(開啟另外一個Activity 並且帶資料),提到了開啟一個新的Activity ,我們將值透過intent 帶到下個Activity 但是,如果我們開啟的Actrivity其實是有一個任務 ...

  8. [Xamarin.Android]使用Java Bindings Libary專案 Binding Java元件(.jar) 與Metadata.xml、型別對應 (转帖)

    使用Xamarin開發Android APP時, 如果已經有原本就用Java寫好的套件(.jar), 就可以利用Xamarin提供的Java Bindings Libary將他變成C#可使用的元件. ...

  9. [Xamarin.Android] 結合Windows Azure與Google cloud message 來實現Push Notification (转帖)

    這一篇要討論如何使用Xamarin.Android 整合GCM以及Windows Azure來實作Android手機上的推播通知服務. 這篇文章比較著重概念的部分,在開始讀這篇之前,也可以先參考一下X ...

随机推荐

  1. Inna and Binary Logic

    Codeforces Round #234 (Div. 2) E:http://codeforces.com/problemset/problem/400/E 题意:给你n个数,然后每相邻的两个数可以 ...

  2. Ext.js form 表单提交问题

    var form = new Ext.form.FormPanel({ labelAlign : 'right', border : false, bodyStyle : 'background-co ...

  3. nginx 配置多个主机

    <pre name="code" class="html"> server { listen 8001; server_name localhost ...

  4. 【HDOJ】2451 Simple Addition Expression

    递推,但是要注意细节.题目的意思,就是求s(x) = i+(i+1)+(i+2),i<n.该表达中计算过程中CA恒为0(包括中间值)的情况.根据所求可推得.1-10: 31-100: 3*41- ...

  5. bzoj3531

    不难想到树链剖分这题的难点是记录的是路径上宗教相同的点裸的想法是对每一种宗教都开一棵线段树,记录每个点的评级但显然这样会爆空间,仔细分析一下,这些线段树内很多点压根就没用到因此我们考虑对线段树动态开点 ...

  6. 【数学规律】Vijos P1582 笨笨的L阵游戏

    题目链接: https://vijos.org/p/1582 题目大意: 就是o(o<=50)个人在n*m(n,m<=2000)的格子上放L型的东西(有点像俄罗斯方块的L,可对称旋转),问 ...

  7. FZYZOJ-1578 [NOIP福建夏令营]数列分段

    P1578 -- [NOIP福建夏令营]数列分段 时间限制:1000MS      内存限制:131072KB 状态:Accepted      标签:    二分   无   无 Descripti ...

  8. D - How Many Answers Are Wrong(hdu 3038)

    总算碰到一道不那么无聊的题了^^ 先说一下题意吧,有两个人一个叫TT的男孩一个叫FF的女孩(名字太随意了吧....),这个叫TT的男孩会经常叫这个女孩一起玩一个游戏,这个有些是这样的,随便写一个数列, ...

  9. codeforces 610B

    Description Vika has n jars with paints of distinct colors. All the jars are numbered from 1 to n an ...

  10. selenium webdriver启动IE浏览器失败的解决办法

    通过selenium webdriver启动IE浏览器失败,报错:selenium.common.exceptions.WebDriverException: Message: Unexpected ...