# COL216 Assignment 2

Stage 6 report

### Aniruddha Deb 2020CS10869

# **Summary**

This stage implemented the PMConnect module, which acts as a memory controller for reading/writing. We also implemented post-indexed addressing for memory, which required a slight modification of the datapath.

The concept of storing bytes rather than words brings into question endianness. The memory that we implemented is big endian, meaning that the least significant byte is stored in the most significant position, similar to the following structure:

The big endian choice for memory was made early in the design stage, as it allowed us to initialize memory as an array of words, and easily load words out of memory. The code in mem.vhdl reflects this.

This stage implemented and tested all the types of operators for data transfer instructions, as well as implementing the necessary logic in the control unit decoding the instructions for loading and storing signed bytes/words.

#### **File Structure**

```
2020CS10869.zip
 Assignment.png
  Makefile
  — alu.vhdl
  — commons.vhdl
  – cpu.vhdl
  cpu_multicycle.vhdl
  — dt tb.vhdl
 — idx_tb.vhdl
  - logs
    ├─ cpu_synth_log.txt

    pmconnect_synth_log.txt

 — mem.vhdl
  mytypes.vhdl
 — pmconnect.vhdl
 predicator.vhdl
 — regfile.vhdl
  report.pdf
  - run.do
  shifter.vhdl
```

# **Program Details**

- pmconnect.vhdl implements the PMConnect module
- dt\_tb.vhdl testbench for data transfer instructions (instructions defined in test\_progs/dt\_test.s)
- idx\_tb.vhdl testbench for data transfer instructions (instructions defined in test\_progs/idx\_test.s)

Other program details are the same as previous stages.

# **Testing**

#### **DT** Testing

```
@ dt_test.s
                           @ testing all types of DT instructions
                               .text
0 => X"E3A00078"
                                mov r0, #120 @ byte address 30
1 => X"E3A010AD"
                                mov r1, #0xAD
2 => X"E3811CDE"
                                orr r1, #0xDE00
3 => X"E38118FE"
                                orr r1, #0xFE0000
4 => X"E38114CA"
                                orr r1, #0xCA000000 @ r1 now stores 0xCAFEDEAD
5 => X"E5801000"
                                str r1, [r0]
6 => X"E1C010B4"
                                strh r1, [r0,#4]
7 => X"E1C010B6"
                                strh r1, [r0,#6]
                                strb r1, [r0,#8]
8 => X"E5C01008"
                                strb r1, [r0,#9]
9 => X"E5C01009"
10 => X"E5C0100A"
                                strb r1, [r0,#10]
11 => X"E5C0100B"
                                strb r1, [r0,#11]
12 => X"E5902000"
                                ldr r2, [r0]
                                1drh r2, [r0]
13 => X"E1D020B0"
```

```
14 => X"E1D020F0"
                                ldrsh r2, [r0]
15 => X"E1D020B2"
                                ldrh r2, [r0,#2]
16 => X"E1D020F2"
                                ldrsh r2, [r0,#2]
17 => X"E5D02000"
                                ldrb r2, [r0]
18 => X"E1D020D0"
                                ldrsb r2, [r0]
19 => X"E5D02001"
                                ldrb r2, [r0,#1]
20 => X"E1D020D1"
                                ldrsb r2, [r0,#1]
21 => X"E5D02002"
                                ldrb r2, [r0,#2]
22 => X"E1D020D2"
                                ldrsb r2, [r0,#2]
23 => X"E5D02003"
                                ldrb r2, [r0,#3]
24 => X"E1D020D3"
                                ldrsb r2, [r0,#3]
                                .end
```





#### Index testing (post/pre addressing)

