

# **EE529 Embedded Systems**

Group 1

## **Lab Assignment 4**

**Student Name :** Ayan Garg and Om Maheshwari

**Roll Number :** B23484 and B23089

## Contents

|                                                          |           |
|----------------------------------------------------------|-----------|
| <b>1 Question 1</b>                                      | <b>2</b>  |
| 1.1 VHDL Implementation of Half Adder . . . . .          | 2         |
| 1.2 Results . . . . .                                    | 2         |
| <b>2 Question 2</b>                                      | <b>3</b>  |
| 2.1 VHDL Implementation of Full Adder . . . . .          | 3         |
| 2.2 Results . . . . .                                    | 4         |
| <b>3 Question 3</b>                                      | <b>4</b>  |
| 3.1 4-bit Ripple Carry Adder (RCA) . . . . .             | 4         |
| 3.1.1 Architecture . . . . .                             | 4         |
| 3.1.2 Carry Propagation . . . . .                        | 4         |
| 3.2 Technology Schematic Observations . . . . .          | 4         |
| 3.3 4-bit Carry Look-Ahead Adder (CLA) . . . . .         | 5         |
| 3.3.1 Architecture . . . . .                             | 5         |
| 3.3.2 Technology Schematic Observations . . . . .        | 5         |
| 3.4 Comparison & Inferences . . . . .                    | 6         |
| 3.4.1 Inferences from the Technology Schematic . . . . . | 6         |
| 3.5 VHDL Implementation of 4-Bit RCA Adder . . . . .     | 6         |
| 3.6 VHDL Implementation of 4-Bit CLA Adder . . . . .     | 7         |
| 3.7 Results . . . . .                                    | 8         |
| <b>4 Question 4</b>                                      | <b>9</b>  |
| 4.1 Theory . . . . .                                     | 9         |
| 4.1.1 Seven-Segment Display . . . . .                    | 9         |
| 4.1.2 BCD to Seven-Segment Decoding . . . . .            | 10        |
| 4.2 Hardware . . . . .                                   | 11        |
| 4.2.1 Equipment . . . . .                                | 11        |
| 4.2.2 PMOD JA Pin Configuration . . . . .                | 11        |
| 4.2.3 Physical Setup . . . . .                           | 12        |
| 4.3 VHDL Implementation . . . . .                        | 13        |
| 4.3.1 VHDL Design Code . . . . .                         | 13        |
| 4.3.2 XDC Constraint File . . . . .                      | 13        |
| 4.4 Results . . . . .                                    | 13        |
| 4.4.1 Observed Outputs . . . . .                         | 14        |
| <b>5 Question 5</b>                                      | <b>15</b> |
| <b>6 Question 6</b>                                      | <b>15</b> |
| 6.1 Theory . . . . .                                     | 15        |
| 6.1.1 Working Principle . . . . .                        | 15        |
| 6.1.2 Overflow and Borrow Detection . . . . .            | 16        |
| 6.2 VHDL Implementation . . . . .                        | 16        |
| 6.3 Results . . . . .                                    | 16        |

## 1 Question 1



Figure 1: Schematic of Half Adder

### 1.1 VHDL Implementation of Half Adder

```

1 library IEEE;
2 use IEEE.STD_LOGIC_1164.ALL;
3
4 entity HA is
5     Port (
6         A      : in STD_LOGIC;
7         B      : in STD_LOGIC;
8         SUM   : out STD_LOGIC;
9         CARRY : out STD_LOGIC
10    );
11 end HA;
12
13 architecture dataflow of HA is
14 begin
15
16     SUM  <= A xor B;
17     CARRY <= A and B;
18
19 end dataflow;

```

Listing 1: VHDL Code for Half Adder

```

1 #####Switches
2 set_property -dict { PACKAGE_PIN G15    IOSTANDARD LVCMOS33 } [get_ports { A }]; #IO_L19N_T3_VREF_35 Sch=sw[0]
3 set_property -dict { PACKAGE_PIN P15    IOSTANDARD LVCMOS33 } [get_ports { B }]; #IO_L24P_T3_34 Sch=sw[1]
4
5 ##LEDs
6 set_property -dict { PACKAGE_PIN M14    IOSTANDARD LVCMOS33 } [get_ports { SUM }]; #IO_L23P_T3_35 Sch=led[0]
7 set_property -dict { PACKAGE_PIN M15    IOSTANDARD LVCMOS33 } [get_ports { CARRY }]; #IO_L23N_T3_35 Sch=led[1]

```

