# Q1 RISC-V Warmup

5 Points

REMINDER: Gradescope does not have submission history for in-browser assignments such as lecture questions and homeworks. If you press "save answer" or "submit" after the deadline, the autograder *will* mark it as late and you'll get 0 points in the next TCP rerun. When you review old homework and lecture assignments, do not click any buttons otherwise you risk getting a zero on that assignment.

Answer the following questions about RISC-V. Don't be afraid to take some RISCs.

| RISC-V is a(n) _ language.     |                                                             |
|--------------------------------|-------------------------------------------------------------|
| ✓ machine code                 |                                                             |
| high-level                     |                                                             |
| <b>✓</b> assembly              |                                                             |
| C-like                         |                                                             |
| numerical                      |                                                             |
| None of the above              |                                                             |
|                                |                                                             |
| RISC-V follows the CPU         | J design strategy.                                          |
| CISC                           |                                                             |
| <b>▼</b> RISC                  |                                                             |
| SISC                           |                                                             |
| DISC                           |                                                             |
| None of the above              |                                                             |
|                                |                                                             |
| Which of the following is true | e of the RISC philosophy? Select all that apply.            |
| ✓ RISC stands for Reduce       | ed Instruction Set Computing                                |
| RISC encourages the in         | astruction set to be large and expansive                    |
| ✓ In RISC, a simple instru     | ction set helps to build faster hardware                    |
| ✓ In RISC, complicated or      | perations can be performed by composing simple instructions |
| None of the above              |                                                             |
|                                |                                                             |

Which of the following is False about a processor register?

| ✓ A register is a small location of RAM memory.                                                                      |       |
|----------------------------------------------------------------------------------------------------------------------|-------|
| ✓ A register has access speed comparable to a hard drive.                                                            |       |
| <b>▼</b> Registers comprise most of a computer's storage space.                                                      |       |
| A computer typically has thousands of registers.                                                                     |       |
| A register is a small amount of storage directly on the CPU.                                                         |       |
| None of the above                                                                                                    |       |
| RISC-V has# integer registers.                                                                                       |       |
| 32                                                                                                                   |       |
|                                                                                                                      |       |
| For the RISC-V we learn in this class, a register can hold# by                                                       | rtes. |
| 4                                                                                                                    |       |
|                                                                                                                      |       |
| Q2 Instruction Types                                                                                                 |       |
| 9 Points                                                                                                             |       |
|                                                                                                                      |       |
| Classify each of the following RISC-V instructions by type.                                                          |       |
|                                                                                                                      |       |
| Classify each of the following RISC-V instructions by type.  addit 0, a0, 1  R                                       |       |
| addi t0, a0, 1                                                                                                       |       |
| addi t0, a0, 1                                                                                                       |       |
| addi t0, a0, 1<br>○ R<br><b>⊙</b> I                                                                                  |       |
| addi t0, a0, 1  R  I  S                                                                                              |       |
| addi t0, a0, 1  R  I  S  S  S  S  S  S  S  S  S  S  S  S                                                             |       |
| addi t0, a0, 1  R  I  S  S  S  S  U                                                                                  |       |
| addi t0, a0, 1  R  I  S  S  U  U  U  W t0, 8(s2)                                                                     |       |
| addi t0, a0, 1  R  I  S  S  SB  U  U  U  U  W t0, 8(s2)  R  I                                                        |       |
| addi t0, a0, 1  R  I  S  S  SB  U  U  U  U  U  V  W  t0, 8(s2)  R  I  S  I                                           |       |
| addi t0, a0, 1  R  I  S  S  SB  U  U  U  W t0, 8(s2)  R  I  S  SB                                                    |       |
| addi t0, a0, 1  R  I  S  S  SB  U  U  U  U  V  W t0, 8(s2)  R  I  S  S  S  S  S  D  S  D  S  D  S  D  S  D  D        |       |
| addi t0, a0, 1  R  I  S  S  SB  U  U  U  W t0, 8(s2)  R  I  S  SB                                                    |       |
| addi t0, a0, 1  R  I  S  S  SB  U  U  U  U  V  W t0, 8(s2)  R  I  S  S  S  S  S  D  S  D  S  D  S  D  S  D  D        |       |
| addi t0, a0, 1  O R  I I O S O SB O UJ  w t0, 8(s2) O R  O I O S O SB O UJ  coeq a0, a1, loop O R                    |       |
| addi t0, a0, 1  O R  I I  O S  O SB  O U  O UJ  w t0, 8(s2)  O R  I I  O S  O SB  O U  O UJ                          |       |
| addi t0, a0, 1  R  I  S  S  SB  U  U  U  W t0, 8(s2)  R  I  S  SB  U  U  U  U  D  S  S  S  S  S  S  S  S  S  S  S  S |       |
| addi t0, a0, 1  R  I  S  S  SB  U  U  U  U  U  U  U  U  U  D  S  S  S  S  S  S  S  S  S  S  S  S                     |       |
| addi t0, a0, 1  R  I  S  S  SB  U  U  U  W t0, 8(s2)  R  I  S  SB  U  U  U  U  D  S  S  S  S  S  S  S  S  S  S  S  S |       |

