EDA实验一:指令运算单元设计——第一次用FPGA开发板

  • 2020-11-15
  • 597
  • 0

题目

设计一个指令运算单元ALU,完成功能如下。

(1)操作类型1:将操作数1作为一个无符号二进制数,在七段管以十进制显示二进制序列等效值。
(2)操作类型2:实现操作数3、操作数4之间相加、减、乘的操作,在七段管以十/十六进制进制显示操作数和结果。操作数3和4为BCD码表示的2位十进制数(表示的值为00-99)。

实现代码

module lab1(sw,hex0,hex1,hex2,hex3,hex4,hex5,hex6,hex7);
    input[17:0] sw;
    output[6:0] hex0,hex1,hex2,hex3,hex4,hex5,hex6,hex7;
    reg[4:0] h7,h6,h5,h4,h3,h2,h1,h0;
    reg[15:0] o1,o2,s;
    reg[17:0] sw0;

    always@(*)
        begin
            if(sw[3:0]>9) sw0[3:0]=9;
            else sw0[3:0]=sw[3:0];
            if(sw[7:4]>9) sw0[7:4]=9;
            else sw0[7:4]=sw[7:4];
            if(sw[11:8]>9) sw0[11:8]=9;
            else sw0[11:8]=sw[11:8];
            if(sw[15:12]>9) sw0[15:12]=9;
            else sw0[15:12]=sw[15:12];

            if(sw[17:16]==0)
                begin 
                    h7=16;
                    h6=16;
                    h5=16;
                    h0=sw[15:0]%10;
                    h1=sw[15:0]/10%10;
                    h2=sw[15:0]/100%10;
                    h3=sw[15:0]/1000%10;
                    h4=sw[15:0]/10000;
                    show(h0,hex0);
                    show(h1,hex1);
                    show(h2,hex2);
                    show(h3,hex3);
                    show(h4,hex4);
                end
            else if(sw[17:16]==1)
                begin  
                    o1=sw0[15:12]*10+sw0[11:8];
                    o2=sw0[7:4]*10+sw0[3:0];
                    s=o1+o2;
                    h7=sw0[15:12];
                    h6=sw0[11:8];
                    h5=sw0[7:4];
                    h0=s%10;
                    h1=s/10%10;
                    h2=s/100;
                    h3=16;
                    h4=sw0[3:0];
                    show(h0,hex0);
                    show(h1,hex1);
                    show(h2,hex2);
                    show(h3,hex3);
                    show(h4,hex4);
                    show(h5,hex5);
                    show(h6,hex6);
                    show(h7,hex7);
                end
            else if(sw[17:16]==2)
                begin  
                    o1=sw0[15:12]*10+sw0[11:8];
                    o2=sw0[7:4]*10+sw0[3:0];
                    s=o1*o2;
                    h7=sw0[15:12];
                    h6=sw0[11:8];
                    h5=sw0[7:4];
                    h0=s%10;
                    h1=s/10%10;
                    h2=s/100%10;
                    h3=s/1000%10;
                    h4=sw0[3:0];
                    show(h0,hex0);
                    show(h1,hex1);
                    show(h2,hex2);
                    show(h3,hex3);
                    show(h4,hex4);
                    show(h5,hex5);
                    show(h6,hex6);
                    show(h7,hex7);
                end
            else if(sw[17:16]==3)
                begin  
                    o1=sw0[15:12]*10+sw0[11:8];
                    o2=sw0[7:4]*10+sw0[3:0];
                    if(o1>=o2)
                        begin
                            s=o1-o2;
                            h7=sw0[15:12];
                            h6=sw0[11:8];
                            h5=sw0[7:4];
                            h0=s%10;
                            h1=s/10%10;
                            h2=s/100%10;
                            h3=16;
                            h4=sw0[3:0];
                            show(h0,hex0);
                            show(h1,hex1);
                            show(h2,hex2);
                            show(h3,hex3);
                            show(h4,hex4);
                            show(h5,hex5);
                            show(h6,hex6);
                            show(h7,hex7); 
                        end
                    else
                        begin
                            s=o2-o1;
                            h7=sw0[15:12];
                            h6=sw0[11:8];
                            h5=sw0[7:4];
                            h0=s%10;
                            h1=s/10%10;
                            h2=s/100%10;
                            h3=10;
                            h4=sw0[3:0];
                            show(h0,hex0);
                            show(h1,hex1);
                            show(h2,hex2);
                            show(h3,hex3);
                            show(h4,hex4);
                            show(h5,hex5);
                            show(h6,hex6);
                            show(h7,hex7); 
                        end
                end
        end

    task show;
        input reg[3:0] decc;				// 输入,无符号二进制数
        output reg[6:0] out;				// 输出,7位二进制数值
        if(decc==0) 	 out=7'b1000000;	// 七段管显示0
        else if(decc==1) out=7'b1111001;	// 七段管显示1
        else if(decc==2) out=7'b0100100;	// 七段管显示2
        else if(decc==3) out=7'b0110000;	// 七段管显示3
        else if(decc==4) out=7'b0011001;	// 七段管显示4
        else if(decc==5) out=7'b0010010;	// 七段管显示5
        else if(decc==6) out=7'b0000010;	// 七段管显示6
        else if(decc==7) out=7'b1111000;	// 七段管显示7
        else if(decc==8) out=7'b0000000;	// 七段管显示8
        else if(decc==9) out=7'b0011000;	// 七段管显示9
        else if(decc==10)out=7'b0111111;	// 七段管显示-
        else 			 out=7'b1111111;	// 七段管不显示
    endtask
endmodule

实现效果

十进制显示
加法
乘法
减法
减法

结语

我爱EDA!

评论

还没有任何评论,你来说两句吧!

发表评论

     

鲁ICP备20004960号-3