Cvičení 3

1.

module maindec(Opcode, RegWrite, RegDst, ALUSrc, ALUOp, Branch, MemWrite, MemToReg);
    input [5:0] Opcode;
    output RegWrite;
    output RegDst;
    output ALUSrc;
    output [1:0] ALUOp;
    output Branch;
    output MemWrite;
    output MemToReg;
	 reg[7:0] out=0;
	 always @(*)
	 case(Opcode)
		6'b000000: out= 8'b11010000;
		6'b100011: out= 8'b10100001;
		6'b101011: out= 8'b00100010;
		6'b000100: out= 8'b00001100;
		6'b001000: out= 8'b10100000;
	 endcase
	 assign {RegWrite, RegDst, ALUSrc, ALUOp, Branch, MemWrite, MemToReg} = out;
endmodule
module aludec(ALUOp, Funct, ALUControl);
    input [1:0] ALUOp;
    input [5:0] Funct;
    output reg [2:0] ALUControl;
	 always @(*)
	 case(ALUOp)
		2'b00: ALUControl = 3'b010;
		2'b01: ALUControl = 3'b110;
		default:
			case(Funct)
				6'b100000: ALUControl = 3'b010;
				6'b100010: ALUControl = 3'b110;
				6'b100100: ALUControl = 3'b000;
				6'b100101: ALUControl = 3'b001;
				6'b101010: ALUControl = 3'b111;
			endcase
	 endcase
endmodule
module controlunit(Opcode, Funct, Zero, RegWrite, RegDst, ALUSrc, PCSrc, MemWrite, MemToReg, ALUControl);
    input [5:0] Opcode;
    input [5:0] Funct;
    input Zero;
    output RegWrite;
    output RegDst;
    output ALUSrc;
    output PCSrc;
    output MemWrite;
    output MemToReg;
    output [2:0] ALUControl;	 
	 wire [1:0] ALUOp;
	 wire Branch;	 
	 maindec mdec(Opcode, RegWrite, RegDst, ALUSrc, ALUOp, Branch, MemWrite, MemToReg);
	 aludec adec(ALUOp, Funct, ALUControl);	 
	 assign PCSrc = Zero & Branch;
endmodule

2.

addi $s0, $0, 0x0010
lw $s1, 0($s0)           //load a
lw $s2, 4($s0)           //load b
lw $s3, 8($s0)           //load c

slt $t0, $s2, $s1        //if(b<a)t0=1 else t0=0
beq $t0, $0, if          //if(t0=0) if vetev
  sub $s1, $s1, $s2      //a=a-b
  beq $0, $0, L2       //jump
if:
  addi $t1, $0, 0          //i=0
  while:
    beq $t1, $s3, done     //if(i=c) konec cyklu
    add $s1, $s1, $t1      //a+=i
    addi $t1, $t1, 1       //i++
    beq $0, $0, while    //jump
  done:
L2:
  
sw $s1, 0($s0)           //store a
courses/a4m36pap/cviceni3.txt · Poslední úprava: 2025/01/03 18:29 (upraveno mimo DokuWiki)
Nahoru
chimeric.de = chi`s home Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0