#### OpenRISC hardware bootloader over WiFi

Germán Cano Quiveu

Universidad de Sevilla

Departamento Tecnología Electrónica

(University of Seville - DTE)

# Background

- TIC204 : Research group, lines of work
  - Design and verification of digital integrated circuits.
  - Design of digital embedded systems
  - Design of SoC (System on Chip) on programmable devices (FPGA).
  - Design of application-specific peripherals for SoC.
  - Design of digital systems based on open hardware and software.

# General Idea



CREATE A IOT NODE THAT CAN BE UPDATED BY WIFI

#### Main Goals

- Update any code anywhere.
- Use the minimum amount of resources.
- Try to utilize a modular design.

### **Main Actors**

- SoC-OpenRISC
  - Nexys4DDR
  - Verilog
- NodeMCU
  - ESP8266: WiFi, TCP/IP
  - Arduino IDE
- Server
  - Send Binary Code
  - Python Scripts







#### NEXYS4DDR PORT

- Main Features:
  - OpenRISC(
     https://github.com/openrisc/orpsoc-cores/tree/master/systems/atlys)
  - DDR
    - MIG tool
    - Wb2axi (https://github.com/wallento/wb2axi)
  - SPI slave
  - Bootloader Module
    - Designed as fusesoc core
  - nexys4ddr\_nodemcu system for fusesoc

#### **Custom Protocol**

| n_block | total_blocks | total_bytes | data    |
|---------|--------------|-------------|---------|
| 4 bytes | 4 bytes      | 4 bytes     | X bytes |
|         |              |             |         |

#### Data packets

- n\_block : current block, 4 bytes
- total\_blocks : total number of blocks, 4 bytes
- total\_bytes: bytes in field data, 4 bytes
- Data: chunk of binary data from the code in Base64
  - Max size of 512 bytes of the original code

## SCHEMATIC



#### **Bootloader Proccess I**

- Server
  - initialize the process
- ESP8266
  - resend each packet to Bootloader Module
  - checks total\_blocks
    - If true send end signal



#### **Bootloader Proccess II**

- Bootloader Module
  - Reset the OperRISC
  - Uses a MUX to get access to the DDR
  - Write receiving packet
  - Check End Signal
  - Release MUX and reset signal



# Bootloader Module: State Machine



# Implementations Results

| -∢ H  | lierarchy                              |                 |                             |                     |                  |                         |                          |                                |                         |               |                   |
|-------|----------------------------------------|-----------------|-----------------------------|---------------------|------------------|-------------------------|--------------------------|--------------------------------|-------------------------|---------------|-------------------|
|       | Name                                   | Slice<br>LUTs ( | Slice Registers<br>(126800) | F7 Muxes<br>(31700) | Slice<br>(15850) | LUT as Logic<br>(63400) | LUT as Memory<br>(19000) | LUT Flip Flop Pairs<br>(63400) | Block RAM Tile<br>(135) | DSPs<br>(240) | Bonded I<br>(210) |
|       | Ψ- M orbsoc_tob                        | 10675           | 8042                        | 31                  | 3417             | 9940                    | 735                      | 4081                           | 26                      |               |                   |
|       |                                        | 5567            | 4764                        | 8                   | 1863             | 4849                    | 718                      | 2586                           | 0                       | -             |                   |
| %     |                                        | 3328            | 1981                        | 4                   | 1136             | 3328                    | 0                        | 799                            | 26                      |               |                   |
| 19/20 | 🍑 🔃 dbg_if0 (adbg_top)                 | 1155            | 620                         | 13                  | 465              | 1155                    | 0                        | 334                            | 0                       | _             |                   |
| X     | - 7 <u>- autri0000</u> (dant_to        |                 | 294                         | 6                   | 139              | 376                     | 16                       | 204                            | 0                       | _             |                   |
|       | 🍦 😰 boot0 (bootloader_m                |                 | 180                         | 0                   |                  | 53                      | 0                        | 7                              | 0                       |               |                   |
|       | - <b>■ counter2</b> (contado           |                 | 32                          | 0                   | 17               |                         | 0                        | 1                              | 0                       | _             |                   |
|       | -I r_total_bytes_0 (re                 | 13              | 32                          | 0                   | 9                |                         | 0                        | 0                              | 0                       |               |                   |
|       | - r_state_prev_0 (re                   | 3               | 4                           | 0                   | 2                |                         | 0                        | 0                              | 0                       | _             |                   |
|       | -a counter_1 (contad                   | 3               | 32                          | 0                   | 10               | _                       | 0                        | 1                              | 0                       | _             |                   |
|       | - counter0 (contado                    |                 | 26                          | 0                   | 8                | 2                       | 0                        | 1                              | 0                       | _             |                   |
|       | - r_block_0 (registro)                 | 1               | 18                          | 0                   | 6                | 1                       | 0                        | 0                              | 0                       |               |                   |
|       | − <b>1</b> r3 (registro_para           | 0               | 8                           | 0                   | 2                |                         | 0                        | 0                              | 0                       | _             |                   |
|       | -1 r2 (registro_para                   | 0               | 8                           | 0                   | 1                | 0                       | 0                        | 0                              | 0                       |               |                   |
|       | -1 (registro_para                      | 0               | 8                           | 0                   | 2                | _                       | 0                        | 0                              | 0                       | _             |                   |
|       | ro (registro_para                      | 0               | 8                           | 0                   | 1                | 0                       | 0                        | 0                              | 0                       |               |                   |
|       | ram_mux_5 (generic                     | 32              | 0                           | 0                   | 30               | 32                      | 0                        | 0                              | 0                       | _             |                   |
|       | wb_intercon0 (wb_int                   | 31              | 22                          | 0                   | 24               | 31                      | 0                        | 10                             | 0                       | _             |                   |
|       | itag_tap0 (tap_top)                    | 28              | 70                          | 0                   | 19               |                         | 1                        | 19                             | 0                       | _             |                   |
|       | ram_mux_6 (generic                     | 22              | 0                           | 0                   | 10               |                         | 0                        | 0                              | 0                       |               |                   |
|       | esp8266 (SPI_slave)                    | 22              | 36                          | 0                   | 12               |                         | 0                        | 16                             | 0                       | _             |                   |
|       | gpio0 (gpio)                           | 21              | 25                          | 0                   | 16<br>12         | 21                      | 0                        | 17                             | 0                       |               |                   |
| 1     | e seg7 (display)                       | 12<br>9         | 34                          | 0                   | 12               |                         | 0                        | 3                              | 0                       |               |                   |
|       | - switch0 (switch)                     | 9               | 9                           | _                   |                  | 4                       |                          | 1                              | 0                       |               |                   |
|       | - a ram_mux_7 (generic<br>- rom0 (rom) | 1               | 0                           | 0                   | 4                |                         | 0                        | 0                              | 0                       | _             |                   |
|       | • clkgen0 (design_1_cl                 | 0               | 0                           |                     | 0                |                         | 0                        | 0                              | 0                       |               |                   |

Slice LUTs: uses 0.49% of the total of orpsoc\_top. Slice Registers: uses 2.23% of the total of orpsoc\_top.

# **Future Improvements**

- Server
  - User Interface
- ESP8266
  - Secure channel
- SoC-OpenRISC
  - Rollback protocol

## **GITHUB**

**GITHUB PAGE** 

https://github.com/germancq/BOW