

|                                   |                                        |
|-----------------------------------|----------------------------------------|
| <b>Course Title:</b>              | Computer Organization and Architecture |
| <b>Course Number:</b>             | COE 608                                |
| <b>Semester/Year (e.g. F2017)</b> | W2023                                  |

|                   |                 |
|-------------------|-----------------|
| <b>Instructor</b> | Demetres Kostas |
|-------------------|-----------------|

|                               |                   |
|-------------------------------|-------------------|
| <b>Assignment/Lab Number:</b> | 3                 |
| <b>Assignment/Lab Title:</b>  | 32-bit ALU Design |

|                         |              |
|-------------------------|--------------|
| <b>Submission Date:</b> | Feb 1, 2023  |
| <b>Due Date:</b>        | Feb 15, 2023 |

| Student LAST Name | Student FIRST Name | Student Number | Section | Signature* |
|-------------------|--------------------|----------------|---------|------------|
| Hernandez         | Spencer            | 501033228      | 11      | Spencer H  |
| Dumlao            | Carlo              | 501018239      | 11      | C.D        |
|                   |                    |                |         |            |

\*By signing above you attest that you have contributed to this written lab report and confirm that all work you have contributed to this lab report is your own work. Any suspicion of copying or plagiarism in this work will result in an investigation of Academic Misconduct and may result in a "0" on the work, an "F" in the course, or possibly more severe penalties, as well as a Disciplinary Notice on your academic record under the Student Code of Academic Conduct, which can be found online at:  
<http://www.ryerson.ca/senate/current/pol60.pdf>

# Table of Contents

|                                |           |
|--------------------------------|-----------|
| <b>1.0 32-Bit ALU</b>          | <b>3</b>  |
| 1.1 Description                | 3         |
| 1.2 VHDL Code                  | 3         |
| 1.3 Waveform                   | 5         |
| <b>2.0 Full Adder</b>          | <b>6</b>  |
| 2.1 Description                | 6         |
| 2.2 VHDL Code                  | 6         |
| <b>3.0 32-bit Ripple Adder</b> | <b>7</b>  |
| 3.1 Description                | 7         |
| 3.2 VHDL Code                  | 7         |
| <b>4.0 Multiplexer 2:1</b>     | <b>8</b>  |
| 4.1 Description                | 8         |
| 4.2 VHDL Code                  | 9         |
| <b>5.0 Multiplexer 8:1</b>     | <b>9</b>  |
| 5.1 Description                | 9         |
| 5.2 VHDL Code                  | 9         |
| <b>6.0 Shift Left Logical</b>  | <b>10</b> |
| 6.1 Description                | 10        |
| 6.2 VHDL Code                  | 10        |
| <b>7.0 Shift Right Logical</b> | <b>10</b> |
| 7.1 Description                | 10        |
| 7.2 VHDL Code                  | 11        |
| <b>8.0 32-Bit AND Operator</b> | <b>11</b> |
| 8.1 Description                | 11        |
| 8.2 VHDL Code                  | 11        |
| <b>9.0 32-Bit OR Operator</b>  | <b>11</b> |
| 9.1 Description                | 11        |
| 9.2 VHDL Code                  | 12        |
| <b>10.0 Zero Detector</b>      | <b>12</b> |
| 10.1 Description               | 12        |
| 10.2 VHDL Code                 | 12        |
| <b>11.0 Carry Detector</b>     | <b>13</b> |
| 11.1 Description               | 13        |

|                                      |           |
|--------------------------------------|-----------|
| 11.2 VHDL Code                       | 13        |
| <b>12.0 Decoder 4:7</b>              | <b>13</b> |
| 12.1 Description                     | 13        |
| 12.2 VHDL Code                       | 13        |
| <b>13.0 32-Bit ALU + Decoder 4:7</b> | <b>14</b> |
| 13.1 Description                     | 14        |
| 13.2 VHDL Code                       | 14        |
| 13.3 Diagram                         | 16        |
| 13.4 Waveform                        | 16        |
| <b>14.0 Discussion</b>               | <b>17</b> |

# 1.0 32-Bit ALU

## 1.1 Description

The main component that is used to perform arithmetic and bitwise operations on two 32-bit numbers.

