下面是我设计的模块的一部分,仿真的时候发现if语句循环出现问题,比如data从0跳变为1,times的值会一直加到3,src也变成了0000000100010001。求教这里敏感性列表里data只变化了一次为什么if语句的循环条件会判断这么多次?
always @ (data or RESET or finish)
begin
if(RESET==0) //检测到reset信号
begin
SRCH=0;SRCL=0;DSTH=0;DSTL=0;ALU_OP=0;finish=0;times=0;src=0;dst=0;num=0;
end
if(data==15 && num==1)
begin
finish=1; times=0; num=0;
end
if(finish==1)
begin
finish=0;src=0;dst=0;ALU_OP=0;
end
//输入数字时向src和dst存入
if(data<10 && times<3)
begin
if(num==0)
begin
src[11:8]=src[7:4];
src[7:4]=src[3:0];
src[3:0]=data[3:0];
end
else
begin
dst[11:8]=dst[7:4];
dst[7:4]=dst[3:0];
dst[3:0]=data[3:0];
end
times=times+1;
end
//输入符号
if(data==10 && num==0)
begin
ALU_OP=1; times=0; num=1;
end
if(data==11 && num==0)
begin
ALU_OP=2; times=0; num=1;
end
if(data==12 && num==0)
begin
ALU_OP=3; times=0; num=1;
end
if(data==13 && num==0)
begin
ALU_OP=4; times=0; num=1;
end
if(data==14 && num==0)
begin
ALU_OP=5; times=0; num=1;
end
SRCH=src[15:8]; SRCL=src[7:0];
DSTH=dst[15:8]; DSTL=dst[7:0];
end
verilog if语句循环次数问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
0条回答
悬赏问题
- ¥15 R语言Rstudio突然无法启动
- ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
- ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
- ¥15 用windows做服务的同志有吗
- ¥60 求一个简单的网页(标签-安全|关键词-上传)
- ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
- ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
- ¥100 为什么这个恒流源电路不能恒流?
- ¥15 有偿求跨组件数据流路径图
- ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值