## Question 2 - Instruction Set 2 - x295+

## B. Compiling and assembling a C program using our x295+ instruction set

Table 1

| C program              | x295+ assembly program | x295+ machine code             |
|------------------------|------------------------|--------------------------------|
|                        |                        | program                        |
| z = (x + y) * (x - y); | LOAD x, r0             | 1010 000 XXX XXXXXX            |
|                        |                        | 0000 <src 12="" bits=""></src> |
|                        |                        |                                |
|                        | LOAD y, r1             | 1010 001 XXX XXXXXX            |
|                        | - 17                   | 0000 <src 12="" bits=""></src> |
|                        | ADD r0, r1, r2         |                                |
|                        |                        | 0001 010 000 001 XXX           |
|                        | SUB r0, r1, r3         |                                |
|                        | 30010,11,13            | 0010 011 000 001 XXX           |
|                        | NALII x2 x2 x4         |                                |
|                        | MUL r2, r3, r4         | 0011 100 010 011 XXX           |
|                        |                        |                                |
|                        | STORE r4, z            | 1011 XXX 100 XXXXXX            |
|                        |                        | A. <src 12="" bits=""></src>   |

## C. Evaluating our x295+ instruction set using Memory Traffic criteria

Table 2

| x295+ program  (1 assembly instruction/ machine code instruction per row) | Fetch  (number of word size memory accesses) + Provide an explanation explaining the count | Decode/Execute  (number of word size memory accesses) + Provide an explanation explaining the count |
|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| Assembly instruction:                                                     | Count: 2                                                                                   | Count: 1                                                                                            |
| LOAD x, r0                                                                | <b>Explanation:</b> LOAD format is made of 32 bits (2 words)                               | <b>Explanation:</b> LOAD instruction accesses memory once, example:                                 |
| Machine code instruction:                                                 |                                                                                            |                                                                                                     |
| 1010 000 XXX XXXXXX                                                       |                                                                                            | - LOAD a, rC = rC <- M[a]                                                                           |
| 0000 <src 12="" bits=""></src>                                            |                                                                                            |                                                                                                     |
| Assembly instruction:  LOAD y, r1  Machine code instruction:              | <b>Explanation:</b> LOAD format is made of 32 bits (2 words)                               | <b>Explanation:</b> LOAD instruction accesses memory once, example:                                 |
| 1010 001 XXX XXXXXX<br>0000 <src 12="" bits=""></src>                     |                                                                                            | - LOAD a, rC = rC <- M[a]                                                                           |
| Assembly instruction:                                                     | Count: 1                                                                                   | Count: 0                                                                                            |
| ADD r0, r1, r2                                                            | <b>Explanation:</b> ADD format is made of 16 bits (1 word)                                 | <b>Explanation:</b> ADD instruction does not access memory                                          |
| Machine code instruction:                                                 |                                                                                            |                                                                                                     |
| 0001 010 000 001 XXX                                                      |                                                                                            |                                                                                                     |
| Assembly instruction:                                                     | Count: 1                                                                                   | Count: 0                                                                                            |
| SUB r0, r1, r3                                                            | <b>Explanation:</b> SUB format is made of 16 bits (1 word)                                 | <b>Explanation:</b> SUB instruction does not access memory                                          |
| Machine code instruction:                                                 |                                                                                            |                                                                                                     |

| 0010 011 000 001 XXX           |                                                               |                                                            |
|--------------------------------|---------------------------------------------------------------|------------------------------------------------------------|
| Assembly instruction:          | Count: 1                                                      | Count: 0                                                   |
| MUL r2, r3, r4                 | <b>Explanation:</b> MUL format is made of 16 bits (1 word)    | <b>Explanation:</b> MUL instruction does not access memory |
| Machine code instruction:      |                                                               |                                                            |
| 0011 100 010 011 XXX           |                                                               |                                                            |
| Assembly instruction:          | Count: 2                                                      | Count: 1                                                   |
| STORE r4, z                    | <b>Explanation:</b> STORE format is made of 32 bits (2 words) | <b>Explanation:</b> STORE instruction accesses memory      |
| Machine code instruction:      |                                                               | once, example:                                             |
| 1011 XXX 100 XXXXXX            |                                                               | - STORE rA, c = M[c] <- rA                                 |
| 0000 <src 12="" bits=""></src> |                                                               |                                                            |
| Grand Total: 12                | Total: 9                                                      | Total: 3                                                   |

Once completed, submit it on Crowdmark as your answer to Question 2.