## 1.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3. use ieee.std_logic_arith.all;
4. use ieee.std_logic_unsigned.all;
5.
6. entity alu is
7. port(
8.     a      : in    std_logic_vector(31 downto 0) := (others => '0');
9.     b      : in    std_logic_vector(31 downto 0) := (others => '0');
10.    op     : in    std_logic_vector(2 downto 0);
11.    result : out   std_logic_vector(31 downto 0);
12.    cout   : out   std_logic;
13.    zero   : out   std_logic);
14.end alu;
15.
16.architecture description of alu is
17.    component rippleAdder32
18.        port (
19.            a          : in    std_logic_vector(31
downto 0);
20.            b          : in    std_logic_vector(31
downto 0);
21.            cin       : in    std_logic;
22.            cout      : out   std_logic;
23.            s         : out   std_logic_vector(31 downto 0)
24.        );
25.    end component;
26.    component mux2to1
27.        port (
28.            s          : in    std_logic;
29.            w0, w1   : in    std_logic_vector(31 downto 0);
30.            f         : out   std_logic_vector(31 downto 0)
31.        );
32.    end component;
33.    component mux8to1
34.        port (
35.            s          : in    std_logic_vector(2 downto 0);
36.            w0         : in    std_logic_vector(31 downto 0);
37.            w1         : in    std_logic_vector(31 downto 0);
38.            w2         : in    std_logic_vector(31 downto 0);

```

```

39.           w3 : in      std_logic_vector(31 downto 0);
40.           w4 : in      std_logic_vector(31 downto 0);
41.           w5 : in      std_logic_vector(31 downto 0);
42.           w6 : in      std_logic_vector(31 downto 0);
43.           w7 : in      std_logic_vector(31 downto 0);
44.           f    : out     std_logic_vector(31 downto 0)
45.       );
46.   end component;
47. component shiftLeft
48.   port (
49.       w    : in      std_logic_vector(31 downto 0);
50.       f    : out    std_logic_vector(31 downto 0)
51.   );
52. end component;
53. component shiftRight
54.   port (
55.       w    : in      std_logic_vector(31 downto 0);
56.       f    : out    std_logic_vector(31 downto 0)
57.   );
58. end component;
59. component andOp
60.   port (
61.       a    : in      std_logic_vector(31 downto 0);
62.       b    : in      std_logic_vector(31 downto 0);
63.       f    : out    std_logic_vector(31 downto 0)
64.   );
65. end component;
66. component orOp
67.   port (
68.       a    : in      std_logic_vector(31 downto 0);
69.       b    : in      std_logic_vector(31 downto 0);
70.       f    : out    std_logic_vector(31 downto 0)
71.   );
72. end component;
73. component zeroDetect
74.   port (
75.       w    : in      std_logic_vector(31 downto 0);
76.       f    : out    std_logic
77.   );
78. end component;
79. component carryDetect
80.   port (
81.       a    : in      std_logic;
82.       b    : in      std_logic;
83.       f    : out    std_logic
84.   );
85. end component;
86.
87. signal c_out : std_logic;
88. signal z_out : std_logic;
89. signal add_carry : std_logic;
90. signal gnd : std_logic_vector(31 downto 0):= (others => '0');

```

```

91.      signal b_not : std_logic_vector(31 downto 0);
92.      signal add_out : std_logic_vector(31 downto 0);
93.      signal and_out : std_logic_vector(31 downto 0);
94.      signal or_out : std_logic_vector(31 downto 0);
95.      signal rol_out : std_logic_vector(31 downto 0);
96.      signal ror_out : std_logic_vector(31 downto 0);
97.      signal mux2tol_out : std_logic_vector(31 downto 0);
98.      signal mux8tol_out : std_logic_vector(31 downto 0);
99. begin
100.     and32 : andOp port map(a, b, and_out);
101.     or32 : orOp port map(a, b, or_out);
102.
103.     b_not <= not b;
104.     smallMux : mux2tol port map(op(2), b, b_not, mux2tol_out);
105.     adder32 : rippleAdder32 port map(a, mux2tol_out, op(2), add_carry,
106.                                         add_out);
107.     logicLeft32 : shiftLeft port map(a, rol_out);
108.     logicRight32 : shiftRight port map(a, ror_out);
109.
110.     largeMux : mux8tol port map(op, and_out, or_out, add_out, gnd,
111.                                   rol_out, ror_out, add_out, gnd, mux8tol_out);
112.     zeroSystem : zeroDetect port map(mux8tol_out, z_out);
113.     carrySystem : carryDetect port map(add_carry, op(1), c_out);
114.     result <= mux8tol_out;
115.     zero <= z_out;
116.     cout <= c_out;
117.
118. end description;