Listing 2: Constraint File for Half Adder

### 1.2 Results



Figure 2: Realized Schematic for Half Adder

## 2 Question 2



Figure 3: Schematic of Full Adder using Half Adders

### 2.1 VHDL Implementation of Full Adder

```

1 library IEEE;
2 use IEEE.STD_LOGIC_1164.ALL;
3
4 entity FA is
5   Port (
6     A      : in  STD_LOGIC;
7     B      : in  STD_LOGIC;
8     Cin   : in  STD_LOGIC;
9     SUM   : out STD_LOGIC;
10    Cout  : out STD_LOGIC
11  );
12 end FA;
13
14 architecture structural of FA is
15
16   component HA
17     Port (
18       A      : in  STD_LOGIC;
19       B      : in  STD_LOGIC;
20       SUM   : out STD_LOGIC;
21       CARRY : out STD_LOGIC
22     );
23   end component;
24
25   signal S1, C1, C2 : STD_LOGIC;
26
27 begin
28
29   HA1: HA
30     port map (
31       A      => A,
32       B      => B,
33       SUM   => S1,
34       CARRY => C1
35     );
36
37   HA2: HA
38     port map (
39       A      => S1,
40       B      => Cin,
41       SUM   => SUM,
42       CARRY => C2
43     );
44
45   Cout <= C1 or C2;
46
47 end structural;

```

Listing 3: VHDL Code for Full Adder

## 2.2 Results



Figure 4: Realized Schematic for Full Adder

## 3 Question 3

### 3.1 4-bit Ripple Carry Adder (RCA)

#### 3.1.1 Architecture

Four full adders are cascaded so that the carry-out of stage  $i$  feeds the carry-in of stage  $i+1$ , as shown in Figure 5.



Figure 5: Block diagram of the 4-bit Ripple Carry Adder.

#### 3.1.2 Carry Propagation

The  $n$ -bit RCA critical path traverses all  $n$  full adders serially:

$$t_{RCA} = n \cdot t_{FA}$$

For  $n = 4$  and a typical full-adder gate delay of  $t_{FA}$ , the total delay is  $4t_{FA}$ . Each additional bit adds one full-adder delay, making the RCA *linearly slow* for large  $n$ .

## 3.2 Technology Schematic Observations

Examining the synthesised schematic in the CAD tool reveals:

- The carry chain is a long path of XOR and AND-OR gates connected end-to-end, clearly visible as a horizontal daisy-chain.
- The synthesis tool may automatically infer a carry-chain primitive (e.g. FPGA CARRY4) to speed up the ripple, but the logical structure remains serial.

- Gate count is minimal ( $\approx 2$  XOR + 3 AND/OR per bit), making the RCA very *area-efficient*.

### 3.3 4-bit Carry Look-Ahead Adder (CLA)

#### 3.3.1 Architecture

Instead of waiting for each carry to ripple, the CLA pre-computes all carries in parallel using the generate and propagate signals:

$$G_i = A_i \cdot B_i \quad P_i = A_i \oplus B_i \quad (1)$$

$$C_1 = G_0 + P_0 C_0 \quad (2)$$

$$C_2 = G_1 + P_1 G_0 + P_1 P_0 C_0 \quad (3)$$

$$C_3 = G_2 + P_2 G_1 + P_2 P_1 G_0 + P_2 P_1 P_0 C_0 \quad (4)$$

$$C_4 = G_3 + P_3 G_2 + P_3 P_2 G_1 + P_3 P_2 P_1 G_0 + P_3 P_2 P_1 P_0 C_0 \quad (5)$$

All carries  $C_1-C_4$  are available simultaneously after a *fixed* two-level AND-OR delay.



Figure 6: Block diagram of the 4-bit Carry Look-Ahead Adder.

#### 3.3.2 Technology Schematic Observations

The synthesised CLA schematic shows:

