

# 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

|                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Registers</b><br>PC: 2147483652 (-2147483644)<br>IN1: 0 (0)<br>IN2: 0 (0)<br>ACC: 2 (2)<br>SP: 2147549183 (-2147418113)<br>BAF: 2147549183 (-2147418113)<br>CS: 2147483648 (-2147483648)<br>DS: 2147483670 (-2147483626) | <b>SRAM Codesegment: PC (2147483652)</b><br>00000: ADDI PC 5<- CS<br>00001: ADDI PC 2<br>00002: LOADI ACC 2<br>00003: STORE ACC 1<br>00004: LOADI ACC 1<- PC<br>00005: STORE ACC 3<br>00006: LOADI IN1 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 | <b>SRAM Datasegment: DS (2147483670)</b><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 | <b>SRAM Stack: SP (2147549183)</b><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 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

(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



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

## 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.

**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.

# 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 keyboard shortcuts "Ctrl+Alt+E" and "Ctrl+Alt+D".

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 VS Code interface showing a file named 'testisrs.reti'. The code contains several syntax errors and warnings, such as 'IVTE command is only intended for use in isr files.' and 'Unknown instruction "STO"'. A tooltip for the 'STORE' instruction is displayed, providing its definition: 'Stores the value of the specified register into the i-th memory cell.' Other parts of the code include initialization, a loop, and various memory 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          bred 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
- Autocomplete suggestions

# Results

## Debugger and Memory View

The screenshot shows a debugger interface for the ReTI-II OS. The assembly code window displays the following pseudocode for calculating Fibonacci numbers:

```
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>
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    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+1)
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
```

The memory view shows the state of memory at address 0 and 3. The variable register pane shows the following values:

| Register | Value      |
|----------|------------|
| 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

### 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 assembly code editors from the ReTI-Tools VSCode extension. The left editor is titled 'testisrs.reti' and the right is titled 'isrs.reti'. Both editors have a toolbar at the top with icons for file operations, search, and navigation.

**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

# 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

- 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>