```

## 1.3 Waveform

The functional and timing waveform of the 32-bit ALU are shown in Figure 1.1 and Figure 1.2, respectively. The correctness of its output waveform is briefly discussed below :

- **AND:** The 1st operation that the ALU performed (i.e. [0, 100 ns]). As expected, the zero flag is set to high during this time, as a result of the signal ‘a’ that has a current value of 0x0.
- **OR:** The 2nd operation that the ALU performed (i.e. [100ns, 200 ns]). For this time interval, the signal ‘a’ and ‘b’ have a value of 0x1 and 0x0, respectively; hence, the output of the ALU is immediately set to 0x1 forcing the zero flag to be low.
- **ADD:** The 3rd operation that the ALU performed (i.e. [200ns, 300 ns]). In this time interval, its output is 0x7, which is to be expected since the current operands are 0x4 and 0x3 ( $0x04+0x03 = 0x07$ ).
- **SUB:** The 4th operation that the ALU performed (i.e. [300ns, 400 ns]). During this time interval, its output has a value of 0x1 due to the current operands of 0x4 and 0x3

( $0x04 - 0x03 = 0x01$ ). Notice that the operation and these operands have set the carry out of the ALU to be high.

- **ROL:** The 4th operation that the ALU performed (i.e. [400ns, 500 ns]). During this operation, the '1' bit at the least significant bit of signal 'a' has been shifted to the left, resulting in an output value of 0x2.
- **ROR:** The last operation that the ALU performed (i.e. [500ns, 600 ns]). In this time interval, the value 0x2 from the input signal has been shifted to the right, resulting in an output value of 0x1.



Figure 1.1: Functional waveform of the 32-bit ALU.



Figure 1.2: Timing waveform of the 32-bit ALU.

## 2.0 Full Adder

### 2.1 Description

Performs the addition of three binary inputs, which is an essential component of the ripple adder.

### 2.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;

```

```

3. use ieee.std_logic_arith.all;
4. use ieee.std_logic_unsigned.all;
5.
6. entity fullAdder is
7. port(
8.     a : in std_logic;
9.     b : in std_logic;
10.    cin : in std_logic;
11.    cout : out std_logic;
12.    s : out std_logic
13. );
14.end fullAdder;
15.
16.architecture description of fullAdder is
17.begin
18.    s <= a xor b xor cin;
19.    cout <= ((a xor b) and cin) or (a and b);
20.end description;

```

## 3.0 32-bit Ripple Adder

### 3.1 Description

A complex component composed of multiple full adders that is capable of adding and subtracting two 32-bit signals. This ripple adder is always used whenever the ALU wants to perform an ADD or SUB operation.