- A **fan-in explosion**: gates in the CLA logic unit have increasingly large fan-ins (up to  $n + 1$ ) for higher carry bits, which can force the synthesiser to add buffer trees.
- The carry logic is a wide two-level AND-OR network, clearly distinct from the narrow serial chain seen in the RCA.
- Sum outputs are produced by XOR-ing the partial-FA outputs with the pre-computed carries, so their delay is also nearly constant.
- Overall gate count is *significantly higher* than the RCA.

### 3.4 Comparison & Inferences

Table 1 summarises the key differences.

Table 1: RCA vs. CLA — Summary Comparison

| Metric                     | Ripple Carry (RCA)                 | Carry Look-Ahead (CLA)                   |
|----------------------------|------------------------------------|------------------------------------------|
| <b>Delay</b>               | $O(n)$ — linear with bits          | $O(\log n)$ — parallel carry computation |
| <b>Gate Count</b>          | Low ( $\approx 5n$ gates)          | Higher (extra propagate/generate logic)  |
| <b>Wiring</b>              | Simple, serial carry chain         | Complex, wide carry network              |
| <b>Fan-in</b>              | Small (max 2–3)                    | Large (grows with block size)            |
| <b>Scalability</b>         | Poor for large $n$                 | Better; hierarchical design used         |
| <b>FPGA Mapping</b>        | Uses fast dedicated carry chain    | Often reduces to carry-chain logic       |
| <b>Area</b>                | Compact                            | Larger; more routing resources           |
| <b>Power (Dynamic)</b>     | Lower switching activity           | Higher due to wide carry logic           |
| <b>Glitch Power</b>        | Minimal                            | Higher (reconvergent paths)              |
| <b>Logical Depth</b>       | Linear ( $\approx 2n$ gate levels) | Logarithmic ( $\log n$ )                 |
| <b>Layout Regularity</b>   | Highly regular                     | Irregular routing                        |
| <b>Maximum Frequency</b>   | Limited                            | Higher (ASIC implementation)             |
| <b>Design Complexity</b>   | Simple                             | Complex carry network                    |
| <b>Preferred Word Size</b> | Small/medium                       | Medium/large (hierarchical)              |

#### 3.4.1 Inferences from the Technology Schematic

- Speed vs. Area trade-off.** The CLA schematic is visibly larger and more densely connected than the RCA, yet its critical path is shorter. This is a classic trade-off: speed is bought with additional gates and wiring.
- Ripple chain visibility in RCA.** The RCA schematic shows a straight carry chain with no parallelism. Any single slow gate on this path becomes the timing bottleneck for the entire adder.
- Fan-in limits CLA scalability.** As  $n$  grows, the CLA carry equations require AND gates with up to  $n$  inputs. For  $n > 4$ , the synthesiser must split large gates into multi-level trees, which partially erodes the speed advantage. Practical large adders therefore use *hierarchical* CLA or Kogge–Stone / Brent–Kung trees.

### 3.5 VHDL Implementation of 4-Bit RCA Adder

```

1 library IEEE;
2 use IEEE.STD_LOGIC_1164.ALL;
3
4 entity RCA_4bit is
5   Port (
6     A      : in STD_LOGIC_VECTOR(3 downto 0);
7     B      : in STD_LOGIC_VECTOR(3 downto 0);
8     Cin   : in STD_LOGIC;
9     SUM   : out STD_LOGIC_VECTOR(3 downto 0);
10    Cout  : out STD_LOGIC
11  );

```

```

12 end RCA_4bit;
13
14 architecture structural of RCA_4bit is
15
16 component FA
17   Port (
18     A      : in STD_LOGIC;
19     B      : in STD_LOGIC;
20     Cin   : in STD_LOGIC;
21     SUM   : out STD_LOGIC;
22     Cout  : out STD_LOGIC
23   );
24 end component;
25
26 signal C : STD_LOGIC_VECTOR(3 downto 0);
27
28 begin
29
30   FA0: FA
31     port map (
32       A      => A(0),
33       B      => B(0),
34       Cin   => Cin,
35       SUM   => SUM(0),
36       Cout  => C(0)
37     );
38
39   FA1: FA
40     port map (
41       A      => A(1),
42       B      => B(1),
43       Cin   => C(0),
44       SUM   => SUM(1),
45       Cout  => C(1)
46     );
47
48   FA2: FA
49     port map (
50       A      => A(2),
51       B      => B(2),
52       Cin   => C(1),
53       SUM   => SUM(2),
54       Cout  => C(2)
55     );
56
57
58   FA3: FA
59     port map (
60       A      => A(3),
61       B      => B(3),
62       Cin   => C(2),
63       SUM   => SUM(3),
64       Cout  => C(3)
65     );
66
67   Cout <= C(3);
68
69 end structural;

```