```
@ idx_test.s
                           @ tests preindexing, postindexing, and writeback
                           @ the following types of data transfer operators exist in ARM
                           @ 1. [<Rn>, #+/-<offset_12>]
                           @ 2. [<Rn>, +/-<Rm>]
                           @ 3. [<Rn>, +/-<Rm>, <shift> #<shift_imm>]
                           @ 4. [<Rn>, #+/-<offset_12>]!
                           @ 5. [<Rn>, +/-<Rm>]!
                           @ 6. [<Rn>, +/-<Rm>, <shift> #<shift_imm>]!
                           @ 7. [<Rn>], #+/-<offset_12>
                           @ 8. [<Rn>], +/-<Rm>
                           @ 9. [<Rn>], +/-<Rm>, <shift> #<shift_imm>
                           @ 1-3 were tested previously, here we test 4-9
                                .text
0 => X"E3A00060"
                               mov r0, #96 @ byte address 24
1 => X"E3A010AD"
                               mov r1, #0xAD
2 => X"E3811CDE"
                               orr r1, #0xDE00
                               orr r1, #0xFE0000
3 => X"E38118FE"
4 => X"E38114CA"
                               orr r1, #0xCA000000
5 => X"E3A02004"
                               mov r2, #4
6 => X"E5A01004"
                               str r1, [r0, #4]! @ store at 25, r0 = 100
                               str r1, [r0, r2]! @ store at 26, r0 = 104
7 => X"E7A01002"
8 => X"E7201082"
                               str r1, [r0, -r2, lsl #1]! @ store at 24, r0 = 96 again
9 => X"E280000C"
                               add r0, #12
10 => X"E4801004"
                               str r1, [r0], #4 @ store at 27, r0 = 108
11 => X"E6801082"
                               str r1, [r0], r2, lsl #1 @ store at 28, r0 = 116
                                .end
```



## **Synthesis**

#### **CPU**

The CPU entity with the PMConnect module successfully synthesized using Mentor Precision on EDAPlayground. The logs are in cpu\_synth\_log.txt in logs. Note that the CPU had only one IO pin, and that was synthesized. Mentor did not synthesize any of the other entities declared and port mapped inside the CPU (ALU, register file, program and data memory etc), although it did the syntax/synthesis checks for all the entities

```
# Info: ***********************************
# Info: Device Utilization for 7A100TCSG324
# Info: ***********************************
# Info: Resource
                             Used Avail Utilization
# Info: -----
# Info: IOs
                                  210
                                          0.48%
# Info: Global Buffers
                              0
                                  32
                                          0.00%
# Info: LUTs
                                  63400 0.00%
                              0
# Info: CLB Slices
                             0
                                   15850
                                         0.00%
# Info: Dffs or Latches
                             0
                                  126800 0.00%
                                  135
# Info: Block RAMs
                              0
                                          0.00%
# Info: DSP48E1s
                              0
                                   240
                                          0.00%
# Info: -----
# Info: **********************************
# Info: Library: work
                 Cell: cpu
                          View: cpu_arch
# Info: ****************************
# Info: Number of ports :
# Info: Number of nets:
# Info: Number of instances:
                                      0
# Info: Number of references to this view :
                                      0
# Info: Total accumulated area :
# Info: Number of gates :
# Info: Number of accumulated instances :
                                      0
# Info: ****************
# Info: IO Register Mapping Report
# Info: ****************
# Info: Design: work.cpu.cpu_arch
# Info: +-----+-----+
# Info: | Port | Direction | INFF | OUTFF | TRIFF |
# Info: +-----+-----+
# Info: | clock | Input
                    # Info: +-----+-----+
# Info: Total registers mapped: 0
```

# **PMConnect**

The PMConnect module was also separately designed, synthesized and tested.