| sb t0, 12(s2)    |  |  |
|------------------|--|--|
| <b>O</b> R       |  |  |
| 0                |  |  |
| <b>o</b> s       |  |  |
| O SB             |  |  |
| OU               |  |  |
| O M              |  |  |
|                  |  |  |
| jal x0, label    |  |  |
| <b>O</b> R       |  |  |
| ОІ               |  |  |
| <b>O</b> S       |  |  |
| O SB             |  |  |
| <b>O</b> U       |  |  |
| <b>⊙</b> N1      |  |  |
|                  |  |  |
| bne x10,x0,loop  |  |  |
| O R              |  |  |
| ОІ               |  |  |
| <b>O</b> S       |  |  |
| <b>⊙</b> SB      |  |  |
| OU               |  |  |
| O M              |  |  |
|                  |  |  |
| jalr ra, s0, 0   |  |  |
| O R              |  |  |
| <b>⊙</b> I       |  |  |
| <b>O</b> S       |  |  |
| O SB             |  |  |
| OU               |  |  |
| O M              |  |  |
|                  |  |  |
| slli x11, x10, 4 |  |  |
| O R              |  |  |
| <b>⊙</b> I       |  |  |
| O s              |  |  |
| O SB             |  |  |
| <b>O</b> U       |  |  |
| O m              |  |  |
|                  |  |  |
| sub t0, t1, zero |  |  |

| <b>⊙</b> R                                            |                     |
|-------------------------------------------------------|---------------------|
| O I                                                   |                     |
| <b>O</b> s                                            |                     |
| O SB                                                  |                     |
| ΟU                                                    |                     |
| O m                                                   |                     |
|                                                       |                     |
|                                                       |                     |
| 00 M; B;                                              |                     |
| Q3 Misc Risc 4 Points                                 |                     |
| What does the following do:                           |                     |
| et acce the following act                             |                     |
| xor x1, x1, x2                                        |                     |
| xor x2, x1, x2<br>xor x1, x1, x2                      |                     |
|                                                       |                     |
| Sets x1 to 0                                          |                     |
| Sets x1 to -1                                         |                     |
| _ Sets XI to -I                                       |                     |
| Sets x2 to 0                                          |                     |
| Sets x2 to -1                                         |                     |
| 36t3 AZ 10 -1                                         |                     |
| ✓ Swaps x1 and x2                                     |                     |
| Sets x1 == x2                                         |                     |
|                                                       |                     |
| Sets x1 and x2 to only bits which both do not share   |                     |
| Sets x1 and x2 to only bits which both share          |                     |
|                                                       |                     |
|                                                       |                     |
| Given the following code:                             |                     |
| # x10 holds 0x34FF                                    |                     |
| slli x <mark>12, x10, 0x10</mark>                     |                     |
| srli x12, x12, 0x08<br>and x12, x12, x10              |                     |
|                                                       |                     |
| What is in x12?                                       |                     |
| O 0x0                                                 |                     |
| <b>⊙</b> 0x3400                                       |                     |
| O 0x4F0                                               |                     |
| O 0xFF00                                              |                     |
| O 0x34FF                                              |                     |
| O None of the other options                           |                     |
| Given the following code sequence (assume x5 is somew | here on the stack): |
|                                                       |                     |
| addi x <mark>11</mark> , x0, -1261                    |                     |

```
1b x12, 1(x5)
1bu x13, 2(x5)
```

What is the 32bit value in x12? (Write your answer in hex)

```
0xFFFFFFB
```

What is the 32bit value in x13? (Write your answer in hex)

```
0x00000013
```

## Q4 Take a RISC for a WHILE

3 Points

C code:

```
1. int A[20];
2. int sum = 0;
3. int i = 19;
4. while (i >= 0) {
5.    sum += A[i];
6.    i --;
7. }
```

Corresponds to the following RISC-V assembly code:

