圈内人 2019-07-08 21:57
浏览 232

ispLEVER,输入值没能赋给中间变量

课设任务,中间有一部分是用三个开关n0n1n2给中间值temp赋值为00,01,10

/*
clk:时钟信号
n0,n1,n2:密码输入信号
lock:状态显示信号
reset:复位信号
set:密码确认信号
*/
module code(lock,warning,num1,num2,num3,num4,clkin,n0,n1,n2,set,reset,close,temp);
input n0,n1,n2,set,reset,clkin,close;
output reg [1:0]temp;
output reg [1:0]num1,num2,num3,num4;
output reg lock,warning;
reg [1:0]i;
always@(posedge n0||n1||n2)
begin
case({n2,n1,n0})
3'b001:temp<=2'b00;
3'b010:temp<=2'b01;
3'b100:temp<=2'b10;
endcase
end
begin
case(i)
2'b00:begin 
num1<=temp;
i<=1;
end
2'b01:begin 
num2<=temp;
i<=2;
end
2'b10:begin 
num3<=temp;
i<=3;
end
2'b11:begin 
num4<=temp;
i<=0;
end
default: i<=2'b00;
endcase
end
always@(*)
    begin
        if(!lock&&set)
        begin
            if({(num4==2'b01)&&(num3==2'b00)&&(num2==2'b01)&&(num1==2'b01)})
            lock<=1;
            else 
            begin
                lock<=0;
                warning<=1;
            end
        end     
        if(lock&&close)
            lock<=0;
        if(reset)
            warning<=0;
            num1<=0;
            num2<=0;
            num3<=0;
            num4<=0;
            i<=2'b00;
    end
endmodule

synplify时,automake log里出现这样的提示:

@W: CG1160 :"C:\users\a2763\documents\tencent files\2763739926\filerecv\light\code.v":14:16:14:26|Found complex event expression
@W: CL118 :"C:\users\a2763\documents\tencent files\2763739926\filerecv\light\code.v":58:3:58:4|Latch generated from always block for signal warning; possible missing assignment in an if or case statement.
@W: CL207 :"C:\users\a2763\documents\tencent files\2763739926\filerecv\light\code.v":56:3:56:4|All reachable assignments to lock assign 0, register removed by optimization.
@W: CL159 :"C:\users\a2763\documents\tencent files\2763739926\filerecv\light\code.v":9:25:9:29|Input clkin is unused
@W: CL159 :"C:\users\a2763\documents\tencent files\2763739926\filerecv\light\code.v":9:31:9:35|Input close is unused
@W: MT462 :|Net set_c appears to be an unidentified clock source. Assuming default frequency. 

跑波形,发现temp总是为0
图片说明
如果在case({n2,n1,n0})之前加个temp<=2'b11;波形就会变成这样
图片说明
这个bug卡了好几天了,课设死线将至,万策尽yi

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥20 Html备忘录页面制作
    • ¥15 黄永刚的晶体塑性子程序中输入的材料参数里的晶体取向参数是什么形式的?
    • ¥20 数学建模来解决我这个问题
    • ¥15 计算机网络ip分片偏移量计算头部是-20还是-40呀
    • ¥15 stc15f2k60s2单片机关于流水灯,时钟,定时器,矩阵键盘等方面的综合问题
    • ¥15 YOLOv8已有一个初步的检测模型,想利用这个模型对新的图片进行自动标注,生成labellmg可以识别的数据,再手动修改。如何操作?
    • ¥30 NIRfast软件使用指导
    • ¥20 matlab仿真问题,求功率谱密度
    • ¥15 求micropython modbus-RTU 从机的代码或库?
    • ¥15 django5安装失败