Lab 4

## Part 1 - Adder-Subtracter

• 1)



- 2)
  So the Adder-Subtracter subtracts B from A (in other words, perform A
  B) and in part it does this by inverting the bits in B and adding it to A. However, to make it line up mathematically, you have to add 1 to A.
- 4)



|   | ۲ |
|---|---|
| • | Э |

| ,                       |                             |                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                     |
|-------------------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\operatorname{sign} A$ | $\operatorname{signB}$      | signSum                                                                                                                                                                                                                                         | overflow                                                                                                                                                                                                                                                                                                                            |
| 0                       | 0                           | 0                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                   |
| 0                       | 0                           | 1                                                                                                                                                                                                                                               | 1                                                                                                                                                                                                                                                                                                                                   |
| 0                       | 1                           | 0                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                   |
| 0                       | 1                           | 1                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                   |
| 1                       | 0                           | 0                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                   |
| 1                       | 0                           | 1                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                   |
| 1                       | 1                           | 0                                                                                                                                                                                                                                               | 1                                                                                                                                                                                                                                                                                                                                   |
| 1                       | 1                           | 1                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                                                                                                   |
|                         | signA 0 0 0 0 1 1 1 1 1 1 1 | signA         signB           0         0           0         0           0         1           0         1           1         0           1         0           1         1           1         1           1         1           1         1 | signA         signB         signSum           0         0         0           0         0         1           0         1         0           0         1         1           1         0         0           1         0         1           1         1         0           1         1         0           1         1         1 |

Part 2 - Two-Port Adder

- 5-bit two-port adder circuit:
- 1)
  The Xor gate essentially works like a bitwise inverter when Sub = 1 and like a gate that doesn't change anything when Sub = 0.
- 2)
  The wiring of the splitter near the Xor gate takes whatever the value of Sub is and replicates it over 5-bits. So if Sub = 1, then the splitter outputs 11111.
- 3)
  There are 5 control bits.
- 4)
  Two, Addition and subtraction. I'm not sure what Acc is doing here, its doesn't seem to change anything. I can't get the register to change to the input value at all.

• 5) By changing the Rmux control signal, one can choose one of the four input. The chosen signal will be added to the register value if  $\mathrm{Sub}=0$ , or subtracted from the register value if  $\mathrm{Sub}=1$ .