接这位楼主的提问,看了许多大虾们的解答,想提问一下,考虑到a的高电平会持续一段时间。如果要求非要在a的上升沿将count清零,如何实现呢?谢谢各位的支持!!!
两个always模块的变量赋值问题
引入一个锁存器Lock,用来区分a的上升沿和高电平。
always @(posedge a or posedge b)
begin
if ( a==1 && Lock==0 )
begin
count <= 0;
Lock <= 1;
end
else
begin
count <= count + 1;
if ( a==0 )
Lock <= 0;
end
end
一般对于寄存器,复位是需要的,所以我这里省略了。
或者可以拆成两个写。这里采用同步复位
always @(posedge a or posedge b)
begin
if(rst==0)
begin
count <= 0;
end
else
begin
if ( a==1 && Lock==0 )
begin
count <= 0;
end
else
begin
count <= count + 1;
end
end
end
always @(posedge a or posedge b)
begin
if(rst==0)
begin
count <= 0;
end
else
begin
if ( a==1 && Lock==0 )
begin
Lock <= 1;
end
else
begin
if ( a==0 )
Lock <= 0;
end
end
end
好的。下面是我的程序,红色部分是增加的东西,增加了后就通过不了综合了。综合的问题是在第二个always上面涂红,问题是the logic for gpshighclkcnt [15:0] does not match a standard flip-flop.
module fuzhugen(gps,
gpshighclk,
rst,
fuzhu,
fuzhu1);
input gps;
input gpshighclk;
input rst;
output fuzhu; //增加一个fuzhu输出端口信号
output fuzhu1; //增加一个fuzhu1输出端口信号
reg fuzhu;
reg fuzhu1;
reg lockgpshigh;
reg [15:0] gpshighclkcnt;
always @ (posedge gps or posedge gpshighclk)
begin
if(rst)
begin
gpshighclkcnt<=16'd0;
fuzhu1<=(1==0);
fuzhu<=(0==1);
end
else
begin
if(gps && !lockgpshigh)
begin
gpshighclkcnt<=16'd0;
fuzhu<=(0==1);
fuzhu1<=(0==1);
end //gps信号上升沿时候,计数器清零,fuzhu和fuzhu1输出port清零
if(gps && gpshighclkcnt==16'd239)
begin
fuzhu <=(1==1);
end //当gps信号为高时并且计数器计数到239的时候fuzhu信号输出高电平
if(gps && gpshighclkcnt==16'd240)
begin
fuzhu1<=(1==1);
end //当gps信号为高时并且计数器计数到240的时候fuzhu1信号输出高电平
else
begin
gpshighclkcnt<=gpshighclkcnt+16'd1;
end
end
end
always @ (posedge gps or posedge gpshighclk)
begin
if(rst)
begin
gpshighclkcnt<=16'd0;
end
else
begin
if(gps && !lockgpshigh)
begin
lockgpshigh<=(1==1);
end
else
begin
if(!gps)
begin
lockgpshigh<=(1==0);
end
end
end
end
endmodule
回复
有奖活动 | |
---|---|
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
【有奖活动】智能可穿戴设备AR/VR如何引领科技新潮流! | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
【有奖活动】震撼来袭!这场直播将直击工程师的心灵! |
打赏帖 | |
---|---|
【换取手持数字示波器】滞回比较电路分析被打赏30分 | |
【换取手持数字示波器】电流镜电路分析被打赏20分 | |
【换取手持数字示波器】基于状态变量推导实现有源滤波器被打赏20分 | |
玩转“DFRobot盖革计数器模块”准备工作认识模块知识分享被打赏30分 | |
【换取手持数字示波器】AHT10温度检测分享被打赏40分 | |
【换取手持数字示波器】ACM32F070开发板点亮LCD屏和触控按键,串口,ADC被打赏40分 | |
【换取手持数字示波器】ACM32F070LCD屏和触控按键功驱动蜂鸣器分享被打赏40分 | |
【换取手持数字示波器】国民技术PWM功能知识分享被打赏40分 | |
【换取手持数字示波器】放大器运放知识分享被打赏40分 | |
【分享评测,赢取加热台】+开关电源AC输入知识分享被打赏30分 |