waj13 2015-08-23 07:48
浏览 2493

verilog if语句循环次数问题

下面是我设计的模块的一部分,仿真的时候发现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

  • 写回答

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,出参布尔值