Listing 4: VHDL Code for 4-Bit RCA Adder

### 3.6 VHDL Implementation of 4-Bit CLA Adder

```

1 library IEEE;
2 use IEEE.STD_LOGIC_1164.ALL;
3
4 entity CLA_4bit is
5   Port (
6     A      : in STD_LOGIC_VECTOR(3 downto 0);
7     B      : in STD_LOGIC_VECTOR(3 downto 0);
8     Cin   : in STD_LOGIC;
9     SUM   : out STD_LOGIC_VECTOR(3 downto 0);
10    Cout  : out STD_LOGIC
11  );
12 end CLA_4bit;
13
14 architecture structural of CLA_4bit is
15
16   component FA
17     Port (
18       A      : in STD_LOGIC;
19       B      : in STD_LOGIC;
20       Cin   : in STD_LOGIC;
21       SUM   : out STD_LOGIC;
22       Cout  : out STD_LOGIC
23     );
24   end component;
25
26   signal P, G : STD_LOGIC_VECTOR(3 downto 0);
27   signal C : STD_LOGIC_VECTOR(4 downto 0);
28
29 begin
30   C(0) <= Cin;

```

```

31      P <= A xor B;
32      G <= A and B;
33
34      C(1) <= G(0) or (P(0) and C(0));
35
36      C(2) <= G(1) or
37          (P(1) and G(0)) or
38          (P(1) and P(0) and C(0));
39
40      C(3) <= G(2) or
41          (P(2) and G(1)) or
42          (P(2) and P(1) and G(0)) or
43          (P(2) and P(1) and P(0) and C(0));
44
45      C(4) <= G(3) or
46          (P(3) and G(2)) or
47          (P(3) and P(2) and G(1)) or
48          (P(3) and P(2) and P(1) and G(0)) or
49          (P(3) and P(2) and P(1) and P(0) and C(0));
50
51      FA0: FA port map(A(0), B(0), C(0), SUM(0), open);
52      FA1: FA port map(A(1), B(1), C(1), SUM(1), open);
53      FA2: FA port map(A(2), B(2), C(2), SUM(2), open);
54      FA3: FA port map(A(3), B(3), C(3), SUM(3), open);
55
56      Cout <= C(4);
57  end structural;

```

Listing 5: VHDL Code for 4-Bit CLA Adder

### 3.7 Results



Figure 7: Realized Schematic for 4-bit RCA



Figure 8: Realized Schematic for 4-bit CLA



Figure 9: Simulation Results for 4-bit RCA



Figure 10: Simulation Results for 4-bit CLA

## 4 Question 4

### 4.1 Theory

#### 4.1.1 Seven-Segment Display

A seven-segment display is an electronic display device used to represent decimal and hexadecimal numerals. It consists of seven individual LED segments arranged in a figure-eight pattern, each of which can be independently turned ON or OFF to form digits and characters.

The seven segments are conventionally labeled **a** through **g** as shown in Figure 11:



Figure 11: Seven-segment display internal segment labeling (a–g). (Insert image here)

#### 4.1.2 BCD to Seven-Segment Decoding

A BCD (Binary Coded Decimal) to seven-segment decoder takes a 4-bit binary input and produces the appropriate 7-bit output to illuminate the correct segments. The truth table for hexadecimal digits 0–F is given in Table 2.

Table 2: Truth table for 4-bit input to seven-segment output (Common Cathode). Logic 1 = segment ON.

