aboutsummaryrefslogtreecommitdiff
path: root/src/logic_unit.v
blob: 5ada9c99a4ba3d9584169fa0a2504745609bfca5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
module logic_unit #(
  parameter N = 32
)(
  input [N-1:0] A, B,
  input [1:0] OP, // 00: AND, 01: OR, 10: XOR
  output reg [N-1:0] RESULT
);
  
  always @ (*) begin
    case (OP)
      2'b00: RESULT <= A & B;
      2'b01: RESULT <= A | B;
      2'b10: RESULT <= A ^ B;
    endcase
  end

endmodule