### Jack Cwynar

### Lab 2 Testing/Simulation Screenshots

#### **Starting Sim**

```
VSIM 105> do Lab2_ALU_Cwynar.do
```

# Unsigned Add Tests (normal, overflow)

| <b>- /</b> /alu/operand1 | 32'h00AAAAAA | 00AAAAAA  | FFFFFFF   |
|--------------------------|--------------|-----------|-----------|
| 🛨 🥠 /alu/operand2        | 32'h00111111 | 00111111  | 00000001  |
|                          | 4'h0         | 0         |           |
| <b></b> /alu/result      | 32'h00000000 | (OOBBBBBB | (00000000 |
|                          | 4'h0         | 0         | 1         |

### Unsigned Sub Tests (normal, underflow)

| - /alu/operand1                 | 32'h00AAAAAA | FFFFFFF   |   | 00000001 |    |
|---------------------------------|--------------|-----------|---|----------|----|
| <b>≖</b> ⊸ /alu/operand2        | 32'h00111111 | 111111111 |   | 00000010 |    |
| <b>≖</b> ⊸ /alu/operation       | 4'h0         | 1         |   |          |    |
| <b>≖</b> – <b>♦</b> /alu/result | 32'h00000000 | \ EEEEEEE | Έ | FFFFFF   | -1 |
| <b>-</b> - <b></b> /alu/error   | 4'h0         | Ĭ,O       |   | 2        |    |

# 2's Complement Add (normal, overflow, underflow)

| <b>∓</b> -                        | 32'h00AAAAAA | FFFFFFF9  | 7FFFFFFF  | (80000000 |
|-----------------------------------|--------------|-----------|-----------|-----------|
| <b>⊥</b> - <b>◇</b> /alu/operand2 | 32'h00111111 | 00000007  | 00000001  | 80000000  |
|                                   | 4'h0         | 1,2       |           |           |
| <b>II</b> - <b>⟨</b> /alu/result  | 32'h00000000 | (00000000 | (80000000 | (00000000 |
|                                   | 4'h0         | Xo .      | 1         | 2         |

# 2's Complement Subtract (normal, overflow, underflow)

| - /alu/operand1                    | 32'h00AAAAAA | 03333333  | , 7FFFFFFF | 80000000     |
|------------------------------------|--------------|-----------|------------|--------------|
| <b>II</b> — <b>4</b> /alu/operand2 | 32'h00111111 | 02222222  | 80000000   | , TEFFEFFF , |
| <b>- 4</b> /alu/operation          | 4'h0         | 3         |            | X            |
| <b></b> /alu/result                | 32'h00000000 | (01111111 | (FFFFFFFF  | 00000001     |
| <b></b> /alu/error                 | 4'h0         | 0         | 1          | .2           |

# 2's Complement Multiply (normal, overflow, underflow)

| <b>- →</b> /alu/operand1 | 32'h00AAAAAA | 00000100  | 80000000  |           |
|--------------------------|--------------|-----------|-----------|-----------|
| - → /alu/operand2        | 32'h00111111 | 00000100  | 80000001  | 7FFFFFFE  |
| <u>→</u> /alu/operation  | 4'h0         | 4         |           |           |
|                          | 32'h00000000 | (00010000 | (80000000 | (00000000 |
|                          | 4'h0         | 0         | 1         | 2         |

# 2's Complement Divide (normal, underflow, divide by zero)

|                 | 32'h00AAAAAA | 00000064 | (80000000 | OFFFFFF   |
|-----------------|--------------|----------|-----------|-----------|
| - /alu/operand2 | 32'h00111111 | 00000002 | FFFFFFF   | (00000000 |
|                 | 4'h0         | 5        |           |           |
|                 | 32'h00000000 | 00000032 | (80000000 | (00000000 |
| +- /alu/error   | 4'h0         | 0        | 2         | 3         |

### Logical AND (1 AND 1, 0 AND 1, 0 AND 0)

| <b>- →</b> /alu/operand1        | 32'h00AAAAAA | 11111111 | 00000000  |          |
|---------------------------------|--------------|----------|-----------|----------|
|                                 | 32'h00111111 | 11111111 |           | 00000000 |
| <b>∓</b> -                      | 4'h0         | 6        |           |          |
| <b>≖</b> - <b>/</b> /alu/result | 32'h00000000 | 00000001 | (00000000 |          |
| +- /alu/error                   | 4'h0         | 0        |           |          |

#### Bitwise AND

|                     | 32'h00AAAAAA | AAAAAAA  | FFFFFFF  |
|---------------------|--------------|----------|----------|
| - ✓ /alu/operand2   | 32'h00111111 | 55555555 | X        |
|                     | 4'h0         | 7        | 1        |
| <b></b> /alu/result | 32'h00000000 | 00000000 | 55555555 |
| <b></b> /alu/error  | 4'h0         | 0        |          |

# Logical OR (1 OR 1, 0 OR 1)

| <b>∓</b> -        | 32'h00AAAAAA | AAA  | AAAA | FFFFFFF |    | 111111111 |    | 00000000 | , |
|-------------------|--------------|------|------|---------|----|-----------|----|----------|---|
| 📺 🥠 /alu/operand2 | 32'h00111111 | 5555 | 5555 |         |    | 11111111  |    |          | , |
|                   | 4'h0         | 7    |      |         |    | 8         |    |          |   |
| 💶 🔷 /alu/result   | 32'h00000000 | 0000 | 0000 | 555555  | 55 | (000000   | 01 |          |   |
|                   | 4'h0         | 0    |      |         |    |           |    |          |   |

### Bitwise OR

| AAAAAAA  |   | FFFFFFF |  |
|----------|---|---------|--|
| 55555555 |   |         |  |
| 9        |   |         |  |
| FFFFFF   | F |         |  |
|          |   |         |  |

# Logical NOT of operand1

# Bitwise NOT of operand1

|         |   | FFFFFFF |    |
|---------|---|---------|----|
|         |   |         |    |
| В       |   |         |    |
| (FFFFFF | F | (000000 | 00 |
|         |   |         |    |