接这位楼主的提问,看了许多大虾们的解答,想提问一下,考虑到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
回复
打赏帖 | |
---|---|
分享博世的两种不同的喷射系统模式被打赏5分 | |
汽车+开路实验与短路实验被打赏10分 | |
多点式电子控制汽油喷射系统知识分享被打赏10分 | |
分享机械控制式汽油喷射系统被打赏5分 | |
汽车显示屏——第2部分:TFTLCD、OLED和micro-LED显示屏电源技术被打赏50分 | |
汽车+汽车电路板的走线规则被打赏20分 | |
五一劳动节快乐被打赏5分 | |
【分享开发笔记,赚取电动螺丝刀】s32k146适配zephyr(六)使用Ozone调试镜像被打赏29分 | |
【分享开发笔记,赚取电动螺丝刀】s32k146适配zephyr(五)添加设备树节点被打赏33分 | |
【分享开发笔记,赚取电动螺丝刀】s32k146适配zephyr(四)使用I2C总线驱动RA8900CE芯片被打赏23分 |