RVSCC/rtl/alu.sv

51 lines
1.2 KiB
Systemverilog
Raw Normal View History

`include "timescale.sv"
2023-02-26 23:26:11 +00:00
import rv32i_defs::*;
module alu (
input logic [OperandSize-1:0] a,
input logic [OperandSize-1:0] b,
input alu_opcode_t operation,
output logic [OperandSize-1:0] result,
output logic [3:0] status
);
logic n, z, c, v;
always_comb begin
case (operation)
SUM: begin
{c, result} = a + b;
v = (result[OperandSize-1] & !a[OperandSize-1] & !b[OperandSize-1]) |
(!result[OperandSize-1] & a[OperandSize-1] & b[OperandSize-1]);
end
SUB: begin
{c, result} = a - b;
v = (result[OperandSize-1] & !a[OperandSize-1] & !b[OperandSize-1]) |
(!result[OperandSize-1] & a[OperandSize-1] & !b[OperandSize-1]);
end
OR: begin
result = a | b;
c = 'b0;
v = 'b0;
end
AND: begin
result = a & b;
c = 'b0;
v = 'b0;
end
SLT: begin
result = {31'd0, a < b};
c = 'b0;
v = 'b0;
end
default: begin
result = 'dx;
c = 1'bx;
v = 1'bx;
end
endcase
n = result[OperandSize-1];
z = (result == '0);
status = {n, z, c, v};
end
endmodule