

# ReTI-Tools: A VSCode Extension for ReTI Assembly Programming

Bachelorthesis for the B. Sc. Informatik at University of Freiburg

Presenter: Malte Pullich

Chair of Computer Architecture

Examiner: Prof. Dr. Armin Biere

Adviser: Dr. Mathias Fleury, Tobias Faller  
Freiburg, 12.11.2025



# Agenda

---

- 1. Motivation:** State of the Art and Usage
- 2. Background:** ReTI Architecture and Differences between both Versions
- 3. Approach:** Improving on Interactivity and Adding Features
- 4. Results:** Improvement on existing Features, new Features
- 5. Conclusion:** Goals Reached & Future Work

# Motivation

|                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers                                                                                                                                                  | SRAM Codesegment: PC (2147483652<br>00000: ADDI PC 5<- CS<br>00001: ADDI PC 2<br>00002: LOAD ACC 2<br>00003: STORE ACC 1<br>00004: LOADI ACC 1<- PC<br>00005: STORE ACC 3<br>00006: LOADI IN2 3<br>00007: JUMP<= 12<br>00008: LOAD IN1 2<br>00009: LOAD ACC 3<br>00010: STORE ACC 2<br>00011: ADD IN1 3<br>00012: MOVE IN1 ACC<br>00013: STORE ACC 3<br>00014: ADDI ACC 1<br>00015: STORE ACC 1<br>00016: LOAD ACC 0<br>00017: SUB ACC 1<br>00018: JUMP -11<br>00019: NOP<br>00020: JUMP 0<br>00021: ADD ACC IN1<br>00022: 281542656<- DS<br>00023: 281542656<br>00024: 281542656<br>00025: 281542656<br>00026: 281542656<br>00027: 281542656<br>00028: 281542656<br>00029: 281542656<br>00030: 281542656<br>00031: 281542656<br>00032: 281542656<br>00033: 281542656<br>00034: 281542656 | SRAM Datasegment: DS (2147483670<br>00005: STORE ACC 3<br>00006: LOADI IN2 3<br>00007: JUMP<= 12<br>00008: LOAD IN1 2<br>00009: LOAD ACC 3<br>00010: STORE ACC 2<br>00011: ADD IN1 3<br>00012: MOVE IN1 ACC<br>00013: STORE ACC 3<br>00014: ADDI ACC 1<br>00015: STORE ACC 1<br>00016: LOAD ACC 0<br>00017: SUB ACC 1<br>00018: JUMP -11<br>00019: NOP<br>00020: JUMP 0<br>00021: ADD ACC IN1<br>00022: 281542656<- DS<br>00023: 281542656<br>00024: 281542656<br>00025: 281542656<br>00026: 281542656<br>00027: 281542656<br>00028: 281542656<br>00029: 281542656<br>00030: 281542656<br>00031: 281542656<br>00032: 281542656<br>00033: 281542656<br>00034: 281542656<br>00035: 281542656<br>00036: 281542656<br>00037: 281542656<br>00038: 281542656<br>00039: 281542656 | SRAM Stack: SP (2147549183)<br>65501: -631242752<br>65502: -631242752<br>65503: -631242752<br>65504: -631242752<br>65505: -631242752<br>65506: -631242752<br>65507: -631242752<br>65508: -631242752<br>65509: -631242752<br>65510: -631242752<br>65511: -631242752<br>65512: -631242752<br>65513: -631242752<br>65514: -631242752<br>65515: -631242752<br>65516: -631242752<br>65517: -631242752<br>65518: -631242752<br>65519: -631242752<br>65520: -631242752<br>65521: -631242752<br>65522: -631242752<br>65523: -631242752<br>65524: -631242752<br>65525: -631242752<br>65526: -631242752<br>65527: -631242752<br>65528: -631242752<br>65529: -631242752<br>65530: -631242752<br>65531: -631242752<br>65532: -631242752<br>65533: -631242752<br>65534: -631242752<br>65535: -631242752<- SP BAF |
| EPROM: PC (2147483652)                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| UART                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0: 0<br>1: 0<br>2: 3<br>Current send data:<br>All send data:<br>Waiting time sending: 0<br>Waiting time receiving: 0<br>Current input:<br>Remaining input: |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

(n)ext instruction, (c)ontinue to breakpoint, (r)estart, (s)tep into isr, (f)inalize isr, (t)rigger isr, (a)ssign watchobject reg or addr,

Fig.1 : Screenshot of the Emulator by Jürgen Mattheis [1]

# Motivation

| Registers                     | SRAM Codesegment: PC (2147483652) | SRAM Datasegment: DS (2147483670) | SRAM Stack: SP (2147549183) |
|-------------------------------|-----------------------------------|-----------------------------------|-----------------------------|
| PC: 2147483652 (-2147483644)  | 00000: ADDI PC 5<- CS             | 00005: STORE ACC 3                | 65501: -631242752           |
| IN1: 0 (0)                    | 00001: ADDI PC 2                  | 00006: LOADI IN2 3                | 65502: -631242752           |
| IN2: 0 (0)                    | 00002: LOADI ACC 2                | 00007: JUMP<= 12                  | 65503: -631242752           |
| ACC: 2 (2)                    | 00003: STORE ACC 1                | 00008: LOAD IN1 2                 | 65504: -631242752           |
| SP: 2147549183 (-2147418113)  | 00004: LOADI ACC 1<- PC           | 00009: LOAD ACC 3                 | 65505: -631242752           |
| BAF: 2147549183 (-2147418113) | 00005: STORE ACC 3                | 00010: STORE ACC 2                | 65506: -631242752           |
| CS: 2147483648 (-2147483648)  | 00006: LOADI IN2 3                | 00011: ADD IN1 3                  | 65507: -631242752           |
| DS: 2147483670 (-2147483626)  | 00007: JUMP<= 12                  | 00012: MOVE IN1 ACC               | 65508: -631242752           |
| EPROM: PC (2147483652)        | 00008: LOAD IN1 2                 | 00013: STORE ACC 3                | 65509: -631242752           |
|                               | 00009: LOAD ACC 3                 | 00014: ADDI ACC 1                 | 65510: -631242752           |
|                               | 00010: STORE ACC 2                | 00015: STORE ACC 1                | 65511: -631242752           |
|                               | 00011: ADD IN1 3                  | 00016: LOAD ACC 0                 | 65512: -631242752           |
|                               | 00012: MOVE IN1 ACC               | 00017: SUB ACC 1                  | 65513: -631242752           |
|                               | 00013: STORE ACC 3                | 00018: JUMP -11                   | 65514: -631242752           |
|                               | 00014: ADDI ACC 1                 | 00019: NOP                        | 65515: -631242752           |
|                               | 00015: STORE ACC 1                | 00020: JUMP 0                     | 65516: -631242752           |
|                               | 00016: LOAD ACC 0                 | 00021: ADD ACC IN1                | 65517: -631242752           |
|                               | 00017: SUB ACC 1                  | 00022: 281542656<- DS             | 65518: -631242752           |
|                               | 00018: JUMP -11                   | 00023: 281542656                  | 65519: -631242752           |
|                               | 00019: NOP                        | 00024: 281542656                  | 65520: -631242752           |
|                               | 00020: JUMP 0                     | 00025: 281542656                  | 65521: -631242752           |
|                               | 00021: ADD ACC IN1                | 00026: 281542656                  | 65522: -631242752           |
|                               | 00022: 281542656<- DS             | 00027: 281542656                  | 65523: -631242752           |
|                               | 00023: 281542656                  | 00028: 281542656                  | 65524: -631242752           |
|                               | 00024: 281542656                  | 00029: 281542656                  | 65525: -631242752           |
|                               | 00025: 281542656                  | 00030: 281542656                  | 65526: -631242752           |
|                               | 00026: 281542656                  | 00031: 281542656                  | 65527: -631242752           |
|                               | 00027: 281542656                  | 00032: 281542656                  | 65528: -631242752           |
|                               | 00028: 281542656                  | 00033: 281542656                  | 65529: -631242752           |
|                               | 00029: 281542656                  | 00034: 281542656                  | 65530: -631242752           |
|                               | 00030: 281542656                  | 00035: 281542656                  | 65531: -631242752           |
|                               | 00031: 281542656                  | 00036: 281542656                  | 65532: -631242752           |
|                               | 00032: 281542656                  | 00037: 281542656                  | 65533: -631242752           |
|                               | 00033: 281542656                  | 00038: 281542656                  | 65534: -631242752           |
|                               | 00034: 281542656                  | 00039: 281542656                  | 65535: -631242752<- SP BAF  |

(n)ext instruction, (c)ontinue to breakpoint, (r)estart, (s)tep into isr, (f)inalize isr, (t)rigger isr, (a)ssign watchobject reg or addr,

Fig.1 : Screenshot of the Emulator by Jürgen Mattheis [1]

Emulator by Jürgen Mattheis:

# Motivation

|                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers                                                                                                                                                  | SRAM Codesegment: PC (2147483652<br>00000: ADDI PC 5<- CS<br>00001: ADDI PC 2<br>00002: LOAD ACC 2<br>00003: STORE ACC 1<br>00004: LOADI ACC 1<- PC<br>00005: STORE ACC 3<br>00006: LOADI IN2 3<br>00007: JUMP<= 12<br>00008: LOAD IN1 2<br>00009: LOAD ACC 3<br>00010: STORE ACC 2<br>00011: ADD IN1 3<br>00012: MOVE IN1 ACC<br>00013: STORE ACC 3<br>00014: ADDI ACC 1<br>00015: STORE ACC 1<br>00016: LOAD ACC 0<br>00017: SUB ACC 1<br>00018: JUMP -11<br>00019: NOP<br>00020: JUMP 0<br>00021: ADD ACC IN1<br>00022: 281542656<- DS<br>00023: 281542656<br>00024: 281542656<br>00025: 281542656<br>00026: 281542656<br>00027: 281542656<br>00028: 281542656<br>00029: 281542656<br>00030: 281542656<br>00031: 281542656<br>00032: 281542656<br>00033: 281542656<br>00034: 281542656 | SRAM Datasegment: DS (2147483670<br>00005: STORE ACC 3<br>00006: LOADI IN2 3<br>00007: JUMP<= 12<br>00008: LOAD IN1 2<br>00009: LOAD ACC 3<br>00010: STORE ACC 2<br>00011: ADD IN1 3<br>00012: MOVE IN1 ACC<br>00013: STORE ACC 3<br>00014: ADDI ACC 1<br>00015: STORE ACC 1<br>00016: LOAD ACC 0<br>00017: SUB ACC 1<br>00018: JUMP -11<br>00019: NOP<br>00020: JUMP 0<br>00021: ADD ACC IN1<br>00022: 281542656<- DS<br>00023: 281542656<br>00024: 281542656<br>00025: 281542656<br>00026: 281542656<br>00027: 281542656<br>00028: 281542656<br>00029: 281542656<br>00030: 281542656<br>00031: 281542656<br>00032: 281542656<br>00033: 281542656<br>00034: 281542656<br>00035: 281542656<br>00036: 281542656<br>00037: 281542656<br>00038: 281542656<br>00039: 281542656 | SRAM Stack: SP (2147549183)<br>65501: -631242752<br>65502: -631242752<br>65503: -631242752<br>65504: -631242752<br>65505: -631242752<br>65506: -631242752<br>65507: -631242752<br>65508: -631242752<br>65509: -631242752<br>65510: -631242752<br>65511: -631242752<br>65512: -631242752<br>65513: -631242752<br>65514: -631242752<br>65515: -631242752<br>65516: -631242752<br>65517: -631242752<br>65518: -631242752<br>65519: -631242752<br>65520: -631242752<br>65521: -631242752<br>65522: -631242752<br>65523: -631242752<br>65524: -631242752<br>65525: -631242752<br>65526: -631242752<br>65527: -631242752<br>65528: -631242752<br>65529: -631242752<br>65530: -631242752<br>65531: -631242752<br>65532: -631242752<br>65533: -631242752<br>65534: -631242752<br>65535: -631242752<- SP BAF |
| EPROM: PC (2147483652)                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| UART                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0: 0<br>1: 0<br>2: 3<br>Current send data:<br>All send data:<br>Waiting time sending: 0<br>Waiting time receiving: 0<br>Current input:<br>Remaining input: |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

(n)ext instruction, (c)ontinue to breakpoint, (r)estart, (s)tep into isr, (f)inalize isr, (t)rigger isr, (a)ssign watchobject reg or addr,

Fig.1 : Screenshot of the Emulator by Jürgen Mattheis [1]

## Emulator by Jürgen Mattheis:

- OS-dependent (only Linux support)

# Motivation

|                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers                                                                                                                                                  | SRAM Codesegment: PC (2147483652<br>00000: ADDI PC 5<- CS<br>00001: ADDI PC 2<br>00002: LOAD ACC 2<br>00003: STORE ACC 1<br>00004: LOADI ACC 1<- PC<br>00005: STORE ACC 3<br>00006: LOADI IN2 3<br>00007: JUMP<= 12<br>00008: LOAD IN1 2<br>00009: LOAD ACC 3<br>00010: STORE ACC 2<br>00011: ADD IN1 3<br>00012: MOVE IN1 ACC<br>00013: STORE ACC 3<br>00014: ADDI ACC 1<br>00015: STORE ACC 1<br>00016: LOAD ACC 0<br>00017: SUB ACC 1<br>00018: JUMP -11<br>00019: NOP<br>00020: JUMP 0<br>00021: ADD ACC IN1<br>00022: 281542656<- DS<br>00023: 281542656<br>00024: 281542656<br>00025: 281542656<br>00026: 281542656<br>00027: 281542656<br>00028: 281542656<br>00029: 281542656<br>00030: 281542656<br>00031: 281542656<br>00032: 281542656<br>00033: 281542656<br>00034: 281542656 | SRAM Datasegment: DS (2147483670<br>00005: STORE ACC 3<br>00006: LOADI IN2 3<br>00007: JUMP<= 12<br>00008: LOAD IN1 2<br>00009: LOAD ACC 3<br>00010: STORE ACC 2<br>00011: ADD IN1 3<br>00012: MOVE IN1 ACC<br>00013: STORE ACC 3<br>00014: ADDI ACC 1<br>00015: STORE ACC 1<br>00016: LOAD ACC 0<br>00017: SUB ACC 1<br>00018: JUMP -11<br>00019: NOP<br>00020: JUMP 0<br>00021: ADD ACC IN1<br>00022: 281542656<- DS<br>00023: 281542656<br>00024: 281542656<br>00025: 281542656<br>00026: 281542656<br>00027: 281542656<br>00028: 281542656<br>00029: 281542656<br>00030: 281542656<br>00031: 281542656<br>00032: 281542656<br>00033: 281542656<br>00034: 281542656<br>00035: 281542656<br>00036: 281542656<br>00037: 281542656<br>00038: 281542656<br>00039: 281542656 | SRAM Stack: SP (2147549183)<br>65501: -631242752<br>65502: -631242752<br>65503: -631242752<br>65504: -631242752<br>65505: -631242752<br>65506: -631242752<br>65507: -631242752<br>65508: -631242752<br>65509: -631242752<br>65510: -631242752<br>65511: -631242752<br>65512: -631242752<br>65513: -631242752<br>65514: -631242752<br>65515: -631242752<br>65516: -631242752<br>65517: -631242752<br>65518: -631242752<br>65519: -631242752<br>65520: -631242752<br>65521: -631242752<br>65522: -631242752<br>65523: -631242752<br>65524: -631242752<br>65525: -631242752<br>65526: -631242752<br>65527: -631242752<br>65528: -631242752<br>65529: -631242752<br>65530: -631242752<br>65531: -631242752<br>65532: -631242752<br>65533: -631242752<br>65534: -631242752<br>65535: -631242752<- SP BAF |
| EPROM: PC (2147483652)                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| UART                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0: 0<br>1: 0<br>2: 3<br>Current send data:<br>All send data:<br>Waiting time sending: 0<br>Waiting time receiving: 0<br>Current input:<br>Remaining input: |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

(n)ext instruction, (c)ontinue to breakpoint, (r)estart, (s)tep into isr, (f)inalize isr, (t)rigger isr, (a)ssign watchobject reg or addr,

Fig.1 : Screenshot of the Emulator by Jürgen Mattheis [1]

## Emulator by Jürgen Mattheis:

- OS-dependent (only Linux support)
- Workflow requires switching between editor and debugger

# Motivation

The screenshot shows the ReTI-Tools Emulator interface. At the top, there are buttons for RUN (with a play icon) and UART (with a terminal icon). Below them are dropdown menus for 'light' (selected), 'Examples', and 'Pico-C'. To the right are buttons for 'PLAY', 'PREV', and 'NEXT', followed by a 'SHOW GRAPH' toggle switch, a 'SPEED: 1 Hz' button, and a 'NUMBER STYLE' button.

The main area displays assembly code for 'main()' on the left, and the emulator's state on the right. The assembly code is:

```
1 void main() {
2     int x;
3     int y;
4     int z;
5     while (1) {
6         x = 0;
7         y = 1;
8         while (x < 255) {
9             z = x + y;
10            x = y;
11            y = z;
12            print(x);
13        }
14    }
15 }
```

The central part shows the state at 'Instruction 0 | FETCH P0' with the operation 'LOADI DS -2097152'. Registers are shown as follows:

| PC | IN1 | IN2 | ACC | SP | BAF | CS | DS |
|----|-----|-----|-----|----|-----|----|----|
| 0  | 0   | 0   | 0   | 0  | 0   | 0  | 0  |
| 0  | 0   | 0   | 0   | 0  | 0   | 0  | 0  |

Below the registers, memory dump values are listed: 1908408320 and 834666496.

The bottom section shows SRAM, EPROM, and UART memory dump tables:

| SRAM    |            | EPROM |                   | UART     |          |
|---------|------------|-------|-------------------|----------|----------|
| ADDRESS | DATA       | A     | DATA              | REGISTER | DATA     |
| 0       | JUMP 0     | 0     | LOADI DS -2097152 | R0       | 00000000 |
| 1       | 2147483648 | 1     | MULI DS 1024      | R1       | 00000000 |
| 2       | 0          | 2     | MOVE DS SP        | R2       | 00000001 |
| 3       | 0          | 3     | 3208642560        | R3       | 00000000 |

A green message box indicates: 'Compilation successful. Took 1357ms.'

Fig. 2 : Screenshot of the Emulator by Michel Giehl [3]

# Motivation

The screenshot shows the ReTI-Tools Emulator interface. At the top, there are buttons for RUN and UART, and dropdown menus for light, Examples, Pico-C, PLAY, PREV, NEXT, SHOW GRAPH (disabled), SPEED: 1 Hz, and NUMBER STYLE. A green message box indicates "Compilation successful. Took 1357ms".

**Instruction 0 | FETCH P0**  
LOADI DS -2097152

**Registers:**

| PC | IN1 | IN2 | ACC | SP | BAF | CS | DS |
|----|-----|-----|-----|----|-----|----|----|
| 0  | 0   | 0   | 0   | 0  | 0   | 0  | 0  |
| 0  | 0   | 0   | 0   | 0  | 0   | 0  | 0  |

**Memory:**

| SRAM    |            | EPROM |                   | UART     |          |
|---------|------------|-------|-------------------|----------|----------|
| ADDRESS | DATA       | A     | DATA              | REGISTER | DATA     |
| 0       | JUMP 0     | 0     | LOADI DS -2097152 | R0       | 00000000 |
| 1       | 2147483648 | 1     | MULI DS 1024      | R1       | 00000000 |
| 2       | 0          | 2     | MOVE DS SP        | R2       | 00000001 |
| 3       | 0          | 3     | 3208642560        | R3       | 00000000 |

**UART Output:**

```
1 void main() {
2     int x;
3     int y;
4     int z;
5     while (1) {
6         x = 0;
7         y = 1;
8         while (x < 255) {
9             z = x + y;
10            x = y;
11            y = z;
12            print(x);
13        }
14    }
15 }
```

Emulator by Michel Giehl:

Fig. 2 : Screenshot of the Emulator by Michel Giehl [3]

# Motivation

The screenshot shows the ReTI-Tools Emulator interface. On the left, there is a dark panel containing assembly code for a Pico-C program. The code initializes variables x, y, and z, enters a while loop that increments x by y, and prints the value of x. The main interface has several tabs at the top: light, Examples, Pico-C, PLAY, PREV, NEXT, SHOW GRAPH, SPEED: 1 Hz, and NUMBER STYLE. The central part displays the state of the processor. At the top, it says "Instruction 0 | FETCH P0" and "LOADI DS -2097152". Below this are eight registers: PC (0, 0), IN1 (0, 0), IN2 (0, 0), ACC (0, 0), SP (0, 0), BAF (0, 0), CS (0, 0), and DS (0, 0). A memory dump window shows addresses 1908408320 and 834666496. At the bottom, there are three tables: SRAM, EPROM, and UART. The SRAM table shows address 0 with data "JUMP 0" and address 1 with data "2147483648". The EPROM table shows address 0 with data "LOADI DS -2097152" and address 1 with data "MULI DS 1024". The UART table shows four registers R0 through R3 with their corresponding data values.

| SRAM    | EPROM      | UART     |          |
|---------|------------|----------|----------|
| ADDRESS | DATA       | REGISTER | DATA     |
| 0       | JUMP 0     | R0       | 00000000 |
| 1       | 2147483648 | R1       | 00000000 |
| 2       | 0          | R2       | 00000001 |
| 3       | 0          | R3       | 00000000 |

Fig. 2 : Screenshot of the Emulator by Michel Giehl [3]

## Emulator by Michel Giehl:

- Web app, as of Monday 10<sup>th</sup> November, only accessible through Uni network

# Motivation

The screenshot shows the ReTI-Tools emulator interface. On the left, there is a dark panel containing assembly code:

```
1 void main() {
2     int x;
3     int y;
4     int z;
5     while (1) {
6         x = 0;
7         y = 1;
8         while (x < 255) {
9             z = x + y;
10            x = y;
11            y = z;
12            print(x);
13        }
14    }
15 }
```

At the top, there are buttons for RUN, UART, light, Examples, Pico-C, PLAY, PREV, NEXT, SHOW GRAPH (disabled), SPEED: 1 Hz, and NUMBER STYLE. A green message box says "Compilation successful. Took 1357ms." Below the message, the title "Instruction 0 | FETCH P0" and the instruction "LOADI DS -2097152" are displayed. Registers shown are PC, IN1, IN2, ACC, SP, BAF, CS, and DS, all initialized to 0. In the memory section, SRAM at address 0 contains "JUMP 0" and address 1 contains "2147483648". EPROM at address 0 contains "LOADI DS -2097152" and address 1 contains "MULI DS 1024". The UART section shows three registers: R0 (00000000), R1 (00000000), and R2 (00000001). The bottom part of the interface shows the assembly code again.

Fig. 2 : Screenshot of the Emulator by Michel Giehl [3]

## Emulator by Michel Giehl:

- Web app, as of Monday 10<sup>th</sup> November, only accessible through Uni network
- Doesn't support interrupts

# ReTi-Architecture

```
JUMP<= 12
  LOAD IN1 2
  LOAD ACC 3
  STORE 2
  ADD IN1 3
  MOVE IN1 ACC
  STORE 3
  ADDI ACC 1
  STORE 1
  ; Check if i <
  LOAD ACC 0
  SUB ACC 1
JUMP -11
NOP
```

Fig: 3 Excerpt of a ReTI program that calculates Fibonacci numbers



Fig 4: Abstract ReTI architecture [2]

# Differences Between the ReTI Variants

## Differences Between the ReTI Variants

## **ReTI-I (Technical Informatics):**

## ReTI-II (Operating Systems):

# Differences Between the ReTI Variants

## ReTI-I (Technical Informatics):

- Memory is single SRAM

## ReTI-II (Operating Systems):

- Memory split into SRAM, EPROM, UART

# Differences Between the ReTI Variants

## ReTI-I (Technical Informatics):

- Memory is single SRAM
- 1 new internal registers:
  - **I**, Instruction Register

## ReTI-II (Operating Systems):

- Memory split into SRAM, EPROM, UART
- 4 new user-visible registers:
  - **SP**, Stack Pointer
  - **BAF**, Begin Active Frame
  - **CS**, (Begin of) Code Segment
  - **DS**, (Begin of) Data Segment

# Differences Between the ReTI Variants

## ReTI-I (Technical Informatics):

- Memory is single SRAM
- 1 new internal registers:
  - **I**, Instruction Register
- No Interrupts

## ReTI-II (Operating Systems):

- Memory split into SRAM, EPROM, UART
- 4 new user-visible registers:
  - **SP**, Stack Pointer
  - **BAF**, Begin Active Frame
  - **CS**, (Begin of) Code Segment
  - **DS**, (Begin of) Data Segment
- **Interrupts:**
  - Interrupt controller
  - New register **IVN**

# Differences Between the ReTI Variants

## ReTI-I (Technical Informatics):

- Memory is single SRAM
- 1 new internal registers:
  - **I**, Instruction Register
- No Interrupts

## ReTI-II (Operating Systems):

- Memory split into SRAM, EPROM, UART
- 4 new user-visible registers:
  - **SP**, Stack Pointer
  - **BAF**, Begin Active Frame
  - **CS**, (Begin of) Code Segment
  - **DS**, (Begin of) Data Segment
- **Interrupts:**
  - Interrupt controller
  - New register **IVN**
- **New instruction encoding (3 bits for registers)**

# Differences Between the ReTI Variants

## ReTI-I (Technical Informatics):

- Memory is single SRAM
- 1 new internal registers:
  - **I**, Instruction Register
- No Interrupts

## ReTI-II (Operating Systems):

- Memory split into SRAM, EPROM, UART
- 4 new user-visible registers:
  - **SP**, Stack Pointer
  - **BAF**, Begin Active Frame
  - **CS**, (Begin of) Code Segment
  - **DS**, (Begin of) Data Segment
- **Interrupts:**
  - Interrupt controller
  - New register **IVN**
- **New instruction encoding (3 bits for registers)**
- **New instructions (MUL, DIV, MOD)**

# Approach

**Goal:** Improve accessibility and responsiveness to provide a better educational experience.

# Approach

**Goal:** Improve accessibility and responsiveness to provide a better educational experience.

**Extend existing VS Code extension:**

# Approach

**Goal:** Improve accessibility and responsiveness to provide a better educational experience.

**Extend existing VS Code extension:**

- Most used IDE

# Approach

**Goal:** Improve accessibility and responsiveness to provide a better educational experience.

**Extend existing VS Code extension:**

- Most used IDE
- OS-independent

# Approach

**Goal:** Improve accessibility and responsiveness to provide a better educational experience.

**Extend existing VS Code extension:**

- Most used IDE
- OS-independent
- Same tool for both lectures

# Approach

**Goal:** Improve accessibility and responsiveness to provide a better educational experience.

**Extend existing VS Code extension:**

- Most used IDE
- OS-independent
- Same tool for both lectures

**Identified key features to extend:**

# Approach

**Goal:** Improve accessibility and responsiveness to provide a better educational experience.

**Extend existing VS Code extension:**

- Most used IDE
- OS-independent
- Same tool for both lectures

**Identified key features to extend:**

- Emulator

# Approach

**Goal:** Improve accessibility and responsiveness to provide a better educational experience.

**Extend existing VS Code extension:**

- Most used IDE
- OS-independent
- Same tool for both lectures

**Identified key features to extend:**

- Emulator
- Debugger

# Approach

**Goal:** Improve accessibility and responsiveness to provide a better educational experience.

**Extend existing VS Code extension:**

- Most used IDE
- OS-independent
- Same tool for both lectures

**Identified key features to extend:**

- Emulator
- Debugger
- Language Server

# Approach

**Goal:** Improve accessibility and responsiveness to provide a better educational experience.

**Extend existing VS Code extension:**

- Most used IDE
- OS-independent
- Same tool for both lectures

**Identified key features to extend:**

- Emulator
- Debugger
- Language Server

**Additionally:**

# Approach

**Goal:** Improve accessibility and responsiveness to provide a better educational experience.

**Extend existing VS Code extension:**

- Most used IDE
- OS-independent
- Same tool for both lectures

**Identified key features to extend:**

- Emulator
- Debugger
- Language Server

**Additionally:**

- Provide a memory view

# Approach

## Extension's Architecture



Fig. 5: Diagram illustrating the interaction between the different components of the extension.

# Approach

## Extension's Architecture



Fig. 5: Diagram illustrating the interaction between the different components of the extension.

# Results

## Support for Both Architectures



Fig 6: Screenshot of the new setting in VS Code

A screenshot of the VS Code editor showing a file named 'testisrs.reti'. The code contains the following assembly instructions:

```
1 ; Initialization
2 LOADI ACC 5           ; Initiate n = 5,
3 STORE ACC 0           ; Store n in M<0>
4 LOADI ACC 2           ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1           ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
```

The status bar at the bottom right shows the text '= 5'. A context menu is open over the code, with the 'Emulate' option highlighted. The menu also includes 'Debug ReTI' and 'Ctrl+Alt+D'.

Fig 7: Example Usage of the ReTI Emulation in VS Code

# Results

## Support for Both Architectures



Fig 6: Screenshot of the new setting in VS Code

- Added setting to specify desired version

The screenshot shows the VS Code editor with an assembly file named "testisrs.reti". The code consists of six lines of assembly instructions:

```
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5,
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
```

A context menu is open over the assembly code, with the "Emulate" option highlighted. The menu also includes "Debug ReTI" and the keyboard shortcut "Ctrl+Alt+E".

Fig 7: Example Usage of the ReTI Emulation in VS Code

# Results

## Support for Both Architectures



Fig 6: Screenshot of the new setting in VS Code

A screenshot of the VS Code editor showing an assembly file named "testisrs.reti". The code contains six lines of assembly with comments explaining the initialization of variables n and i. A context menu is open over the assembly code, with the "Emulate" option highlighted. The menu also includes "Debug ReTI" and a keyboard shortcut "Ctrl+Alt+E".

```
testisrs.reti  
1 ; Initialization  
2 LOADI ACC 5 ; Initiate n = 5,  
3 STORE ACC 0 ; Store n in M<0>  
4 LOADI ACC 2 ; Initiate i = 2 since F(0) = 0, F(1) = 1  
5 STORE ACC 1 ; Store i in M<1>  
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
```

Fig 7: Example Usage of the ReTI Emulation in VS Code

- Added setting to specify desired version
- Affects all features (emulator, debugger, language server) except quiz

# Results

## Support for Both Architectures



Fig 6: Screenshot of the new setting in VS Code

The screenshot shows the VS Code editor with an assembly file named 'testisrs.reti'. The code contains the following instructions:

```
1 ; Initialization
2 LOADI ACC 5           ; Initiate n = 5,
3 STORE ACC 0           ; Store n in M<0>
4 LOADI ACC 2           ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1           ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
```

A context menu is open over the code, with the 'Emulate' option highlighted. The menu also includes 'Debug ReTI' and a keyboard shortcut 'Ctrl+Alt+E'.

Fig 7: Example Usage of the ReTI Emulation in VS Code

- Added setting to specify desired version
- Affects all features (emulator, debugger, language server) except quiz
- Emulator now callable in .reti files for ReTI-II (OS)

# Results

## Language Server

A screenshot of the Visual Studio Code editor showing a file named `testisrs.reti`. The code is a ReTI assembly program. Several syntax errors are highlighted with red squiggly lines:

- Line 2: `IVTE 2` - *IVTE command is only intended for use in isr files.*
- Line 3: `STD` - *Store n in M<0> Unknown instruction "STD".*
- Line 4: `LOA` - **STORE**
- Line 5: `STO` - **STOREIN**
- Line 6: `JUMP<= ACC` - *Invalid operand.*
- Line 15: `LOAD IN1 2` - *; LOAD F(n-1) into IN1*
- Line 16: `LOAD ACC 3` - *; LOAD F(n) into IN1*

A tooltip for the `STORE` instruction is displayed, showing its documentation: **STORE S i** Stores the value of the specified register into the i-th memory cell.

```
1 ; Initialization
2 IVTE 2    IVTE command is only intended for use in isr files.
3 STD        ; Store n in M<0> Unknown instruction "STD".
4 LOA ↗ STORE
5 STO ↗ STOREIN
6 · F(n-1) will be stored in M<2>, since its 0 no intializati
7 INT          ; orred in M<3>
8 Usage: INT i
9
10 Result: PC := IVT[i]      ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= ACC    Invalid operand.
15 LOAD IN1 2      ; LOAD F(n-1) into IN1
16 LOAD ACC 3      ; LOAD F(n) into IN1
```

Fig 8: Screenshot from VS Code highlighting LSP Features

# Results

## Language Server

A screenshot of the Visual Studio Code editor showing a file named 'testisrs.reti'. The code is written in ReTI assembly. Several syntax errors are highlighted with red squiggly lines: 'IVTE 2' (line 2), 'STD' (line 3), 'LOA' (line 4), 'STO' (line 4), 'INT 0' (line 11), 'JUMP<= ACC' (line 14), 'LOAD IN1 2' (line 15), and 'LOAD ACC 3' (line 16). A tooltip for the 'STORE' command (line 4) is open, showing its documentation: 'Stores the value of the specified register into the i-th memory cell.' Another tooltip for 'INT' (line 11) is partially visible. The code includes comments explaining variable storage and initialization.

```
testisrs.reti
1 ; Initialization
2 IVTE 2    IVTE command is only intended for use in isr files.
3 STD        ; Store n in M<0>  Unknown instruction "STD".
4 LOA ↗ STORE
5 STO ↗ STOREIN
6 · F(n-1) will be stored in M<2>, since its 0 no intializati
7 INT          ; orred in M<3>
8 Usage: INT i
9
10 Result: PC := IVT[i]      ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= ACC    Invalid operand.
15 LOAD IN1 2      ; LOAD F(n-1) into IN1
16 LOAD ACC 3      ; LOAD F(n) into IN1
```

Fig 8: Screenshot from VS Code highlighting LSP Features

## Features:

# Results

## Language Server

A screenshot of the VS Code editor showing a file named 'testisrs.reti'. The code contains several syntax errors highlighted by red squiggly lines. A tooltip for the 'STORE' instruction is open, providing documentation: 'Stores the value of the specified register into the i-th memory cell.' Other visible errors include 'IVTE command is only intended for use in isr files.', 'Unknown instruction "STO".', 'Invalid operand.', and 'INT will be stored in M<2>, since its 0 no initialized in M<3>'.

```
1 ; Initialization
2 IVTE 2    IVTE command is only intended for use in isr files.
3 STO      ; Store n in M<0>  Unknown instruction "STO".
4 LOA ↗ STORE
5 STO ↗ STOREIN
6 · F(n-1) will be stored in M<2>, since its 0 no initialized in M<3>
7 INT          ; F(n-1) will be stored in M<2>
8 Usage: INT i
9
10 Result: PC := IVT[i] ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= ACC  Invalid operand.
15 LOAD IN1 2      ; LOAD F(n-1) into IN1
16 LOAD ACC 3      ; LOAD F(n) into IN1
```

Fig 8: Screenshot from VS Code highlighting LSP Features

### Features:

- Syntax Highlighting

# Results

## Language Server

A screenshot of the Visual Studio Code interface showing a file named 'testisrs.reti'. The code contains several assembly instructions and comments. A tooltip is displayed over the 'STORE' instruction at line 4, providing documentation: 'Stores the value of the specified register into the i-th memory cell.' Other parts of the code include 'IVTE' (which is noted as being only for ISR files), 'INT' (initialization), 'LOOP', and various 'LOAD' and 'STO' (STORE) instructions.

```
1 ; Initialization
2 IVTE 2    IVTE command is only intended for use in isr files.
3 STO      ; Store n in M<0>  Unknown instruction "STO".
4 LOA ↗ STORE
5 STO ↗ STOREIN
6 · F(n-1) will be stored in M<2>, since its 0 no intializati
7          ; orred in M<3>
8 INT
9 Usage: INT i
10 Result: PC := IVT[i] ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= ACC  Invalid operand.
15 LOAD IN1 2      ; LOAD F(n-1) into IN1
16 LOAD ACC 3      ; LOAD F(n) into IN1
```

Fig 8: Screenshot from VS Code highlighting LSP Features

### Features:

- Syntax Highlighting
- Tooltips (syntax and documentation)

# Results

## Language Server

A screenshot of the Visual Studio Code interface showing a file named 'testisrs.reti'. The code contains several assembly instructions and comments. A tooltip is displayed over the 'STORE' instruction at line 4, providing documentation for the 'STORE S i' command. Another tooltip is shown for the 'INT' instruction at line 7. Error highlights are present for the 'IVTE' command at line 2 and the 'JUMP<=' instruction at line 14. The code includes comments explaining variable storage and loop operations.

```
1 ; Initialization
2 IVTE 2    IVTE command is only intended for use in isr files.
3 STO      ; Store n in M<0>  Unknown instruction "STO".
4 LOA ↗ STORE
5 STO ↗ STOREIN
6 · F(n-1) will be stored in M<2>, since its 0 no intializati
7 INT          ; F(n) will be stored in M<3>
8 Usage: INT i
9
10 Result: PC := IVT[i] ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= ACC  Invalid operand.
15 LOAD IN1 2      ; LOAD F(n-1) into IN1
16 LOAD ACC 3      ; LOAD F(n) into IN1
```

Fig 8: Screenshot from VS Code highlighting LSP Features

### Features:

- Syntax Highlighting
- Tooltips (syntax and documentation)
- Realtime compilation and checking

# Results

## Language Server

A screenshot of a VS Code editor window displaying assembly code for the ReTI architecture. The code is contained in a file named 'testisrs.reti'. Several syntax errors are highlighted with red squiggly lines:

- Line 2: 'IVTE 2' is highlighted with an error message: 'IVTE command is only intended for use in isr files.'
- Line 3: 'STD' is highlighted with an error message: 'Unknown instruction "STD".'
- Line 4: 'LOA' is highlighted with an error message: 'Unknown instruction "LOA".'
- Line 5: 'STO' is highlighted with an error message: 'Unknown instruction "STO".'
- Line 14: 'JUMP<= ACC' is highlighted with an error message: 'Invalid operand.'

The 'STORE' instruction at line 4 is being hovered over, which triggers a tooltip. The tooltip has two parts:

- A dropdown menu with items: 'INT', 'Usage: INT i', and 'Result: PC := IVT[i]'. The 'INT' item is currently selected.
- A detailed description: 'Stores the value of the specified register into the i-th memory cell.'

```
1 ; Initialization
2 IVTE 2    IVTE command is only intended for use in isr files.
3 STD        ; Store n in M<0>    Unknown instruction "STD".
4 LOA ↗ STORE
5 STO ↗ STOREIN
6 · F(n-1) will be stored in M<2>, since its 0 no intializati
7 ·      ored in M<3>
8 INT
9 Usage: INT i
10 Result: PC := IVT[i]
11 ; IN2 will save the offset for the used variables
12 INT 0
13 ; LOOP
14 JUMP<= ACC    Invalid operand.
15 LOAD IN1 2      ; LOAD F(n-1) into IN1
16 LOAD ACC 3      ; LOAD F(n) into IN1
```

Fig 8: Screenshot from VS Code highlighting LSP Features

### Features:

- Syntax Highlighting
- Tooltips (syntax and documentation)
- Realtime compilation and checking
- Autocomplete suggestions

# Results

## Debugger and Memory View

The screenshot shows a debugger interface for a ReTI assembly program. The assembly code is as follows:

```
os > fibonacci_os.reti
1  ; Initialization
2  LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3  STORE ACC 0     ; Store n in M<0>
4  LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5  STORE ACC 1     ; Store i in M<1>
; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
; F(n) will be stored in M<3>
6  LOADI ACC 1
7  STORE ACC 3
8  LOADI IN2 3      ; IN2 will save the offset for the used variables
9
10 ; LOOP
11 JUMP<= 12        ; Skip over the loop if n - i <= 0, meaning i > 0
12 LOAD IN1 2        ; LOAD F(n-1) into IN1
13 LOAD ACC 3        ; LOAD F(n) into IN1
14 STORE ACC 2        ; store F(n) in M<2> since in the next iteration it is F(n-
15 ADD IN1 3          ; calculate F(n+1)
16 MOVE IN1 ACC
17 STORE ACC 3        ; M<3> now holds F(n+1) which in the next iteration will be
18 ADDI ACC 1          ; increase i
19 STORE ACC 1        ; STORE new value of i in M<1>
20 ; Check if i < n for JUMP condition
21 LOAD ACC 0
22 SUB ACC 1          ; ACC = n - M<1> = n - i, will be positive as long as n > i
23 JUMP -11            ; JUMP back to the start of the loop
24 NOP
25 JUMP 0
```

The memory view shows the following state:

| Address | Value | Write |
|---------|-------|-------|
| 0       | 0     |       |
| 1       | 10    | Write |
| 2       | 0     |       |
| 3       | 5     |       |
| 4       | 10    |       |
| 5       | 0     |       |

The variables pane shows the following register values:

- PC = 2
- IN1 = 0
- IN2 = 0
- ACC = 5
- SP = 2147483703
- BAF = 2147483650
- CS = 2147483651
- DS = 2147483672
- I = 2248146944

Fig 9: Screenshot of running ReTI-Debug session

# Results

## Debugger and Memory View

The screenshot shows a debugger interface for a ReTI assembly program. On the left, there's a 'MEMORY VIEW' panel with two tables: one for 'Read' operations and one for 'Write' operations. The 'Read' table shows address 1 with value 10. The 'Write' table shows addresses 00, 01, and 02 with values 5, 10, and 0 respectively. Below these is a 'VARIABLES' panel listing registers and memory locations with their current values.

The main area displays assembly code:

```
os > fibonacci_os.reti
1  v ; Initialization
2    LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3    STORE ACC 0      ; Store n in M<0>
4    LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5    STORE ACC 1      ; Store i in M<1>
6    ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7    ; F(n) will be stored in M<3>
8    LOADI ACC 1
9    STORE ACC 3
10   LOADI IN2 3      ; IN2 will save the offset for the used variables
11
12  ; LOOP
13  v JUMP<= 12      ; Skip over the loop if n - i <= 0, meaning i > 0
14    LOAD IN1 2      ; LOAD F(n-1) into IN1
15    LOAD ACC 3      ; LOAD F(n) into IN1
16    STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-
17    ADD IN1 3        ; calculate F(n+1)
18    MOVE IN1 ACC      ;
19    STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be
20    ADDI ACC 1        ; increase i
21    STORE ACC 1      ; STORE new value of i in M<1>
22    ; Check if i < n for JUMP condition
23    LOAD ACC 0
24    SUB ACC 1        ; ACC = n - M<1> = n - i, will be positive as long as n > i
25    JUMP -11          ; JUMP back to the start of the loop
26    NOP
27    JUMP 0
```

Features both architectures:

Fig 9: Screenshot of running ReTI-Debug session

# Results

## Debugger and Memory View

The screenshot shows a debugger interface for a ReTI assembly program. On the left, the 'MEMORY VIEW' panel displays memory at address 0, showing a value of 10 at address 1, which is being written. Below it, the 'VARIABLES' panel lists registers and memory locations with their current values.

| Address | Value |
|---------|-------|
| 1       | 10    |

| Address | Value |
|---------|-------|
| 00      | 5     |
| 01      | 10    |
| 02      | 0     |

**VARIABLES**

- Registers:
  - PC = 2
  - IN1 = 0
  - IN2 = 0
  - ACC = 5
  - SP = 2147483703
  - BAF = 2147483650
  - CS = 2147483651
  - DS = 2147483672
  - I = 2248146944

The central area shows the assembly code for the fibonacci\_os.reti program:

```
os > fibonacci_os.reti
1 v ; Initialization
2    LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3    STORE ACC 0      ; Store n in M<0>
4    LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5    STORE ACC 1      ; Store i in M<1>
; F(n-1) will be stored in M<2>, since its 0 no initialization is needed
; F(n) will be stored in M<3>
6    LOADI ACC 1
7    STORE ACC 3
8    LOADI IN2 3      ; IN2 will save the offset for the used variables
9
10   ; LOOP
11
12   ; JUMP<= 12      ; Skip over the loop if n - i <= 0, meaning i > 0
13   v JUMP<= 12
14   LOAD IN1 2        ; LOAD F(n-1) into IN1
15   LOAD ACC 3        ; LOAD F(n) into IN1
16   STORE ACC 2        ; store F(n) in M<2> since in the next iteration it is F(n-
17   ADD IN1 3          ; calculate F(n+1)
18   MOVE IN1 ACC
19   STORE ACC 3        ; M<3> now holds F(n+1) which in the next iteration will be
20   ADDI ACC 1          ; increase i
21   STORE ACC 1        ; STORE new value of i in M<1>
22   ; Check if i < n for JUMP condition
23   LOAD ACC 0
24   SUB ACC 1          ; ACC = n - M<1> = n - i, will be positive as long as n > i
25   JUMP -11            ; JUMP back to the start of the loop
26   NOP
27   JUMP 0
```

Fig 9: Screenshot of running ReTI-Debug session

### Features both architectures:

- Reading and writing register values

# Results

## Debugger and Memory View

The screenshot shows a debugger interface for a ReTI assembly program. On the left, the 'MEMORY VIEW' panel displays memory at address 0, showing a value of 10 at address 1, which is being written. Below it, the 'VARIABLES' panel lists registers and memory locations with their current values.

| Address | Value |
|---------|-------|
| 00      | 5     |
| 01      | 10    |
| 02      | 0     |

| Address | Value |
|---------|-------|
| 1       | 10    |

**VARIABLES**

- Registers:
  - PC = 2
  - IN1 = 0
  - IN2 = 0
  - ACC = 5
  - SP = 2147483703
  - BAF = 2147483650
  - CS = 2147483651
  - DS = 2147483672
  - I = 2248146944

The main window shows the assembly code for calculating the nth Fibonacci number. The code uses registers ACC, IN1, and IN2, and memory locations M<0> through M<3>. The assembly code is as follows:

```
os > fibonacci_os.reti
1  v ; Initialization
2    LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3    STORE ACC 0      ; Store n in M<0>
4    LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5    STORE ACC 1      ; Store i in M<1>
6    ; F(n-1) will be stored in M<2>, since its 0 no initialization is needed
7    ; F(n) will be stored in M<3>
8    LOADI ACC 1
9    STORE ACC 3
10   LOADI IN2 3      ; IN2 will save the offset for the used variables
11
12  ; LOOP
13  v JUMP<= 12      ; Skip over the loop if n - i <= 0, meaning i > 0
14    LOAD IN1 2      ; LOAD F(n-1) into IN1
15    LOAD ACC 3      ; LOAD F(n) into IN1
16    STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-
17    ADD IN1 3      ; calculate F(n+1)
18    MOVE IN1 ACC      ;
19    STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be
20    ADDI ACC 1      ; increase i
21    STORE ACC 1      ; STORE new value of i in M<1>
22    ; Check if i < n for JUMP condition
23    LOAD ACC 0
24    SUB ACC 1      ; ACC = n - M<1> = n - i, will be positive as long as n > i
25    JUMP -11        ; JUMP back to the start of the loop
26    NOP
27    JUMP 0
```

Fig 9: Screenshot of running ReTI-Debug session

### Features both architectures:

- Reading and writing register values
- Reading and writing memory

# Results

## Debugger and Memory View

The screenshot shows a debugger interface for a ReTI assembly program. On the left, the 'MEMORY VIEW' panel displays memory at address 0, showing a value of 10 at address 1, which is being written. Below it, the 'VARIABLES' panel lists registers and memory locations with their current values.

| Address | Value |
|---------|-------|
| 00      | 5     |
| 01      | 10    |
| 02      | 0     |

| Address | Value |
|---------|-------|
| 1       | 10    |

**VARIABLES**

- Registers:
  - PC = 2
  - IN1 = 0
  - IN2 = 0
  - ACC = 5
  - SP = 2147483703
  - BAF = 2147483650
  - CS = 2147483651
  - DS = 2147483672
  - I = 2248146944

The main window shows the assembly code for calculating Fibonacci numbers. The code uses registers ACC, IN1, and IN2, and memory locations M<0>, M<1>, and M<2>. The assembly code is as follows:

```
os > fibonacci_os.reti
1  v ; Initialization
2    LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3    STORE ACC 0      ; Store n in M<0>
4    LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5    STORE ACC 1      ; Store i in M<1>
6    ; F(n-1) will be stored in M<2>, since its 0 no initialization is needed
7    ; F(n) will be stored in M<3>
8    LOADI ACC 1
9    STORE ACC 3
10   LOADI IN2 3      ; IN2 will save the offset for the used variables
11
12  ; LOOP
13  v JUMP<= 12      ; Skip over the loop if n - i <= 0, meaning i > 0
14    LOAD IN1 2      ; LOAD F(n-1) into IN1
15    LOAD ACC 3      ; LOAD F(n) into IN1
16    STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-
17    ADD IN1 3      ; calculate F(n+1)
18    MOVE IN1 ACC      ;
19    STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be
20    ADDI ACC 1      ; increase i
21    STORE ACC 1      ; STORE new value of i in M<1>
22    ; Check if i < n for JUMP condition
23    LOAD ACC 0
24    SUB ACC 1      ; ACC = n - M<1> = n - i, will be positive as long as n > i
25    JUMP -11        ; JUMP back to the start of the loop
26    NOP
27    JUMP 0
```

Fig 9: Screenshot of running ReTI-Debug session

### Features both architectures:

- Reading and writing register values
- Reading and writing memory
- Breakpoints

# Results

## Debugger and Memory View

The screenshot shows a debugger interface for the ReTI-II OS. On the left, there's a 'MEMORY VIEW' panel with two tables: one for 'Read' operations and one for 'Write' operations. The 'Read' table shows address 1 with value 10. The 'Write' table shows address 00 with value 5, address 01 with value 10, and address 02 with value 0. Below these is a 'VARIABLES' panel showing register values: PC = 2, IN1 = 0, IN2 = 0, ACC = 5, SP = 2147483703, BAF = 2147483650, CS = 2147483651, DS = 2147483672, and I = 2248146944.

The main area displays assembly code for a Fibonacci calculation:

```
os > fibonacci_os.reti
1  v ; Initialization
2    LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3    STORE ACC 0      ; Store n in M<0>
4    LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5    STORE ACC 1      ; Store i in M<1>
6    ; F(n-1) will be stored in M<2>, since its 0 no initialization is needed
7    ; F(n) will be stored in M<3>
8    LOADI ACC 1
9    STORE ACC 3
10   LOADI IN2 3      ; IN2 will save the offset for the used variables
11
12  ; LOOP
13  v JUMP<= 12      ; Skip over the loop if n - i <= 0, meaning i > 0
14    LOAD IN1 2      ; LOAD F(n-1) into IN1
15    LOAD ACC 3      ; LOAD F(n) into IN1
16    STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-
17    ADD IN1 3        ; calculate F(n+1)
18    MOVE IN1 ACC
19    STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be
20    ADDI ACC 1        ; increase i
21    STORE ACC 1      ; STORE new value of i in M<1>
22    ; Check if i < n for JUMP condition
23    LOAD ACC 0
24    SUB ACC 1        ; ACC = n - M<1> = n - i, will be positive as long as n > i
25    JUMP -11          ; JUMP back to the start of the loop
26    NOP
27    JUMP 0
```

Fig 9: Screenshot of running ReTI-Debug session

### Features both architectures:

- Reading and writing register values
- Reading and writing memory
- Breakpoints

### Features for the ReTI-II (OS):

# Results

## Debugger and Memory View

The screenshot shows a debugger interface for the ReTI-II OS. On the left, the 'MEMORY VIEW' panel displays memory at address 0 and 3. At address 1, there is a 'Read' operation with value 10 and a 'Write' button. The 'VARIABLES' panel shows registers and memory values: PC = 2, IN1 = 0, IN2 = 0, ACC = 5, SP = 2147483703, BAF = 2147483650, CS = 2147483651, DS = 2147483672, and I = 2248146944. The central area shows assembly code for the fibonacci\_os.ret file:

```
os > fibonacci_os.ret
1 v ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0      ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1      ; Store i in M<1>
; F(n-1) will be stored in M<2>, since its 0 no initialization is needed
; F(n) will be stored in M<3>
6 LOADI ACC 1
7 STORE ACC 3
8 LOADI IN2 3      ; IN2 will save the offset for the used variables
9
10 ; LOOP
11
12 JUMP<= 12      ; Skip over the loop if n - i <= 0, meaning i > 0
13 LOAD IN1 2      ; LOAD F(n-1) into IN1
14 LOAD ACC 3      ; LOAD F(n) into IN1
15 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
16 ADD IN1 3        ; calculate F(n+1)
17 MOVE IN1 ACC
18
19 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be
20 ADDI ACC 1        ; increase i
21 STORE ACC 1      ; STORE new value of i in M<1>
22 ; Check if i < n for JUMP condition
23 LOAD ACC 0
24 SUB ACC 1        ; ACC = n - M<1> = n - i, will be positive as long as n > i
25 JUMP -11         ; JUMP back to the start of the loop
26 NOP
27 JUMP 0
```

Fig 9: Screenshot of running ReTI-Debug session

### Features both architectures:

- Reading and writing register values
- Reading and writing memory
- Breakpoints

### Features for the ReTI-II (OS):

- Switching between main program and interrupt service routine file

# Results

## Debugger and Memory View

The screenshot shows a debugger interface for the ReTI-II OS. On the left, there's a 'MEMORY VIEW' panel with two tables: one for 'Read' operations and one for 'Write' operations. The 'Read' table has a single entry at address 1 with value 10. The 'Write' table has an entry at address 1 with value 10 and a 'Write' button. Below these is a 'VARIABLES' panel showing register values: PC = 2, IN1 = 0, IN2 = 0, ACC = 5, SP = 2147483703, BAF = 2147483650, CS = 2147483651, DS = 2147483672, and I = 2248146944.

The main area displays assembly code for a Fibonacci calculation:

```
os > fibonacci_os.reti
1 v ; Initialization
2    LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3    STORE ACC 0      ; Store n in M<0>
4    LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5    STORE ACC 1      ; Store i in M<1>
; F(n-1) will be stored in M<2>, since its 0 no initialization is needed
; F(n) will be stored in M<3>
6    LOADI ACC 1
7    STORE ACC 3
8    LOADI IN2 3      ; IN2 will save the offset for the used variables
9
10   ; LOOP
11
12   ; JUMP<= 12      ; Skip over the loop if n - i <= 0, meaning i > 0
13   LOAD IN1 2        ; LOAD F(n-1) into IN1
14   LOAD ACC 3        ; LOAD F(n) into IN1
15   STORE ACC 2        ; store F(n) in M<2> since in the next iteration it is F(n)
16   ADD IN1 3          ; calculate F(n+1)
17   MOVE IN1 ACC
18   ;
19   STORE ACC 3        ; M<3> now holds F(n+1) which in the next iteration will be
20   ADDI ACC 1          ; increase i
21   STORE ACC 1        ; STORE new value of i in M<1>
22   ; Check if i < n for JUMP condition
23   LOAD ACC 0
24   SUB ACC 1          ; ACC = n - M<1> = n - i, will be positive as long as n > i
25   JUMP -11            ; JUMP back to the start of the loop
26   NOP
27   JUMP 0
```

Fig 9: Screenshot of running ReTI-Debug session

### Features both architectures:

- Reading and writing register values
- Reading and writing memory
- Breakpoints

### Features for the ReTI-II (OS):

- Switching between main program and interrupt service routine file
- Updated Stepping Logic to support interrupts

# Results

## Debugger, Stepping



The image shows two side-by-side code editors within a debugger interface. The left editor is titled 'testisrs.ret' and contains assembly code for initializing variables and performing a loop. The right editor is titled 'isrs.ret' and contains assembly code for restoring registers and keeping register values.

**testisrs.ret:**

```
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1        ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0
```

**isrs.ret:**

```
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



The screenshot shows two assembly code files in a debugger interface:

**testisrs.ret**

```
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1       ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0
```

**isrs.ret**

```
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



The image shows two side-by-side assembly code editors from the ReTI-Tools VSCode extension. The left editor is titled 'testisrs.ret' and the right is 'isrs.ret'. Both editors have a toolbar at the top with icons for file operations, search, and navigation.

**testisrs.ret:**

```
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1        ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0
```

**isrs.ret:**

```
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



The figure shows two assembly code files in a debugger interface:

**testisrs.ret**

```
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1       ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0
```

**isrs.ret**

```
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



The image shows two side-by-side assembly code editors from the ReTI-Tools VSCode extension. Both windows have a toolbar at the top with icons for file operations, search, and navigation.

**Left Window (testisrs.reti):**

```
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1       ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0
```

**Right Window (isrs.reti):**

```
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



The image shows two side-by-side code editors within a debugger interface. The left editor is titled 'testisrs.ret' and contains assembly code for initializing variables and performing a loop. The right editor is titled 'isrs.ret' and contains assembly code for restoring registers and keeping register values.

```
testisrs.ret
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1       ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0

isrs.ret
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



The screenshot shows two assembly files open in the ReTI-Debug extension for VSCode:

**testisrs.ret**

```
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1       ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0
```

**isrs.ret**

```
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



```
testisrs.ret
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0      ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1      ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1       ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0

isrs.ret
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



The screenshot shows two assembly files in a debugger interface:

**testisrs.ret**

```
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1        ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0
```

**isrs.ret**

```
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



The figure shows two assembly code files in a debugger interface:

**testisrs.ret**

```
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1       ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0
```

**isrs.ret**

```
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



The figure displays two assembly code files in a debugger interface:

**testisrs.reti**

```
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1       ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0
```

**isrs.reti**

```
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



```
testisrs.ret
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1       ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0

isrs.ret
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



The screenshot shows two windows of the ReTI-Tools extension in VSCode. The left window displays assembly code for a routine named 'testisrs.ret'. The right window displays assembly code for a routine named 'isrs.ret'. Both windows show the assembly language with color-coded syntax highlighting for instructions and comments. A toolbar at the top of each window contains several icons, with the step-up arrow icon being highlighted by a red box.

```
testisrs.ret
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0      ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1      ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1        ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0
31
```

```
isrs.ret
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Results

## Debugger, Stepping



The image shows two side-by-side windows of a debugger interface, likely ReTI-Tools, displaying assembly code. Both windows have a toolbar at the top with icons for file operations, search, and navigation.

**testisrs.ret:**

```
1 ; Initialization
2 LOADI ACC 5      ; Initiate n = 5, Expected result in M<3> = F(5) = 5
3 STORE ACC 0     ; Store n in M<0>
4 LOADI ACC 2      ; Initiate i = 2 since F(0) = 0, F(1) = 1
5 STORE ACC 1     ; Store i in M<1>
6 ; F(n-1) will be stored in M<2>, since its 0 no intialization is needed
7 ; F(n) will be stored in M<3>
8 LOADI ACC 1
9 STORE ACC 3
10 LOADI IN2 3     ; IN2 will save the offset for the used variables
11 INT 0
12
13 ; LOOP
14 JUMP<= 12       ; Skip over the loop if n - i <= 0, meaning i > 0
15 LOAD IN1 2       ; LOAD F(n-1) into IN1
16 LOAD ACC 3       ; LOAD F(n) into IN1
17 STORE ACC 2      ; store F(n) in M<2> since in the next iteration it is F(n-1)
18 ADD IN1 3        ; calculate F(n+1)
19 MOVE IN1 ACC
20 NOP
21 STORE ACC 3      ; M<3> now holds F(n+1) which in the next iteration will be F(n)
22 ADDI ACC 1       ; increase i
23 STORE ACC 1      ; STORE new value of i in M<1>
24 ; Check if i < n for JUMP condition
25 LOAD ACC 0
26 INT 1
27 SUB ACC 1       ; ACC = n - M<1> = n - i, will be positive as long as n > i
28 JUMP -11         ; JUMP back to the start of the loop
29 NOP
30 JUMP 0
```

**isrs.ret:**

```
1 ; Example routine that restores registers
2 IVTE 0
3 SUBI SP 7
4 STOREIN SP IN1 7
5 STOREIN SP IN2 6
6 STOREIN SP ACC 5
7
8 STOREIN SP CS 2
9 STOREIN SP DS 1
10
11 LOADI IN1 2
12 LOADI IN2 5
13 SUB IN2 IN1
14 LOADI ACC 1
15
16 LOADIN SP DS 1
17 LOADIN SP CS 2
18 LOADIN SP ACC 5
19 LOADIN SP IN2 6
20 LOADIN SP IN1 7
21 ADDI SP 7
22 RTI
23 ; Example routine that keeps register values.
24 IVTE 1
25 LOADI ACC 2
26 MOVE ACC IN1
27 LOADI IN2 5
28 SUB IN2 IN1
29 LOADI ACC 1
30 RTI
```

Fig. 10: Screenshots of running ReTI-Debug session

# Conclusion

## Goals Reached

# Conclusion

## Goals Reached

- All features (emulator, debugger, language server) extended to cover both versions ✓

# Conclusion

## Goals Reached

- All features (emulator, debugger, language server) extended to cover both versions ✓
- Memory view allows easier monitoring and manipulation of memory ✓

# Conclusion

## Goals Reached

- All features (emulator, debugger, language server) extended to cover both versions ✓
- Memory view allows easier monitoring and manipulation of memory ✓
- Debugger and Language Server offer
  - Syntax Highlighting ✓
  - Realtime Compilation ✓
  - Code Completion Suggestions ✓
  - Executing Code and Inspecting/Manipulating ReTI State ✓

# Conclusion

## Goals Reached

- All features (emulator, debugger, language server) extended to cover both versions ✓
- Memory view allows easier monitoring and manipulation of memory ✓
- Debugger and Language Server offer
  - Syntax Highlighting ✓
  - Realtime Compilation ✓
  - Code Completion Suggestions ✓
  - Executing Code and Inspecting/Manipulating ReTI State ✓
- Extension provides familiar programming workflow and OS-independent use ✓

# Conclusion

## Limitations & Future Work

# Conclusion

## Limitations & Future Work

- Emulate UART interface

# Conclusion

## Limitations & Future Work

- Emulate UART interface
- Make debug adapter independent from VS Code (embedding in other editors/tools)

# Conclusion

## Limitations & Future Work

- Emulate UART interface
- Make debug adapter independent from VS Code (embedding in other editors/tools)
- Integrate Pico-C compiler

# Conclusion

## Limitations & Future Work

- Emulate UART interface
- Make debug adapter independent from VS Code (embedding in other editors/tools)
- Integrate Pico-C compiler
- Add datapaths visualization [3]:



Fig. 11: Screenshot of ReTI-Emulator with Datapath-Visualization [3]

# Extra: Language-Server-Protocol



Fig. 12: Example for Communication between Tool and Server in the Language-Server-Protocol [4]

# Extra: Debug-Adapter-Protocol



Fig. 13: VS Code Debug Architecture [5]

# References

- [1]: RETI-Emulator by Jürgen Mattheis, <https://github.com/matthejue/RETI-Emulator>
- [2]: Technische Informatik – Kapitel 2 – Kodierung, Prof. Dr. Armin Biere, University of Freiburg, SS 2024
- [3]: RETI-Emulator by Michel Giehl, [github.com/michel-giehl/Reti-Emulator](https://github.com/michel-giehl/Reti-Emulator)
- [4]: Microsoft *Language Server Protocol - Sequence Diagram*. Retrieved 13. July 2025, from <https://microsoft.github.io/language-server-protocol/overviews/lsp/overview/>
- [5]: Microsoft. *VS Code Debug Architecture*. Retrieved 13. July 2025, from <https://code.visualstudio.com/api/extension-guides/debugger-extension>