### 3.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3. use ieee.std_logic_arith.all;
4. use ieee.std_logic_unsigned.all;
5.
6. entity rippleAdder32 is
7. port(
8.     a : in std_logic_vector(31 downto 0);
9.     b : in std_logic_vector(31 downto 0);
10.    cin : in std_logic;
11.    cout : out std_logic;
12.    s : out std_logic_vector(31 downto 0)
13. );
14.end rippleAdder32;
15.
16.architecture description of rippleAdder32 is
17.    component fullAdder
18.        port (
19.            a : in std_logic;

```

```

20.      b      :  in      std_logic;
21.      cin   :  in      std_logic;
22.      cout  :  out    std_logic;
23.      s      :  out    std_logic
24. );
25. end component;
26. signal c : std_logic_vector(31 downto 0);
27. begin
28.   add0 : fullAdder port map(a(0), b(0), cin, c(0), s(0));
29.   add1 : fullAdder port map(a(1), b(1), c(0), c(1), s(1));
30.   add2 : fullAdder port map(a(2), b(2), c(1), c(2), s(2));
31.   add3 : fullAdder port map(a(3), b(3), c(2), c(3), s(3));
32.   add4 : fullAdder port map(a(4), b(4), c(3), c(4), s(4));
33.   add5 : fullAdder port map(a(5), b(5), c(4), c(5), s(5));
34.   add6 : fullAdder port map(a(6), b(6), c(5), c(6), s(6));
35.   add7 : fullAdder port map(a(7), b(7), c(6), c(7), s(7));
36.   add8 : fullAdder port map(a(8), b(8), c(7), c(8), s(8));
37.   add9 : fullAdder port map(a(9), b(9), c(8), c(9), s(9));
38.   add10 : fullAdder port map(a(10), b(10), c(9), c(10), s(10));
39.   add11 : fullAdder port map(a(11), b(11), c(10), c(11), s(11));
40.   add12 : fullAdder port map(a(12), b(12), c(11), c(12), s(12));
41.   add13 : fullAdder port map(a(13), b(13), c(12), c(13), s(13));
42.   add14 : fullAdder port map(a(14), b(14), c(13), c(14), s(14));
43.   add15 : fullAdder port map(a(15), b(15), c(14), c(15), s(15));
44.   add16 : fullAdder port map(a(16), b(16), c(15), c(16), s(16));
45.   add17 : fullAdder port map(a(17), b(17), c(16), c(17), s(17));
46.   add18 : fullAdder port map(a(18), b(18), c(17), c(18), s(18));
47.   add19 : fullAdder port map(a(19), b(19), c(18), c(19), s(19));
48.   add20 : fullAdder port map(a(20), b(20), c(19), c(20), s(20));
49.   add21 : fullAdder port map(a(21), b(21), c(20), c(21), s(21));
50.   add22 : fullAdder port map(a(22), b(22), c(21), c(22), s(22));
51.   add23 : fullAdder port map(a(23), b(23), c(22), c(23), s(23));
52.   add24 : fullAdder port map(a(24), b(24), c(23), c(24), s(24));
53.   add25 : fullAdder port map(a(25), b(25), c(24), c(25), s(25));
54.   add26 : fullAdder port map(a(26), b(26), c(25), c(26), s(26));
55.   add27 : fullAdder port map(a(27), b(27), c(26), c(27), s(27));
56.   add28 : fullAdder port map(a(28), b(28), c(27), c(28), s(28));
57.   add29 : fullAdder port map(a(29), b(29), c(28), c(29), s(29));
58.   add30 : fullAdder port map(a(30), b(30), c(29), c(30), s(30));
59.   add31 : fullAdder port map(a(31), b(31), c(30), c(31), s(31));
60.   cout <= c(31);
61. end description;

```

## 4.0 Multiplexer 2:1

### 4.1 Description

A small multiplexer that is used to invert a 32-bit signal when the ripple adder is operating in a subtraction mode.

## 4.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3.
4. entity mux2to1 is
5. port (
6.     s      : in    std_logic;
7.     w0, w1 : in    std_logic_vector(31 downto 0);
8.     f      : out   std_logic_vector(31 downto 0)
9. );
10.end mux2to1;
11.
12.architecture Behavior of mux2to1 is
13.begin
14.    with s select
15.        f <= w0 when '0',
16.                  w1 when others;
17.end Behavior;

```

## 5.0 Multiplexer 8:1

### 5.1 Description

A big multiplexer that chooses the operation to be executed by the ALU, based on the 3-bit signal ALU-Op.

## 5.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3.
4. entity mux8to1 is
5.
6. port (
7.     s      : in    std_logic_vector(2 downto 0);
8.     w0    : in    std_logic_vector(31 downto 0);
9.     w1    : in    std_logic_vector(31 downto 0);
10.    w2    : in    std_logic_vector(31 downto 0);
11.    w3    : in    std_logic_vector(31 downto 0);
12.    w4    : in    std_logic_vector(31 downto 0);
13.    w5    : in    std_logic_vector(31 downto 0);
14.    w6    : in    std_logic_vector(31 downto 0);
15.    w7    : in    std_logic_vector(31 downto 0);
16.    f      : out   std_logic_vector(31 downto 0)
17. );
18.end mux8to1;
19.

```

```

20.architecture Behavior of mux8to1 is
21.begin
22.      with s select
23.          f <= w0 when "000",
24.          w1 when "001",
25.          w2 when "010",
26.          w3 when "011",
27.          w4 when "100",
28.          w5 when "101",
29.          w6 when "110",
30.          w7 when "111";
31.end Behavior;

```

## 6.0 Shift Left Logical

### 6.1 Description

Moves a 32-bit data to the left and replaces its least significant bit by a zero bit. This is used as a ROL operation for the ALU.

### 6.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3.
4. entity shiftLeft is
5. port (
6.     w      : in    std_logic_vector(31 downto 0);
7.     f      : out   std_logic_vector(31 downto 0)
8. );
9. end shiftLeft;
10.
11.architecture Behavior of shiftLeft is
12.begin
13.     f <= w(30 downto 0) & '0';
14.end Behavior;

```

## 7.0 Shift Right Logical

### 7.1 Description

