FPGA 如何产生一个时钟周期的延时?比如输入i,输出o,o要在i基础上延时一个时钟周期,忽略芯片自身延时。

偶用的是VHDL……能用VHDL说下吗... 偶用的是VHDL……能用VHDL说下吗 展开
 我来答
弄月了无痕
2011-12-16 · 超过16用户采纳过TA的回答
知道答主
回答量:126
采纳率:0%
帮助的人:63.2万
展开全部
有赋值符号 <= 就可以了,这个符号是延迟一个时钟的。而 = 是不延迟的。
module(clk,i,0);
input clk,i;
output 0;
always @(posedge clk)
begin
0<=i;
end
endmodule
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
九山会龙
2011-12-17 · 超过10用户采纳过TA的回答
知道答主
回答量:36
采纳率:0%
帮助的人:27.1万
展开全部
module delay(clk,i,o);
localparam T = 10; // T 是你的一个时钟周期
input clk,in;
output out;
always @(posedge clk)
begin
#T; //在这里延时
out<=in;
end
endmodule
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
修颜夏5273
2011-12-16 · TA获得超过6.2万个赞
知道大有可为答主
回答量:3.1万
采纳率:0%
帮助的人:4106万
展开全部
用assign语句 在out输出 赋值时前面直接加个延时单位时间就行
如: assign
#1 out=你的表达式
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
iweimo
2011-12-17 · TA获得超过128个赞
知道答主
回答量:96
采纳率:0%
帮助的人:51.8万
展开全部
不知道你只是要仿真还是要下载到cpld/fpga中
如果只是仿真,# t 就可以了,延时t个单位时间
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式