| # | Info:                  | **************************************  |                |                   |                |                                        |  |  |  |  |  |
|---|------------------------|-----------------------------------------|----------------|-------------------|----------------|----------------------------------------|--|--|--|--|--|
|   |                        | **************************************  |                |                   |                | t::::::::::::::::::::::::::::::::::::: |  |  |  |  |  |
|   | <pre>Info: Info:</pre> |                                         |                |                   |                | <br>58.10%                             |  |  |  |  |  |
|   |                        | Global Buffers                          |                |                   | 32             | 0.00%                                  |  |  |  |  |  |
|   | Info:                  |                                         |                |                   | 63400          | 0.11%                                  |  |  |  |  |  |
|   |                        | CLB Slices                              |                |                   | 15850          | 0.05%                                  |  |  |  |  |  |
| # | Info:                  | Dffs or Latches                         |                | 0                 | 126800         | 0.00%                                  |  |  |  |  |  |
| # | Info:                  | Block RAMs                              |                | 0                 | 135            | 0.00%                                  |  |  |  |  |  |
|   |                        | DSP48E1s                                |                | 0                 | 240            | 0.00%                                  |  |  |  |  |  |
|   | Info:                  | ***********                             |                |                   |                |                                        |  |  |  |  |  |
|   |                        | Library: work Cell                      |                |                   |                |                                        |  |  |  |  |  |
| # | Info:                  | *********                               | :. piliconnect | V 10W .           | *******        | _a.c<br>k******                        |  |  |  |  |  |
|   |                        | Number of ports :                       |                |                   | 143            |                                        |  |  |  |  |  |
|   |                        | Number of nets :                        |                |                   | 301            |                                        |  |  |  |  |  |
|   |                        | Number of instances                     | -              |                   | 227            |                                        |  |  |  |  |  |
|   |                        | Number of references                    |                | ew :              | 0              |                                        |  |  |  |  |  |
|   |                        | Total accumulated are                   | ea:            |                   | 71             |                                        |  |  |  |  |  |
|   |                        | Number of LUTs :<br>Number of Primitive | LUTe           |                   | 71<br>85       |                                        |  |  |  |  |  |
|   | Info:                  |                                         |                | ı ·               | 28             |                                        |  |  |  |  |  |
|   | Info:                  |                                         |                |                   |                |                                        |  |  |  |  |  |
|   |                        | **************************************  |                |                   |                |                                        |  |  |  |  |  |
| # | Info:                  | IO Register Mapping                     | Report         |                   |                |                                        |  |  |  |  |  |
|   |                        | ******                                  |                |                   |                |                                        |  |  |  |  |  |
| # | Into:                  | Design: work.pmconnect                  | ct.pmconnect_  | _arc<br>          |                |                                        |  |  |  |  |  |
|   |                        |                                         | Direction      |                   | OUTFF          | TRIFF                                  |  |  |  |  |  |
| # | Info:                  | ++                                      |                |                   | -+             | ++                                     |  |  |  |  |  |
| # | Info:                  | Rout(31)  <br>+                         | Input          |                   |                | !!!!                                   |  |  |  |  |  |
| # | <pre>Info:</pre>       |                                         | Input          |                   | - <del>+</del> |                                        |  |  |  |  |  |
|   |                        | Rout(29)                                | Input          | +<br>             | -+<br>         | ++<br>                                 |  |  |  |  |  |
|   |                        | +                                       | Input          | +<br>             | - <b>+</b>     | <del>+</del> +                         |  |  |  |  |  |
| # | Info:                  | +                                       |                |                   | - <del>+</del> |                                        |  |  |  |  |  |
|   |                        | Rout(27)                                | Input          | <br>              | <br>- <b>+</b> | <br><b>+</b> +                         |  |  |  |  |  |
|   | <pre>Info: Info:</pre> |                                         | Input          |                   | <u> </u>       | ! !                                    |  |  |  |  |  |
| # | Info:                  | Rout(25)                                | Input          |                   | - <del>+</del> |                                        |  |  |  |  |  |
| # | Info:<br>Info:         | +                                       | Input          | +<br>             | -+<br>         | <del>+</del> +<br>                     |  |  |  |  |  |
|   | Info:                  | +                                       |                |                   | -+             |                                        |  |  |  |  |  |
|   | <pre>Info: Info:</pre> | Rout(23)                                | Input          |                   | <br>- <b>+</b> | <br>++                                 |  |  |  |  |  |
| # | Info:<br>Info:         | Rout(22)                                | Input          |                   | İ              | į                                      |  |  |  |  |  |
| # | Info:                  | Rout(21)                                | Input          |                   | - <del>+</del> | <br>                                   |  |  |  |  |  |
| # | Info:<br>Info:         | +                                       | Input          | +<br>             | - <b>+</b><br> | +++<br>                                |  |  |  |  |  |
|   | <pre>Info: Info:</pre> | +                                       | Input          | -<br>             | - <del>†</del> | <del>-</del> <del>-</del>              |  |  |  |  |  |
| # | Info:                  | +                                       |                | <br><del> </del>  | <br>- <b>+</b> | ·+                                     |  |  |  |  |  |
|   | <pre>Info: Info:</pre> | Rout(18)  <br>+                         | Input          | <del> </del><br>+ | <br>-+         | <br><b>+</b> +                         |  |  |  |  |  |
| # | Info:                  | Rout(17)                                | Input          |                   | 1              | 1 1                                    |  |  |  |  |  |

