forked from jv-n/Projeto-RISC-V
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathalu.sv
48 lines (45 loc) · 1.68 KB
/
alu.sv
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
`timescale 1ns / 1ps
module alu#(
parameter DATA_WIDTH = 32,
parameter OPCODE_LENGTH = 4
)
(
input logic [DATA_WIDTH-1:0] SrcA,
input logic [DATA_WIDTH-1:0] SrcB,
input logic [OPCODE_LENGTH-1:0] Operation,
output logic[DATA_WIDTH-1:0] ALUResult
);
always_comb
begin
case(Operation)
4'b0000: // AND
ALUResult = SrcA & SrcB;
4'b0001: // OR
ALUResult = SrcA | SrcB;
4'b0010: // ADD e ADDI
ALUResult = SrcA + SrcB;
4'b0011: // SUB
ALUResult = SrcA - SrcB;
4'b0100: // XOR
ALUResult = SrcA ^ SrcB;
4'b1000: // Equal (beq)
ALUResult = (SrcA == SrcB) ? 1 : 0;
4'b1001: // Not Equal (bne)
ALUResult = (SrcA != SrcB) ? 1 : 0;
4'b1010: // Less than (blt)
ALUResult = (SrcA < SrcB) ? 1 : 0;
4'b1011: // Greater than or equal
ALUResult = (SrcA >= SrcB) ? 1 : 0;
4'b1100: // Shift left (SLLI)
ALUResult = SrcA << SrcB;
4'b1101: // Shift right (SRLI)
ALUResult = SrcA >> SrcB;
4'b1110: //Slt e Slti
ALUResult = (SrcA < SrcB) ? 1 : 0;
4'b1111: //SRAI
ALUResult = SrcA >>> SrcB[4:0];
default:
ALUResult = 0;
endcase
end
endmodule