| <b>Digit</b> | <b>SW[3:0]</b> | <b>a</b> | <b>b</b> | <b>c</b> | <b>d</b> | <b>e</b> | <b>f</b> | <b>g</b> |
|--------------|----------------|----------|----------|----------|----------|----------|----------|----------|
| 0            | 0000           | 1        | 1        | 1        | 1        | 1        | 1        | 0        |
| 1            | 0001           | 0        | 1        | 1        | 0        | 0        | 0        | 0        |
| 2            | 0010           | 1        | 1        | 0        | 1        | 1        | 0        | 1        |
| 3            | 0011           | 1        | 1        | 1        | 1        | 0        | 0        | 1        |
| 4            | 0100           | 0        | 1        | 1        | 0        | 0        | 1        | 1        |
| 5            | 0101           | 1        | 0        | 1        | 1        | 0        | 1        | 1        |
| 6            | 0110           | 1        | 0        | 1        | 1        | 1        | 1        | 1        |
| 7            | 0111           | 1        | 1        | 1        | 0        | 0        | 0        | 0        |
| 8            | 1000           | 1        | 1        | 1        | 1        | 1        | 1        | 1        |
| 9            | 1001           | 1        | 1        | 1        | 1        | 0        | 1        | 1        |
| A            | 1010           | 1        | 1        | 1        | 0        | 1        | 1        | 1        |
| b            | 1011           | 0        | 0        | 1        | 1        | 1        | 1        | 1        |
| C            | 1100           | 1        | 0        | 0        | 1        | 1        | 1        | 0        |
| d            | 1101           | 0        | 1        | 1        | 1        | 1        | 0        | 1        |
| E            | 1110           | 1        | 0        | 0        | 1        | 1        | 1        | 1        |
| F            | 1111           | 1        | 0        | 0        | 0        | 1        | 1        | 1        |

## 4.2 Hardware

### 4.2.1 Equipment

- Digilent Zybo Z7-10/Z7-20 FPGA development board
- Common-cathode 7-segment LED display
- Jumper wires
- Breadboard

### 4.2.2 PMOD JA Pin Configuration

The PMOD JA header on the Zybo Z7 board provides 8 signal pins plus VCC and GND. The physical layout of the 12-pin connector, viewed from the front of the board, is shown in Table 3.

Table 3: Physical pin layout of PMOD JA connector (viewed from outside the board).

|            |            |             |            |            |            |
|------------|------------|-------------|------------|------------|------------|
| <b>VCC</b> | <b>GND</b> | <b>JA4</b>  | <b>JA3</b> | <b>JA2</b> | <b>JA1</b> |
| <b>VCC</b> | <b>GND</b> | <b>JA10</b> | <b>JA9</b> | <b>JA8</b> | <b>JA7</b> |

$\leftarrow$  Left (VCC/GND side) Right (Signal side)  $\rightarrow$

The signal-to-segment mapping used in this experiment is given in Table 4.

Table 4: PMOD JA pin to 7-segment display wiring.

| PMOD Pin | FPGA Package Pin | SEG Index | Display Segment |
|----------|------------------|-----------|-----------------|
| JA1      | N15              | SEG[0]    | a               |
| JA2      | L14              | SEG[1]    | b               |
| JA3      | K16              | SEG[2]    | c               |
| JA4      | K14              | SEG[3]    | d               |
| JA7      | N16              | SEG[4]    | e               |
| JA8      | L15              | SEG[5]    | f               |
| JA9      | J16              | SEG[6]    | g               |
| JA10     | J14              | SEG[7]    | dp              |
| GND      | —                | —         | Common Cathode  |

#### 4.2.3 Physical Setup



Figure 12: Seven-segment display and FPGA Setup

## 4.3 VHDL Implementation

### 4.3.1 VHDL Design Code

```

1 library IEEE;
2 use IEEE.STD_LOGIC_1164.ALL;
3
4 entity switch_to_7seg is
5   Port (
6     SW : in STD_LOGIC_VECTOR(3 downto 0);
7     SEG : out STD_LOGIC_VECTOR(7 downto 0)
8   );
9 end switch_to_7seg;
10
11 architecture Behavioral of switch_to_7seg is
12 begin
13   process(SW)
14   begin
15     SEG(7) <= '0';
16     case SW is
17       when "0000" => SEG(6 downto 0) <= "0111111"; -- 0: abcdef on, g off
18       when "0001" => SEG(6 downto 0) <= "0000110"; -- 1: bc on
19       when "0010" => SEG(6 downto 0) <= "1011011"; -- 2: abdeg on
20       when "0011" => SEG(6 downto 0) <= "1001111"; -- 3: abcdg on
21       when "0100" => SEG(6 downto 0) <= "1100110"; -- 4: bcfg on
22       when "0101" => SEG(6 downto 0) <= "1101101"; -- 5: acdfg on
23       when "0110" => SEG(6 downto 0) <= "1111101"; -- 6: acdefg on
24       when "0111" => SEG(6 downto 0) <= "0000111"; -- 7: abc on
25       when "1000" => SEG(6 downto 0) <= "1111111"; -- 8: all on
26       when "1001" => SEG(6 downto 0) <= "1101111"; -- 9: abcfg on
27       when "1010" => SEG(6 downto 0) <= "1110111"; -- A: abcefg on
28       when "1011" => SEG(6 downto 0) <= "1111100"; -- b: cdefg on
29       when "1100" => SEG(6 downto 0) <= "0111001"; -- C: adef on
30       when "1101" => SEG(6 downto 0) <= "1011110"; -- d: bcdeg on
31       when "1110" => SEG(6 downto 0) <= "1111001"; -- E: adefg on
32       when "1111" => SEG(6 downto 0) <= "1110001"; -- F: aefg on
33       when others => SEG(6 downto 0) <= "0000000";
34     end case;
35   end process;
36 end Behavioral;

```