| # Info:                        | <b>.</b>                |                   |
|--------------------------------|-------------------------|-------------------|
| # Info:                        | Rout(16)                | Input             |
| # Info: •<br># Info:           | +<br>  Rout(15)         |                   |
| # Info:                        | +                       |                   |
| <pre># Info:<br/># Info:</pre> | Rout(14)<br>+           | Input             |
| # Info:                        | Rout(13)                | Input             |
| <pre># Info: * # Info: *</pre> | +<br>  Rout(12)         | +++++<br>Input    |
| # Info:                        | +                       | +                 |
| # Info:<br># Info:             | Rout(11)<br>+           | Input             |
| # Info:<br># Info:             | Rout(10)                | Input             |
| # Info:                        | Rout(9)                 | Input             |
| # Info: •<br># Info:           | +<br>  Rout(8)          |                   |
| # Info:                        | +                       |                   |
| # Info:<br># Info:             | Rout(7)<br><del>+</del> | Input        <br> |
| # Info:<br># Info:             | Rout(6)                 | Input             |
| # Info:                        | Rout(5)                 | Input             |
| # Info:<br># Info:             | +<br>  Rout(4)          |                   |
| # Info:                        | +                       | +                 |
| # Info:<br># Info:             | Rout(3)<br>+            | Input             |
| <pre># Info: # Info:</pre>     | Rout(2)                 | Input             |
| # Info:                        | Rout(1)                 | Input             |
| <pre># Info: * # Info:</pre>   | +<br>  Rout(0)          | +++++<br>Input    |
| # Info:<br># Info:             | +<br>  Rin(31)          |                   |
| # Info:                        | +                       |                   |
| # Info:<br># Info:             | Rin(30)<br>+            | Output            |
| # Info:                        | Rin(29)                 | Output            |
| # Info:<br># Info:             | Rin(28)                 | Output            |
| # Info: ·<br># Info:           | +<br>  Rin(27)          | +++++<br>Output   |
| # Info:                        | +                       | +                 |
| <pre># Info: # Info:</pre>     | Rin(26)<br>+            | Output            |
| <pre># Info: # Info:</pre>     | Rin(25)                 | Output            |
| # Info:                        | Rin(24)                 | Output            |
| # Info: ·<br># Info:           | +<br>  Rin(23)          | ++++++            |
| # Info:                        | +                       |                   |
| # Info:                        | Rin(22)<br>+            | Output            |
| <pre># Info:</pre>             | Rin(21)<br>+            | Output            |
| # Info:                        | Rin(20)                 | Output            |
| # Info:<br># Info:             | +<br>  Rin(19)          | +++++<br>Output   |
| <pre># Info: * # Info:</pre>   | +<br>  Rin(18)          |                   |
| # Info:                        | +                       | +                 |
| <pre># Info:<br/># Info:</pre> | Rin(17)<br>+            | Output            |
| # Info:                        | Rin(16)                 | Output            |

