有个计数器
reg [5:0]count=0;
现在需要用a信号对它清零,b信号对对它进行累加。
always @(posedge a)
count<=0;
always @(posedge b)
count=count+1;
出错了,两个或两个以上always块里面对同一个变量进行赋值,应该怎么解决呢?
两个always模块对一个变量进行赋值
貌似可以了,不过现在出现了个新问题
reg st=0; //开始信号寄存器
always @(posedge p or posedge z)
begin
if (z==1) //第一个Z脉冲z脉冲出现才计数
begin
count<=0;
st<=1;
end
else
begin
if (st==1) //判断是否已经出现Z脉冲
begin
count<=count+1;
if (count==10|count==30) //如果每周计数到10和30个脉冲就发出一个脉冲信号
CLK<=1;
else CLK<=0;
end
else CLK<=0;
end
end
问题是,仿真的时候,并没有等到第一个Z脉冲出现就已经开始计数了。这是为什么呢?
7楼
你的意思是:b作为计数器时钟,上升沿有效;a作为清零是能,高电平有效。
一个变量只能在一个进程中被赋值。
推荐的写法为:
always @ ( posedge b)
begin
if (a)
count <= 0;
else
count <= count + 1;
end
这是同步清零方式,能消除竞争冒险,且符合同步设计思想,便于仿真器穿透。但a高电平必须持续一个b周期以上。
另一种写法为:
always @ ( posedge b or posedge a )
begin
if (a)
count <= 0;
else
count <= count + 1;
end
这是异步清零方式,不推荐。
一个变量只能在一个进程中被赋值。
推荐的写法为:
always @ ( posedge b)
begin
if (a)
count <= 0;
else
count <= count + 1;
end
这是同步清零方式,能消除竞争冒险,且符合同步设计思想,便于仿真器穿透。但a高电平必须持续一个b周期以上。
另一种写法为:
always @ ( posedge b or posedge a )
begin
if (a)
count <= 0;
else
count <= count + 1;
end
这是异步清零方式,不推荐。
8楼
你用的是哪个仿真软件?这种写法从仿真语义上看应该是可以的,除了
if (count==10|count==30) 中的 “|” 应改成 “||”
但这种写法不好。
1, “reg st=0; ”,这个初值仅在仿真时有效,综合是无效,因此综合后st的初值是随机的,应该有一个全局的复位信号对需要的全部寄存器赋初值,先复位再使用。
2, 你的CLK会综合一个不希望的锁存器,因为你在if (z==1) 中未对其赋值。
回复
| 有奖活动 | |
|---|---|
| 2026年“我要开发板活动”第三季,开始了! | |
| 硬核工程师专属补给计划——填盲盒 | |
| “我踩过的那些坑”主题活动——第002期 | |
| 【EEPW电子工程师创研计划】技术变现通道已开启~ | |
| 发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
| 【EEPW在线】E起听工程师的声音! | |
| 高校联络员开始招募啦!有惊喜!! | |
| 【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
我要赚赏金打赏帖 |
|
|---|---|
| 【分享开发笔记,赚取电动螺丝刀】在音频测试中顺序的调整可改变功效被打赏¥18元 | |
| 【分享开发笔记,赚取电动螺丝刀】点阵显示模块及其应用-----献给新年的小礼物被打赏¥22元 | |
| 基于地奇星开发板的数码管模块显示技术被打赏¥23元 | |
| window下生成compilecommands.json的的方法被打赏¥22元 | |
| 【S32K3XX】GPIO中断配置被打赏¥26元 | |
| 【分享开发笔记,赚取电动螺丝刀】WS2812B的RGB灯介绍以及驱动方法被打赏¥25元 | |
| PTC与NTC功能常规对比被打赏¥14元 | |
| 【S32K3XX】核间通信MU使用被打赏¥27元 | |
| 【分享开发笔记,赚取电动螺丝刀】关于3pin锂电池接口的介绍/使用被打赏¥16元 | |
| 以启明云端ESP32P4开发板实现TF卡读写功能被打赏¥28元 | |
我要赚赏金
