## **Device Under Test:**

## **Arithmetic Logic Unit**

The device-under-test is a simple arithmetic logic unit (ALU) device with asynchronous reset. The device has two 8-bit inputs, alu\_a\_in and alu\_b\_in, for operands, and an 8-bit output, alu\_y\_out, for result. A complete list of the ports is showed below.

The opcodes of the ALU are listed below. The result of every operation is generated in one clock cycle.

| 0000 | Addition           | 1000 | Logical AND  |
|------|--------------------|------|--------------|
| 0001 | Subtraction        | 1001 | Logical OR   |
| 0010 | Multiplication     | 1010 | Logical XOR  |
| 0011 | Division           | 1011 | Logical NOR  |
| 0100 | Logical shift left | 1100 | Logical NAND |
| 0101 | Logic shift right  | 1101 | Logical XNOR |
| 0110 | Rotate left        | 1110 | A > B        |
| 0111 | Rotate right       | 1111 | A = B        |

In addition to conveying the carry resulting from an addition operation, the alu\_co\_out also indicates overflow for multiplication operation and underflow for division operation. In case of overflow, alu\_y\_out only gives the 8-bit value of LSB and alu\_co\_out is set to 1'b1. In case of underflow, alu\_y\_out is zero and alu\_co\_out is set to 1'b1. The result of divide-by-zero is simulator dependent, which is normally X.