```
1. add x9, x0, x0
2. add x10, x0, 19
3. add x11, x0, x0
4. Loop:
5. bxx x10, x0, Done
6. lw x12, 0(x11)
7. addi x10, x10, value1
8. addi x11, x11, value2
9. add x9, x9, x12
10. j Loop
11. Done:
```

Q4.1 For the while loop to operate correctly, the following needs to be true.

3 Points

bxx (on line 5) is

- O bgt
- blt
- O bleu
- O bgtu
- O bltu
- O beq
- O bne
- O bge
- O bgeu

value1 (on line 7) is

| O -4                                                                                                                                                 |                                                                                                                           |
|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| O -2                                                                                                                                                 |                                                                                                                           |
| <b>⊙</b> -1                                                                                                                                          |                                                                                                                           |
| O 1                                                                                                                                                  |                                                                                                                           |
| O 2                                                                                                                                                  |                                                                                                                           |
| O 4                                                                                                                                                  |                                                                                                                           |
| <b>O</b> 16                                                                                                                                          |                                                                                                                           |
| value2 (on line 8) i                                                                                                                                 | S                                                                                                                         |
| O -4                                                                                                                                                 |                                                                                                                           |
| O -2                                                                                                                                                 |                                                                                                                           |
| O -1                                                                                                                                                 |                                                                                                                           |
| O 1                                                                                                                                                  |                                                                                                                           |
| O 2                                                                                                                                                  |                                                                                                                           |
| <b>O</b> 4                                                                                                                                           |                                                                                                                           |
| O 16                                                                                                                                                 |                                                                                                                           |
| Q5 RISC-V → 5 Points                                                                                                                                 | Machine Code                                                                                                              |
| Convert anch of the                                                                                                                                  | A III A BIOGRAPH A A A A A A A A A A A A A A A A A A                                                                      |
| Format your answe                                                                                                                                    | e following RISC-V instructions to machine code.  or as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf |
| Format your answe<br>just sucks). Leave a                                                                                                            | r as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf                                                    |
| Format your answe<br>just sucks). Leave a<br>Refer to your RISC-                                                                                     | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answe<br>just sucks). Leave a<br>Refer to your RISC-<br><b>Q5.1</b>                                                                      | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answe just sucks). Leave a Refer to your RISC-Q5.1                                                                                       | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answer just sucks). Leave at Refer to your RISC-Q5.1 1 Point Convert:  sub s0, t0, t2                                                    | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answe just sucks). Leave a Refer to your RISC-Q5.1 1 Point Convert:                                                                      | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answer just sucks). Leave at Refer to your RISC-Q5.1 1 Point Convert:  sub s0, t0, t2                                                    | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answer just sucks). Leave at Refer to your RISC-Q5.1 1 Point Convert:  sub s0, t0, t2                                                    | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answer just sucks). Leave at Refer to your RISC-Q5.1 1 Point Convert:  sub s0, t0, t2  0x40728433                                        | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answer just sucks). Leave at Refer to your RISC-Q5.1 1 Point Convert:  sub s0, t0, t2  0x40728433                                        | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answer just sucks). Leave at Refer to your RISC-Q5.1 1 Point Convert:  sub s0, t0, t2  Q5.2 1 Point                                      | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answer just sucks). Leave at Refer to your RISC-Q5.1 1 Point Convert:  sub s0, t0, t2  0x40728433  Q5.2 1 Point Convert:  slli a0, t0, 3 | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answer just sucks). Leave at Refer to your RISC-Q5.1 1 Point Convert:  sub s0, t0, t2  0x40728433  Q5.2 1 Point Convert:                 | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answer just sucks). Leave at Refer to your RISC-Q5.1 1 Point Convert:  sub s0, t0, t2  0x40728433  Q5.2 1 Point Convert:  slli a0, t0, 3 | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answer just sucks). Leave at Refer to your RISC-Q5.1 1 Point Convert:  sub s0, t0, t2  0x40728433  Q5.2 1 Point Convert:  slli a0, t0, 3 | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |
| Format your answer just sucks). Leave at Refer to your RISC-Q5.1 1 Point Convert:  sub s0, t0, t2  0x40728433  Q5.2 1 Point Convert:  slli a0, t0, 3 | er as 32-bit hexadecimal number, e.g. 0xABADCAFE or 0xabadcafe (the caf<br>any unused bits as 0.                          |

Convert:

```
sw t0, 4(s0)

0x00542223
```

#### Q5.4

1 Point

Convert:

```
jal ra, fib
```

Assume  $PC = 0 \mathrm{x} 00400014$ , and fib is located at  $0 \mathrm{x} 00400028$ .

```
0x014000EF
```

### Q5.5

1 Point

Convert:

```
beq t3, t5, NEXT
```

Assume PC = 0x0040011C, and NEXT is located at 0x0040010C.

```
0xFFEE08E3
```

## Q6 Machine Code → RISC-V Instructions

4 Points

Convert each of the following 32-bit machine code instructions into a RISC-V instruction.

Formatting: use register names in your final answer, e.g. a0 instead of x10. The only exception is the zero register, which you should refer to as "x0" instead of "zero".

Example Format: "add t0, a0, x0" or "lw x0, 61(x5)"

For all questions, you can assume

 $PC = 0 \times 00400010$ 

and we have the following labels:

func1: 0x00400000

func2: 0x00400018

NOTE: Until Gradescope updates its checking, please make sure to follow the formatting above.

## Q6.1

1 Point

0x00598523

sb t0, 10(s3)

#### Q6.2

1 Point

#### 0x00b542b3

```
xor t0, a0, a1
```

### Q6.3

1 Point

#### 0x00728463

```
beq t0, t2, func2
```

#### Q6.4

1 Point

#### 0xFF1FF06F

```
jal x0, func1
```

## Q7 C ↔ RISC-V

4 Points

In each of the following questions, you'll be given either C or RISC-V code, and asked to examine a translation into RISC-V or C, respectively.

The translation may have a bug or logic error. Your task is to identify the line number containing the error, or enter "none" if no problem exists.

Given this C code:

```
if (x < 5) {
    goto label;
}</pre>
```

 $\label{thm:local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local$ 

```
/* x = s0 */
1. addi t0 x0 5
2. slt t1 s0 t0
3. bne t1 x0 label
```

| , |
|---|
|   |

Line 2

Line 3



Given this C code:

```
int x[2] = \{1, 2\}
int y = x[0] + x[1] + 2;
```

identify the buggy line in the following RISC-V translation or enter "none", if there is none:

```
/* x = s0, y = s1 */
1. lw t0 0(s0)
2. lw t1 1(s0)
3. add s1,t0,t1
4. addi s1,s1,2
```

Line 1



Line 3



None

Given this RISC-V code:

```
sub s1 s2 s1
add s0 s0 s2
j end
```

identify the buggy line in the following C translation or enter "none", if there is none. (Hint: register order matters):

```
/* x = s0, y = s1, z = s2 */
1. y -= z;
2. x += z;
3. goto end;
```

✓ Line 1

Line 2

Line 3

None

Given this RISC-V code:

```
slli s0 s0 4
xori s0 s0 3
sw s0 12(s1)
```

identify the buggy line in the following C translation or enter "none", if there is none:

```
1. int x; // x = s0

2. int y[5]; // y = s1

3. x *= math.pow(2, 4);

4. x ^= 3;

5. y[4] = x;
```

| Line 1                                                                                                                            |                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|
| Line 2                                                                                                                            |                                                                        |
| Line 3                                                                                                                            |                                                                        |
| Line 4                                                                                                                            |                                                                        |
| ✓ Line 5                                                                                                                          |                                                                        |
| None                                                                                                                              |                                                                        |
|                                                                                                                                   |                                                                        |
|                                                                                                                                   |                                                                        |
| <b>Q8</b> RISC-V Green<br><sup>6 Points</sup>                                                                                     | Sheet questions                                                        |
| Which of the following is the                                                                                                     | he correct ordering of fields for R-type instruction from bits 31 to 0 |
| ✓ funct7, rs2, rs1, funct3                                                                                                        | 3, rd, opcode                                                          |
| opcode, rs2, rs1, func                                                                                                            | ct3, rd, funct7                                                        |
| funct7, rd, rs1, funct3,                                                                                                          | , rs2, opcode                                                          |
|                                                                                                                                   |                                                                        |
| funct7, rs1, rs2, funct3                                                                                                          | 3, rd, opcode                                                          |
|                                                                                                                                   | 3, rd, opcode                                                          |
| ☐ funct7, rs1, rs2, funct3☐ None of the above                                                                                     | 3, rd, opcode                                                          |
| None of the above                                                                                                                 |                                                                        |
| None of the above  Which of the following RIS                                                                                     | SC-V instructions is actually a pseudo-instruction?                    |
| None of the above  Which of the following RIS                                                                                     |                                                                        |
| None of the above  Which of the following RIS  ✓ li  mulh                                                                         |                                                                        |
| None of the above  Which of the following RIS                                                                                     |                                                                        |
| None of the above  Which of the following RIS  ✓ li  mulh                                                                         |                                                                        |
| None of the above  Which of the following RIS  ✓ li  mulh addi                                                                    |                                                                        |
| None of the above  Which of the following RIS  ✓ li  mulh addi ori                                                                |                                                                        |
| None of the above  Which of the following RIS  ✓ li  mulh addi ori  None of the above                                             |                                                                        |
| None of the above  Which of the following RIS  ✓ li  mulh addi ori  None of the above                                             | SC-V instructions is actually a pseudo-instruction?                    |
| None of the above  Which of the following RIS  ✓ li  mulh addi ori None of the above                                              | SC-V instructions is actually a pseudo-instruction?                    |
| None of the above  Which of the following RIS  ✓ li  mulh addi ori None of the above  Which of the following field rs1            | SC-V instructions is actually a pseudo-instruction?                    |
| None of the above  Which of the following RIS  ✓ li  mulh addi ori None of the above  Which of the following field rs1  ✓ rs2     | SC-V instructions is actually a pseudo-instruction?                    |
| None of the above  Which of the following RIS  ✓ li  mulh addi ori None of the above  Which of the following field rs1  ✓ rs2  rd | SC-V instructions is actually a pseudo-instruction?                    |

Which of the following registers are preserved across a call? (i.e. should have the same value before and after you make a RISC-V function call)

|            | aO                         |                  |             |               |                |              |
|------------|----------------------------|------------------|-------------|---------------|----------------|--------------|
| <b>✓</b> : | s0                         |                  |             |               |                |              |
| 1          | <u>t</u> 4                 |                  |             |               |                |              |
| •          | x19                        |                  |             |               |                |              |
| •          | x9                         |                  |             |               |                |              |
|            | x31                        |                  |             |               |                |              |
|            | None of the above          |                  |             |               |                |              |
|            |                            |                  |             |               |                |              |
| /hich      | n of the following RISC-V  | instructions i   | ncludes a c | onditional s  | tatement in it | s operation? |
| <b>✓</b>   | beq                        |                  |             |               |                |              |
| •          | slt                        |                  |             |               |                |              |
|            | lui                        |                  |             |               |                |              |
| <b>✓</b> ( | sltu                       |                  |             |               |                |              |
|            | None of the above          |                  |             |               |                |              |
|            |                            |                  |             |               |                |              |
| /hich      | n of the following orderin | ig is correct fo | or memory a | allocation st | arting from 0  | ×0?          |
|            | Text/Code, Static Data, S  | tack, Heap       |             |               |                |              |
|            | Static Data, Text/Code, S  | tack, Heap       |             |               |                |              |
| · -        | Text/Code, Static Data, F  | leap, Stack      |             |               |                |              |
|            | None of the above          |                  |             |               |                |              |
|            |                            |                  |             |               |                |              |
|            |                            |                  |             |               |                |              |
|            |                            |                  |             |               |                |              |



| Misc Risc                                                                    | <b>4</b> / 4 pts |
|------------------------------------------------------------------------------|------------------|
|                                                                              |                  |
| QUESTION 4  Take a RISC for a WHILE                                          | <b>3</b> / 3 pts |
| 4.1 For the while loop to operate correctly, the following needs to be true. | 3/3 pts          |
|                                                                              |                  |
| QUESTION 5                                                                   | - /              |
| RISC-V → Machine Code                                                        | <b>5</b> / 5 pts |
| 5.1 (no title)                                                               | <b>1</b> /1 pt   |
| 5.2 (no title)                                                               | <b>1</b> / 1 pt  |
| 5.3 (no title)                                                               | <b>1</b> / 1 pt  |
| 5.4 (no title)                                                               | <b>1</b> / 1 pt  |
| 5.5 (no title)                                                               | <b>1</b> / 1 pt  |
| QUESTION 6                                                                   |                  |
| Machine Code → RISC-V Instructions                                           | <b>4</b> / 4 pts |
| 6.1 (no title)                                                               | <b>1</b> / 1 pt  |
| 6.2 (no title)                                                               | <b>1</b> / 1 pt  |
| 6.3 (no title)                                                               | <b>1</b> / 1 pt  |
| 6.4 (no title)                                                               | <b>1</b> / 1 pt  |
| QUESTION 7                                                                   |                  |
| $C \leftrightarrow RISC-V$                                                   | <b>4</b> / 4 pts |
| QUESTION 8                                                                   |                  |
| RISC-V Green Sheet questions                                                 | <b>6</b> / 6 pts |