verilog always语句中怎么实现 延时一定时间100ns左右 急?

时钟假设50MHZ我想实现的是if(!reveive)send=0(send延时100ns);//就是想在这部分里实现100ns延时,使send延迟100ns的低电平之后... 时钟假设50MHZ 我想实现的是 if(!reveive)
send=0(send延时100ns); //就是想在这部分里实现100ns延时,使send延迟100ns的低电平之后再变高。这里该怎么写呢??
else send=1;
展开
 我来答
yl0409202
推荐于2018-12-31 · TA获得超过567个赞
知道小有建树答主
回答量:483
采纳率:0%
帮助的人:292万
展开全部
50MHZ时钟20ns周期。延时100ns就是五个周期。
reg[2:0] cnt;
always@(posedge clk or nengedge reset)
if(!reset)
cnt <= 0;

else if(cnt == 5 \\(或)!reverve)这里两个竖线打出来是斜的
cnt <= 0;
else
cnt <= cnt + 1'b1;

always@(posedge clk or nengedge reset)
if(!reveive)
send <= 0;
else if(cnt == 5)
send <= 1;
else
send <= send;
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式