Moves a 32-bit data to the right and replaces its most significant bit by a zero bit. This is used as a ROR operation for the ALU.

## 7.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3.
4. entity shiftRight is
5. port (
6.     w      : in    std_logic_vector(31 downto 0);
7.     f      : out   std_logic_vector(31 downto 0)
8. );
9. end shiftRight;
10.
11.architecture Behavior of shiftRight is
12.begin
13.     f <= '0' & w(31 downto 1);
14.end Behavior;

```

# 8.0 32-Bit AND Operator

## 8.1 Description

Performs an AND operation between two 32-bit signals for the ALU.

## 8.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3.
4. entity andOp is
5. port (
6.     a      : in    std_logic_vector(31 downto 0);
7.     b      : in    std_logic_vector(31 downto 0);
8.     f      : out   std_logic_vector(31 downto 0)
9. );
10.end andOp;
11.
12.architecture Behavior of andOp is
13.begin
14.     f <= a and b;
15.end Behavior;

```

# 9.0 32-Bit OR Operator

## 9.1 Description

Performs an OR operation between two 32-bit signals for the ALU.

## 9.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3.
4. entity orOp is
5. port (
6.     a      : in    std_logic_vector(31 downto 0);
7.     b      : in    std_logic_vector(31 downto 0);
8.     f      : out   std_logic_vector(31 downto 0)
9. );
10.end orOp;
11.
12.architecture Behavior of orOp is
13.begin
14.     f <= a or b;
15.end Behavior;

```

## 10.0 Zero Detector

### 10.1 Description

A component that updates the zero flag based on the output of the 32-bit ALU. It is set to low if the output is a non-zero value; otherwise, the flag is set to high.

### 10.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3.
4. entity zeroDetect is
5. port (
6.     w      : in    std_logic_vector(31 downto 0);
7.     f      : out   std_logic
8. );
9. end zeroDetect;
10.
11.architecture Behavior of zeroDetect is
12.begin
13.     f <= not(w(0) or w(1) or w(2) or w(3) or w(4) or w(5)
14.                 or w(6) or w(7) or w(8) or w(9) or w(10)
15.                 or w(11) or w(12) or w(13) or w(14) or w(15)
16.                 or w(16) or w(17) or w(18) or w(19) or w(20)
17.                 or w(21) or w(22) or w(23) or w(24) or w(25)
18.                 or w(26) or w(27) or w(28) or w(29) or w(30)
19.                 or w(31));
20.end Behavior;

```

# 11.0 Carry Detector

## 11.1 Description

A component that updates the carry flag depending on the output carry of the ripple adder, as well as the current operation of the ALU. Specifically, when the ALU is adding or subtracting, then the flag only depends on the output carry of the adder; otherwise, the flag is always set to low.

## 11.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3.
4. entity carryDetect is
5. port (
6.     a      : in    std_logic;
7.     b      : in    std_logic;
8.     f      : out   std_logic
9. );
10.end carryDetect;
11.
12.architecture Behavior of carryDetect is
13.begin
14.    f <= a and b;
15.end Behavior;
```

# 12.0 Decoder 4:7

## 12.1 Description

A decoder that is used to control a single 7-segment display, based on the incoming 4-bit data of the ALU.

## 12.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3.
4. entity decoder is
5. port (
6.     s      : in    std_logic_vector(3 downto 0);
7.     f      : out   std_logic_vector(6 downto 0)
8. );
9. end decoder;
```

```

10.
11. architecture Behavior of decoder is
12.     signal f_out : std_logic_vector(6 downto 0);
13. begin
14.     with s select
15.         f_out <= "1111110" when "0000",
16.                 "0110000" when "0001",
17.                         "1101101" when "0010",
18.                         "1111001" when "0011",
19.                         "0110011" when "0100",
20.                         "1011011" when "0101",
21.                         "1011111" when "0110",
22.                         "1110000" when "0111",
23.                         "1111111" when "1000",
24.                         "1111011" when "1001",
25.                         "1110111" when "1010",
26.                         "0011111" when "1011",
27.                         "1001110" when "1100",
28.                         "0111101" when "1101",
29.                         "1001111" when "1110",
30.                         "1000111" when "1111";
31.         f <= not f_out;
32. end Behavior;

```

## 13.0 32-Bit ALU + Decoder 4:7

### 13.1 Description

The complete system that is used to display the 32-bit output of the ALU in the 8 digit 7-segment LED display.

### 13.2 VHDL Code