| # Info: +                           | <del></del>    | +             | +            | +                      | +                                 | +                |
|-------------------------------------|----------------|---------------|--------------|------------------------|-----------------------------------|------------------|
| # Info:  <br># Info:                | Rin(15)        | Output        | 1            | <u> </u>               |                                   |                  |
| # Info:                             | Rin(14)        | Output        | +            | <del>, -</del>         |                                   |                  |
| # Info: +                           | Rin(13)        | +<br>  Output | +<br> <br>!  | +<br> <br>!            | <del>+</del><br> <br>!            | <del> </del><br> |
| # Info: +                           | Rin(12)        | +<br>  Output | +<br> <br>!  | +<br> <br>:            | <del>+</del><br>!                 | <del> </del><br> |
| # Info: +                           | Rin(11)        | +<br>  Output | +<br>!       | +<br> <br>:            | <del>+</del><br>!                 | +<br>            |
| # Info: + Info: +                   | Rin(10)        | +<br>  Output | <del>+</del> | <del>-</del>           | <del>+</del>                      | <del> </del>     |
| # Info:  <br># Info:                | Rin(9)         | +<br>  Output | <del>+</del> | <del>-</del>           | <del>-</del>                      |                  |
| # Info: + Info: +                   | Rin(8)         | +<br>  Output | <del>+</del> | <del>-</del>           | <del>-</del>                      |                  |
| # Info: + Info: +                   | Rin(7)         | +<br>  Output | +            | <del>-</del>           | <del>-</del>                      |                  |
| # Info: +<br># Info:  <br># Info: + | Rin(6)         | +<br>  Output | +<br> <br>+  | <del>-</del><br> <br>  | <del>-</del>                      |                  |
| # Info:                             | Rin(5)         | +<br>  Output | +            | <del>-</del>           | <del>-</del>                      |                  |
| # Info: + Info: +                   | Rin(4)         | +<br>  Output | +            | <del>-</del>           | <del>-</del>                      |                  |
| # Info: + # Info:                   | Rin(3)         | +<br>  Output | <del>+</del> | <del>-</del>           | <del>-</del>                      |                  |
| # Info: + # Info:                   | Rin(2)         | +<br>  Output | <del>+</del> | <del>-</del>           | <del>-</del>                      |                  |
| # Info: + # Info:                   | Rin(1)         | +<br>  Output | <del>+</del> | <del>-</del>           | <del>+</del><br>                  |                  |
| # Info:  <br># Info:                | Rin(0)         | +<br>  Output | <del>+</del> | <del>-</del>           | <del>-</del>                      |                  |
| # Info: + Info:                     | instruction(7) | +<br>  Input  | <del>+</del> | <del>-</del><br>       | <del>-</del><br>                  |                  |
| # Info: + # Info:                   | instruction(6) | +<br>  Input  | <del>+</del> | <del>-</del>           | <del>+</del><br>                  |                  |
| # Info:  <br># Info:                | instruction(5) | +<br>  Input  | <del>+</del> | <del>-</del>           | <del>+</del><br>                  |                  |
| # Info: +<br># Info:                | instruction(4) | +<br>  Input  | <del>+</del> | <del>-</del>           | <del>-</del>                      |                  |
| # Info: +<br># Info:                | instruction(3) | +<br>  Input  | <del>+</del> | <del>-</del>           | <del>-</del>                      |                  |
|                                     | instruction(2) | +<br>  Input  | +            | <del>-</del>           | <del>+</del><br> <br><del>-</del> |                  |
| # Info: +<br># Info:                | instruction(1) | +<br>  Input  | <del>+</del> | <del>-</del>           | <del>+</del>                      |                  |
|                                     | instruction(0) | +<br>  Input  | <del>+</del> | <del>-</del>           | <del>+</del>                      |                  |
| # Info: +<br># Info:                | enable         | +<br>  Input  | <del>+</del> | <del>-</del>           | <del>-</del>                      |                  |
| # Info: +<br># Info:                | adr(1)         | +<br>  Input  | <del>+</del> | <del>-</del>           | <del>-</del>                      |                  |
| # Info: + Info:                     | adr(0)         | +<br>  Input  | <del>+</del> | <del>-</del>           | <del>-</del>                      |                  |
| # Info: + Info:                     |                | +<br>  Output | <del>+</del> | <del>-</del>           | <del>-</del>                      |                  |
| # Info: + Info:                     | Min(30)        | +<br>  Output | <del>+</del> | <del>-</del><br>       | <del>-</del><br>                  | <del> </del>     |
| # Info: +                           | Min(29)        | +<br>  Output | <del>+</del> | <del>-</del><br>       | <del>+</del><br> <br>:            | <del> </del>     |
| # Info: +                           |                | +<br>  Output | <del>+</del> | <del>+</del><br> <br>: | <del>+</del><br> <br>:            | <del> </del>     |
| # Info: +                           | Min(27)        | +<br>  Output | <del>+</del> | <del>+</del><br> <br>: | <del>+</del><br> <br>:            | <del> </del>     |
| # Info: +<br># Info:                |                | +<br>  Output | +<br>        | <del>+</del><br>       | <del>+</del><br>                  |                  |
|                                     |                |               |              |                        |                                   |                  |

