-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathALU.v
More file actions
56 lines (50 loc) · 1.54 KB
/
ALU.v
File metadata and controls
56 lines (50 loc) · 1.54 KB
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
49
50
51
52
53
54
55
`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////////
// Company:
// Engineer:
//
// Create Date: 20.07.2024 16:38:19
// Design Name:
// Module Name: ALU
// Project Name:
// Target Devices:
// Tool Versions:
// Description:
//
// Dependencies:
//
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
//
//////////////////////////////////////////////////////////////////////////////////
module ALU(
input [31:0] A, B,
input isAdd, isSub, isComp, isMul, isDiv, isMod, isLSL, isLSR, isASR, isOR, isAND, isNOT, isMov,
output reg flags_eq, flags_gt,
output [31:0] aluResult
);
reg [31:0] aluRes;
always @(*) begin
aluRes = 0;
flags_eq = 0;
flags_gt = 0;
if (isAdd) aluRes = A + B; // Addition
if (isSub) aluRes = A - B; // Subtraction
if (isComp) begin // Comparison
flags_eq = (A == B);
flags_gt = (A >> B);
end
if (isMul) aluRes = A * B; // Multiplication
if (isDiv) aluRes = A / B; // Division
if (isMod) aluRes = A % B; // Modulo
if (isLSL) aluRes = A << B; // Logical Shift Left
if (isLSR) aluRes = A >> B; // Logical Shift Right
if (isASR) aluRes = $signed(A) >>> B; // Arithmetic Shift Right
if (isOR) aluRes = A | B; // OR Operation
if (isAND) aluRes = A & B; // AND Operation
if (isNOT) aluRes = ~A; // NOT Operation
if (isMov) aluRes = B; // MOV Operation
end
assign aluResult = aluRes;
endmodule