-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathshortMult.vhd
107 lines (102 loc) · 2.76 KB
/
shortMult.vhd
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
library ieee;
use ieee.std_logic_1164.all;
entity sm is
generic (
constant DATA_WIDTH: integer := 32;
constant TRUNCATED_BITS: integer := 25
);
port (
A: in std_logic_vector(DATA_WIDTH-1 downto 0);
B: in std_logic_vector(DATA_WIDTH-1 downto 0);
V: out std_logic_vector(DATA_WIDTH*2-1 downto 0)
);
end sm;
architecture sm of sm is
component full_adder is
port (
a: in std_logic;
b: in std_logic;
p_In: in std_logic;
s: out std_logic;
p_Out: out std_logic
);
end component;
component half_adder is
port (
a: in std_logic;
b: in std_logic;
s: out std_logic;
p_Out: out std_logic
);
end component;
signal T: std_logic_vector(DATA_WIDTH*(DATA_WIDTH-1)-1 downto 0);
signal C: std_logic_vector(DATA_WIDTH*(DATA_WIDTH-1)-1 downto 0);
begin
genI1J:
for j in TRUNCATED_BITS-1 to DATA_WIDTH-1 generate
genI1J0:
if j = TRUNCATED_BITS-1 generate
adder11: half_adder port map (
(A(TRUNCATED_BITS-1) and B(1)), (A(TRUNCATED_BITS) and B(0)), T(0), C(0)
);
end generate;
genI1Jn:
if j = DATA_WIDTH-1 generate
adder1n: half_adder port map (
(A(DATA_WIDTH-1) and B(1)), C(DATA_WIDTH-2), T(DATA_WIDTH-1), C(DATA_WIDTH-1)
);
end generate;
genI1Jx:
if j > TRUNCATED_BITS-1 and j < DATA_WIDTH-1 generate
adder1x: full_adder port map (
(A(j) and B(1)), (A(j+1) and B(0)), C(j-1), T(j), C(j)
);
end generate;
end generate;
genI:
for i in 1 to DATA_WIDTH-2 generate
genIJ0n:
if i<TRUNCATED_BITS generate
adderx0n: half_adder port map (
T((i-1)*DATA_WIDTH+TRUNCATED_BITS-i), (A(TRUNCATED_BITS-i) and B(i+1)), T(i*DATA_WIDTH+TRUNCATED_BITS-i-1), C(i*DATA_WIDTH+TRUNCATED_BITS-i-1)
);
end generate genIJ0n;
genIJ0:
if i>TRUNCATED_BITS-1 generate
adderx0: half_adder port map (
T((i-1)*DATA_WIDTH+1), (A(0) and B(i+1)), T(i*DATA_WIDTH), C(i*DATA_WIDTH)
);
end generate genIJ0;
genIJx:
for j in TRUNCATED_BITS-i to DATA_WIDTH-2 generate
genIJXn0:
if j>0 generate
adderxx: full_adder port map (
T((i-1)*DATA_WIDTH+j+1), (A(j) and B(i+1)), C(i*DATA_WIDTH+j-1), T(i*DATA_WIDTH+j), C(i*DATA_WIDTH+j)
);
end generate genIJXn0;
end generate genIJx;
adderxn: full_adder port map (
C(i*DATA_WIDTH-1), (A(DATA_WIDTH-1) and B(i+1)), C((i+1)*DATA_WIDTH-2), T((i+1)*DATA_WIDTH-1), C((i+1)*DATA_WIDTH-1)
);
end generate genI;
genV:
for i in 0 to DATA_WIDTH*2-1 generate
genV0:
if i < TRUNCATED_BITS generate
V(i) <= '0';
end generate;
genV1:
if (i > TRUNCATED_BITS-1 and i < DATA_WIDTH) generate
V(i) <= T((i-1)*DATA_WIDTH);
end generate;
genV2:
if (i > DATA_WIDTH-1 and i < DATA_WIDTH*2-1) generate
V(i) <= T(DATA_WIDTH*(DATA_WIDTH-3)+i+1);
end generate;
genVn:
if i=DATA_WIDTH*2-1 generate
V(i) <= C(DATA_WIDTH*(DATA_WIDTH-1)-1);
end generate;
end generate;
end sm;