-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathc_adder.v
50 lines (38 loc) · 820 Bytes
/
c_adder.v
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
module c_adder1(sign_a,sign_b, new_a, new_b, sum, new_sign,greater_flag);
input [23:0]new_a,new_b;
input sign_a,sign_b,greater_flag;
reg [24:0]temp1,temp4,new_a_copy,new_b_copy,temp_r2;
reg [23:0]temp3,temp_r;
reg [25:0]temp2;
output reg new_sign;
output reg [24:0]sum;
always@(*)
begin
if(sign_a == 1'b1 && sign_b == 1'b1)
begin
sum = new_a + new_b;
new_sign = 1'b1;
end
else if(sign_a == 1'b0 && sign_b == 1'b0)
begin
sum = new_a + new_b;
new_sign = 1'b0;
end
else if(((sign_a == 1'b1 && sign_b == 1'b0)||(sign_a == 1'b0 && sign_b == 1'b1)) && (new_a > new_b))
begin
sum = new_a - new_b;
if(greater_flag == 1'b1)
new_sign = sign_a;
else
new_sign = sign_b;
end
else
begin
sum = new_b - new_a;
if(greater_flag == 1'b1)
new_sign = sign_a;
else
new_sign = sign_b;
end
end
endmodule