| # Info: -            | <del></del>    | +             | +                      | +                      | +                      | ŀ                |
|----------------------|----------------|---------------|------------------------|------------------------|------------------------|------------------|
| # Info:<br># Info:   | Min(25)        | Output        |                        |                        | <u> </u>               |                  |
| # Info:              | Min(24)        | Output        | +<br> <br>:            | <br> <br>              | <del>-</del>           | F<br>            |
| # Info: -            | H<br>  Min(23) | +<br>  Output | <del>+</del>           | +<br>                  | <del>+</del><br>       | <b>+</b><br>     |
| # Info: -            | <br>  Min(22)  | <br>  Output  | <del>+</del>           | +<br>                  | <del>+</del><br>       | <b>+</b><br>     |
| # Info: -            | +<br>  Min(21) | +<br>  Output | +<br>                  | +<br>                  | +<br>                  | <del> </del><br> |
| # Info: -            | +<br>  Min(20) | +<br>  Output | +<br>                  | <del>+</del><br>       | +<br>                  | <b>+</b><br>     |
| # Info: -            | <br>  Min(19)  | +<br>  Output | <del>+</del>           | <del>+</del>           | <del>+</del>           | <b>+</b><br>     |
| # Info: -            | +<br>  Min(18) | +<br>  Output | <del>+</del>           | <del>+</del>           | <del>+</del>           | <b>+</b><br>     |
| # Info: -            | <br>  Min(17)  | Output        | <del>+</del>           | <del> </del><br>       | <del>+</del><br> <br>: | <b> </b> -       |
| # Info: -            | Min(16)        | Output        | <del>+</del>           | <del> </del><br>       | <del>+</del><br> <br>: | <b> </b>         |
| # Info: - # Info:    | Min(15)        | <br>  Output  | <del>+</del><br>       | <del>-</del>           | <del>-</del>           | <b>-</b><br>     |
| # Info: - # Info:    | H              | +<br>  Output | <del>+</del><br>       | <del>-</del><br> <br>  | <del>-</del><br>       | <del>-</del><br> |
| # Info: -            | Min(13)        | Output        | +<br>!                 | <del>-</del>           | <del>+</del>           | <del>-</del><br> |
| # Info: -            | H              | +<br>  Output | <del>-</del>           | <del>-</del><br> <br>: | <del>-</del>           | <b>-</b>         |
| # Info: -            | +              | +<br>  Output | <del>-</del>           | <del>-</del><br> <br>: | <del>-</del>           | <b>-</b>         |
| # Info: -            | +<br>  Min(10) | +<br>  Output | <del>-</del>           | <del>-</del><br> <br>: | <del>-</del>           | <del>-</del><br> |
| # Info: -            | +              | +<br>  Output | <del>+</del><br> <br>: | <del>-</del><br>       | <del>-</del>           | <b>-</b><br>     |
| # Info: -            | Min(8)         | Output        | +<br> <br>:            | <del>-</del>           | <del>+</del>           | <b>-</b><br>     |
| # Info: -            | +              | +<br>  Output | <del>+</del><br> <br>: | <del>-</del><br>       | <del>-</del>           | <del>-</del><br> |
| # Info: -            |                | +<br>  Output | <del>+</del><br> <br>: | <del>-</del><br>       | <del>-</del>           | <del>-</del><br> |
| # Info: -            |                | Output        | <del>+</del>           | <del> </del><br> <br>  | <del>+</del><br> <br>: |                  |
|                      | Min(4)         | Output        | <del>+</del>           | <del> </del><br> <br>  | <del>+</del><br> <br>: |                  |
| # Info: - # Info:    | Min(3)         | +<br>  Output | <del>+</del><br>       | <del>-</del><br> <br>  | <del>-</del><br>       | <del>-</del><br> |
| # Info:              |                | +<br>  Output | <del>+</del><br>       | <del>-</del><br> <br>  | <del>-</del><br>       | <del>-</del><br> |
| # Info: - # Info:    | Min(1)         | <br>  Output  | <del>-</del>           | <del>-</del>           | <del>-</del>           | <del>-</del><br> |
| # Info: - # Info:    | Min(0)         | <br>  Output  | <del>-</del>           | <del>-</del>           | <del>-</del>           | <del>-</del><br> |
|                      | Mout(31)       | +<br>  Input  | <del>+</del><br> <br>: | <del>-</del><br>       | <del>-</del>           | <b>-</b><br>     |
|                      | Mout(30)       | +<br>  Input  | <del>+</del><br> <br>: | <del>-</del><br>       | <del>-</del>           | <b>+</b><br>     |
|                      | Mout(29)       | +<br>  Input  | <del>+</del><br> <br>: | <del>-</del><br>       | <del>-</del>           | <b>-</b><br>     |
|                      | Mout(28)       | <br>  Input   | <del>+</del><br>       | <del>-</del>           | <del>-</del>           | <del> </del><br> |
|                      | Mout(27)       | +<br>  Input  | <del>+</del><br>       | <del>-</del><br> <br>  | <del>-</del><br>       | <b>-</b>         |
|                      | Mout(26)       | +<br>  Input  | <del>+</del><br>       | <del>-</del><br> <br>  | <del>-</del><br>       | <b>-</b>         |
| # Info: -<br># Info: | <br>  Mout(25) | +<br>  Input  | <del>+</del><br>       | <del>-</del>           | <del>+</del><br>       | <b>+</b>         |
| # IIIO.              | HOUL(20)       | ι τιιρατ      | I                      | I                      | I                      |                  |

