Vous êtes sur la page 1sur 1

module ALU (a, b, s, y);

input [3:0] a, b, s;
output [7:0] y;
reg [7:0] s;
always @*
begin
case(s)
4'b0000 : y<=a+b;
4'b0001 : y<=a-b;
4'b0010 : y<=a*b;
4'b0011 : y<=a/b;
4'b0100 : y<=a%b;
4'b0101 : y<=a&b;
4'b0110 : y<=a|b;

4'b0111 : y<=a==b;
4'b1000 : y<=a&&b;
4'b1001 : y<=a||b;
4'b1010 : y<=a>>2;
4'b1011 : y<=a<<2;
4'b1100 : y<=a^b;
4'b1101 : y<=-a;
4'b1110 : y<=(a,b);
4'b1111 : y<=(2{a});
endcase
end
endmodule