Listing 6: VHDL implementation of the switch-to-seven-segment decoder

### 4.3.2 XDC Constraint File

```

1 #####Switches
2 set_property -dict { PACKAGE_PIN G15 IOSTANDARD LVCMOS33 } [get_ports { SW[0] }]; #IO_L19N_T3_VREF_35 Sch=sw[0]
3 set_property -dict { PACKAGE_PIN P15 IOSTANDARD LVCMOS33 } [get_ports { SW[1] }]; #IO_L24P_T3_34 Sch=sw[1]
4 set_property -dict { PACKAGE_PIN W13 IOSTANDARD LVCMOS33 } [get_ports { SW[2] }]; #IO_L4N_T0_34 Sch=sw[2]
5 set_property -dict { PACKAGE_PIN T16 IOSTANDARD LVCMOS33 } [get_ports { SW[3] }]; #IO_L9P_T1_DQS_34 Sch=sw[3]
6
7 ## PMOD Header JA used as GPIO for 7-Segment
8 set_property -dict { PACKAGE_PIN N15 IOSTANDARD LVCMOS33 } [get_ports { SEG[0] }]; # JA1
9 set_property -dict { PACKAGE_PIN L14 IOSTANDARD LVCMOS33 } [get_ports { SEG[1] }]; # JA2
10 set_property -dict { PACKAGE_PIN K16 IOSTANDARD LVCMOS33 } [get_ports { SEG[2] }]; # JA3
11 set_property -dict { PACKAGE_PIN K14 IOSTANDARD LVCMOS33 } [get_ports { SEG[3] }]; # JA4
12 set_property -dict { PACKAGE_PIN N16 IOSTANDARD LVCMOS33 } [get_ports { SEG[4] }]; # JA7
13 set_property -dict { PACKAGE_PIN L15 IOSTANDARD LVCMOS33 } [get_ports { SEG[5] }]; # JA8
14 set_property -dict { PACKAGE_PIN J16 IOSTANDARD LVCMOS33 } [get_ports { SEG[6] }]; # JA9
15 set_property -dict { PACKAGE_PIN J14 IOSTANDARD LVCMOS33 } [get_ports { SEG[7] }]; # JA10

```

Listing 7: VHDL Constraint File for switch-to-seven-segment decoder

## 4.4 Results

The design was successfully synthesized, implemented, and programmed onto the Zybo Z7 FPGA board. Upon toggling the four slide switches, the corresponding hexadecimal digit (0–F) was correctly displayed on the seven-segment display.

#### 4.4.1 Observed Outputs



Figure 13: Observed seven-segment display output for all 16 hexadecimal inputs (0–F).

## 5 Question 5

In this experiment, the half adder circuit is implemented on the FPGA using push button switches as inputs instead of slide switches. The logical functionality of the circuit remains unchanged; only the physical input interface is modified.

Push buttons are momentary switches, meaning they generate a logic level only while being pressed. Therefore, the primary modification required in this problem is in the constraint file, where the FPGA pin assignments are updated to map the half adder inputs ( $A$  and  $B$ ) to the push button pins instead of the slide switch pins. The LED output pin assignments remain the same as in Problem 1.