| # Info: -                        | +                          | +                     | <b></b>          | +                      | ++                            | _        |
|----------------------------------|----------------------------|-----------------------|------------------|------------------------|-------------------------------|----------|
| # Info:                          | Mout(24)                   | <br>  Input           |                  | [                      | ! !                           | _        |
| # Info:                          | Mout(23)                   | Input                 |                  | ļ                      |                               | _        |
| # Info: -                        | +<br>  Mout(22)            | <br>  Input           |                  | +<br>                  | ++<br>                        | -        |
| # Info: -                        | +<br>  Mout(21)            | +<br>  Input          | +<br>            | +<br>                  | ++<br>                        | =        |
| # Info: -<br># Info:             | +<br>  Mout(20)            | +<br>  Input          | +<br>            | +<br>                  | ++<br>                        | -        |
| # Info: -<br># Info:             | +<br>  Mout(19)            | +<br>  Input          | +<br>            | +<br>                  | ++<br>                        | •        |
| # Info: -<br># Info:             | +<br>  Mout(18)            | +<br>  Input          | +<br>            | +<br>                  | ++<br>                        | -        |
| <pre># Info: -</pre>             | +<br>  Mout(17)            |                       | <br>             | +<br>                  | ++<br>                        | <u>=</u> |
| <pre># Info: - # Info:</pre>     | +<br>  Mout(16)            | +<br>  Input          | +                | <del>†</del>           | ++<br>                        | -        |
| # Info: -                        | +<br>  Mout(15)            | +                     | '<br>+<br>I      | ,<br><del>†</del><br>! | '<br><del> +</del><br>        | -        |
| # Info: -                        | +                          | +                     | <br>             | !<br><del> </del>      | <br><del> </del><br>          | -        |
| # Info: -                        | Mout(14)<br><del> </del>   | Input<br><del> </del> | <br>             | <br><del> </del>       | <br><del> +</del>             | -        |
| # Info:<br># Info: -             | Mout(13)<br>+              | Input<br>+            | <br><del> </del> | <br><del> </del>       | <br><del>+</del> +            | -        |
| <pre># Info: -</pre>             | Mout(12)<br>+              | Input<br>+            | <br><del> </del> | <br><del>+</del>       | <br><del>+</del> +            | <u>-</u> |
| <pre># Info: -</pre>             | Mout(11)<br>+              | Input<br>+            | <br>+            | <br>+                  | <br>+                         | -        |
| # Info:                          | Mout(10)                   | Input                 |                  | !                      | į į                           |          |
| # Info: -                        | Mout(9)                    |                       |                  | <del>+</del>           | <del>+</del> <del>+</del><br> | -        |
| # Info: -                        | +<br>  Mout(8)             | +<br>  Input          | +<br>            | +<br>                  | ++<br>                        | =        |
| # Info: -<br># Info:             | +<br>  Mout(7)             | +<br>  Input          | +<br>            | +<br>                  | ++<br>                        | -        |
| # Info: -<br># Info:             | +<br>  Mout(6)             | +<br>  Input          | +<br>            | +<br>                  | ++<br>                        | -        |
| # Info: -<br># Info:             | +<br>  Mout(5)             | +<br>  Input          | +<br>            | +<br>                  | ++<br>                        | -        |
| <pre># Info: -</pre>             | +<br>  Mout(4)             | +<br>  Input          | +<br>            | +<br>                  | ++<br>                        | =        |
| <pre># Info: - # Info:</pre>     | <del>t</del><br>  Mout(3)  | +<br>  Input          | +                | +<br>                  | ++<br>                        | -        |
| # Info: -                        | +<br>  Mout(2)             | +<br>  Input          | '<br>+<br>I      | ,<br><del> </del>      | '<br><del> </del><br>         | -        |
| # Info: -                        | +                          | +                     | '<br>}<br>!      | ,<br>+<br>!            | '<br><del>+</del> +<br>       | -        |
| # Info: -                        | +                          | +                     | <br>             | <br><del> </del>       | <br><del> </del><br>          | <u>-</u> |
| <pre># Info:<br/># Info: -</pre> | Mout(0)<br>+               | Input<br>+            | <br><del> </del> | <br><del> </del>       | <br><del> +</del>             | -        |
| <pre># Info: +</pre>             | MW(3)<br>+                 | Output<br>+           | <br><del> </del> | <br>+                  | <br>++                        |          |
| # Info:                          | MW(2)                      | Output                | <br>             | <br><b></b>            | <br>                          |          |
| # Info:                          | MW(1)                      | Output                | <br>             | <br>                   |                               |          |
| # Info: -<br># Info:             | +<br>  MW(0)               | +<br>  Output         | +<br>            | +<br>                  | ++<br>                        | -        |
| # Info:                          | +<br>Total registers mappe | +                     | <b></b>          | +                      | ++                            | -        |

# **Design and Verification**

The design to be implemented was as follows:



Note the addition of the extra multiplexer for the regfile write address, as we would be needed to write to Rn (19-16) in the case of an update. The design also allows for pre-indexed reading (directly taking the value for the memory write address from the register file), as well as post-indexed addressing. Finally, an extra mux/modifications are made to unify and supply the immediate offset for load/store half word instructions (the address is split between a high nibble and a low nibble)

The state diagram remains the same; for writeback during data transfer instructions, we write back to the register file in the writeback\_dt\_str state and the load\_dt\_ldr state (writeback\_dt\_ldr writes to the regfile, so we can't update Rn simultaneously), hence we need to introduce no new states for writing.