```

1. library ieee;
2. use ieee.std_logic_1164.all;
3. use ieee.std_logic_arith.all;
4. use ieee.std_logic_unsigned.all;
5.
6. entity alu_7seg is
7. port(
8.     a      : in    std_logic_vector(31 downto 0);
9.     b      : in    std_logic_vector(31 downto 0);
10.    op     : in    std_logic_vector(2 downto 0);
11.    r0    : out   std_logic_vector(6 downto 0);
12.    r1    : out   std_logic_vector(6 downto 0);
13.    r2    : out   std_logic_vector(6 downto 0);
14.    r3    : out   std_logic_vector(6 downto 0);
15.    r4    : out   std_logic_vector(6 downto 0);
16.    r5    : out   std_logic_vector(6 downto 0);

```

```

17.      r6 :  out    std_logic_vector(6 downto 0);
18.      r7 :  out    std_logic_vector(6 downto 0);
19.      cout :       out    std_logic;
20.      zero :       out    std_logic);
21.end alu_7seg;
22.
23.architecture description of alu_7seg is
24.      component   alu
25.          port (
26.              a      :  in     std_logic_vector(31 downto 0) := (others =>
27.                                         '0');
28.              b      :  in     std_logic_vector(31 downto 0) := (others =>
29.                                         '0');
30.              op     :  in     std_logic_vector(2 downto 0);
31.              result:  out    std_logic_vector(31 downto 0);
32.              cout   :  out    std_logic;
33.              zero   :  out    std_logic
34.          );
35.      end component;
36.
37.      component   decoder
38.          port (
39.              s      :  in     std_logic_vector(3 downto 0);
40.              f      :  out    std_logic_vector(6 downto 0)
41.          );
42.      end component;
43.begin
44.      alu32 : alu port map(a, b, op, result, cout, zero);
45.      d0 : decoder port map(result(3 downto 0), r0);
46.      d1 : decoder port map(result(7 downto 4), r1);
47.      d2 : decoder port map(result(11 downto 8), r2);
48.      d3 : decoder port map(result(15 downto 12), r3);
49.      d4 : decoder port map(result(19 downto 16), r4);
50.      d5 : decoder port map(result(23 downto 20), r5);
51.      d6 : decoder port map(result(27 downto 24), r6);
52.      d7 : decoder port map(result(31 downto 28), r7);
53.
54.end description;

```

### 13.3 Diagram



Figure 13.1: Schematic of the 32-bit ALU, along with the 4 to 7 decoders.

### 13.4 Waveform

Its functional and timing waveform are shown in Figure 13.2 and Figure 13.3, respectively. Notice that each decoder is able to receive a unique 4-bit data from the 32-bit ALU. When the ALU output is 0x00000018 (i.e. during the time interval [600, 900ns]), it is evident that the decoder 'S0' holds the first 4-bit (0x8) while 'S1' holds the second 4-bit (0x1); and since the next bits of the output are all zero, the rest of the decoders are also set to a value of 0x0.



Figure 13.2: Functional waveform of the 32-Bit ALU + Decoder 4:7.



Figure 13.3: Timing waveform of the 32-Bit ALU + Decoder 4:7.

## 14.0 Discussion

Depending on the different opcodes the ALU is capable of performing bitwise and arithmetic operations as observed from the functional diagram. Upon looking at the timing diagram Figure 1.2 there appears to be a bigger dealer upon the addition function and the subtraction function that it does for bitwise operations such as the AND and OR function. This stems from the fact that it was implemented using a ripple carry adder. In contrast to the look ahead adder, the ripple carry adder carries more propagation delay proportional to the size of the number in bits. Due to a finite amount of time to perform each carry the propagation delay increases as the number of time it takes to carry occurs consecutively instead of instantaneously.

In Figure 14.1 below, notice that the time delay depends on the value of the operands – the larger the binary, the greater instability the ALU will experience. Taking this into consideration, the worst case path  $T_{WC}$  of the designed ALU can be approximated by setting all bits of signal ‘a’ to one bit and allowing signal ‘b’ to have a value of 0x1. This will ensure that all of the full adders within the ripple adder are triggered by a carry, when the ALU is performing an ADD operation. By inspection, the  $T_{WC}$  is around 50ns or  $f_{WC} \approx 20MHz$ . The CPU frequency should not go below this frequency; otherwise, the ALU will likely output unwanted data.



Figure 14.1: Timing waveform showing the effect of adding a large number.