The RTL schematic and technology schematic generated after synthesis also remain unchanged, as the internal implementation within the FPGA configurable logic blocks (CLBs) is identical. Only the external input pin mapping differs due to the use of push button switches.

The VHDL code remains the same as in Problem 1.

```

1 ##Buttons
2 set_property -dict { PACKAGE_PIN K19  IOSTANDARD LVCMOS33 } [get_ports { A }];
3 set_property -dict { PACKAGE_PIN Y16  IOSTANDARD LVCMOS33 } [get_ports { B }];
4                                         #IO_L10P_T1_AD11P_35 Sch=btn[2]
5                                         #IO_L7P_T1_34 Sch=btn[3]
6 ##LEDs
7 set_property -dict { PACKAGE_PIN M14  IOSTANDARD LVCMOS33 } [get_ports { SUM }];
8 set_property -dict { PACKAGE_PIN M15  IOSTANDARD LVCMOS33 } [get_ports { CARRY }];
9                                         #IO_L23P_T3_35 Sch=led[0]
10                                         #IO_L23N_T3_35 Sch=led[1]
```

Listing 8: Constraint File for Half Adder

## 6 Question 6

### 6.1 Theory

A 4-bit adder-subtractor combines both addition and subtraction into a single circuit controlled by a mode signal  $M$ . The design exploits the two's complement representation of negative numbers, where subtraction  $A - B$  is equivalent to:

$$A - B = A + \overline{B} + 1 \quad (6)$$

That is, the subtrahend  $B$  is bitwise complemented (one's complement) and a 1 is added through the carry-in, yielding the two's complement negation of  $B$ .

#### 6.1.1 Working Principle

A single XOR gate per bit acts as a programmable inverter controlled by the mode signal  $M$ :

$$B'_i = B_i \oplus M \quad (7)$$

- When  $M = 0$ :  $B'_i = B_i$  (unchanged), and  $C_{in} = 0$ , so the circuit computes  $A + B$ .
- When  $M = 1$ :  $B'_i = \overline{B}_i$  (complemented), and  $C_{in} = 1$ , so the circuit computes  $A + \overline{B} + 1 = A - B$ .

The carry-in of the RCA is tied directly to  $M$ , providing the +1 needed for two's complement in subtraction mode. The unified expression for the circuit's output is:

$$S = A + (B \oplus M) + M \quad (8)$$

### 6.1.2 Overflow and Borrow Detection

For **addition** ( $M = 0$ ): the carry-out  $C_{out}$  indicates an unsigned overflow.

For **subtraction** ( $M = 1$ ): the borrow is the logical complement of  $C_{out}$ , i.e., Borrow =  $\overline{C_{out}}$ . When  $C_{out} = 0$ , the result is negative (a borrow occurred); when  $C_{out} = 1$ , the subtraction was exact (no borrow).

## 6.2 VDHL Implementation

```

1 library IEEE;
2 use IEEE.STD_LOGIC_1164.ALL;
3
4 entity subtractor_4bit is
5   Port (
6     A      : in  STD_LOGIC_VECTOR(3 downto 0);
7     B      : in  STD_LOGIC_VECTOR(3 downto 0);
8     DIFF   : out STD_LOGIC_VECTOR(3 downto 0);
9     Borrow : out STD_LOGIC
10    );
11 end subtractor_4bit;
12
13 architecture structural of subtractor_4bit is
14
15   component RCA_4bit
16     Port (
17       A      : in  STD_LOGIC_VECTOR(3 downto 0);
18       B      : in  STD_LOGIC_VECTOR(3 downto 0);
19       Cin   : in  STD_LOGIC;
20       SUM   : out STD_LOGIC_VECTOR(3 downto 0);
21       Cout  : out STD_LOGIC
22     );
23   end component;
24
25   signal B_comp : STD_LOGIC_VECTOR(3 downto 0);
26   signal Cout_int : STD_LOGIC;
27
28 begin
29
30   B_comp <= not B;
31
32   U1: RCA_4bit
33     port map(
34       A      => A,
35       B      => B_comp,
36       Cin   => '1',
37       SUM   => DIFF,
38       Cout  => Cout_int
39     );
40
41   Borrow <= not Cout_int;
42
43 end structural;

```

Listing 9: 4 bit subtractor using 4 bit RCA

## 6.3 Results



Figure 14: Simulation Results



Figure 15: Realized Schematic