

# UART→FPGA SPI-Flash ████

## 1. ████

█████ UART █ FPGA █ `firmware.bin` █ SPI Flash███████████

█████

- PC █`host/uart\_fwu.py`
- FPGA █`fpga/rtl/fw\_top.sv` █

## 2. ████

### 2.1 UART

- `uart\_rx` █FPGA █ USB-UART █ TX█
- `uart\_tx` █FPGA █ USB-UART █ RX█
- █ 3.3V TTL █

### 2.2 SPI Flash

- `spi\_cs\_n` █
- `spi\_sck` █
- `spi\_mosi` █
- `spi\_miso` █

█████ SPI █ QSPI█

## 3. FPGA ████

### 3.1 ████

████[fwu\_top.sv](file:///k:/TRAЕ/uart\_spi/fpga/rtl/fw\_top.sv)

████

- `clk` █
- `rst\_n` █
- `uart\_rx/uart\_tx`
- `spi\_cs\_n/spi\_sck/spi\_mosi/spi\_miso`

### 3.2 ████

- `CLK\_HZ` █Hz█
- `UART\_BAUD` █ `921600`
- `SPI\_CLK\_DIV` █ SPI SCK █ SCK █ `CLK\_HZ/(2\*SPI\_CLK\_DIV)` █

████50MHz █ SPI\_CLK\_DIV=4 █ SCK≈6.25MHz█

## 4. ████↔FPGA█

███████████

- 1) `HELLO` ████FPGA █ `HELLO\_RSP` █ Flash ID/███████
- 2) `START` ████/███████/███████/███████ CRC/page\_size█
- 3) `ERASE` ████ sector\_size ████
- 4) `DATA` ████offset + ████ + ████

```
5) `FINISH` + CRC32
6) `QUERY` `written_bytes` `running_crc32`

`DATA` `seq` ACK `seq` `FPGA` `seq+offset+len` DATA ACK

## 5. PC

### 5.1

```bash
python -m venv .venv
.venv\Scripts\activate
pip install -r host/requirements.txt
```

```

```
### 5.2
```

```
```bash
python -m host uart_fwu \
--port COM5 \
--baud 921600 \
--fw firmware.bin \
--base-addr 0x000000 \
--chunk 256 \
--timeout 0.2 \
--retries 8
```

```

```
```

```

```
```bash
python -m host uart_fwu --list-ports
```

```

```
```

```

```
```bash
python -m host uart_fwu --port auto --fw firmware.bin --base-addr 0x000000
```

```

```
```

```

```
- `--port` Windows `COM5`
- `--port-like` / ID `CH340` `VID:PID=1A86:7523`
- `--list-ports`
- `--baud`
- `--fw` `.bin` `.` bin` 
- `--fw-name` `--fw` `.bin` 
- `--bin` `.bin` 
- `--base-addr` Flash FPGA
- `--chunk` DATA 256
- `--timeout` ACK/
- `--retries` 

## 6. " "

```

```
### 6.1
```

## UART ■■■ SLIP ■■■■■■■■■■■■

11

| magic[2] | ver[1] | type[1] | seq[2] | len[2] | payload[len] | crc32[4] |

11

- `magic` ┌─┐0x55 0xAA
- `ver` ┌─┐0x01
- `type` ┌─┐███████
- `seq` ┌─┐16 █████
- `len` ┌─┐payload █████
- `crc32` ┌─┐ `magic..payload` ┌─┐ CRC32(IEEE)

■■■■■/■■■■■ [protocol.md](file:///k:/TRAE/uart\_spi/docs/protocol.md)■■■■■

### 6.2 SPI Flash ████SR1█

FPGA ████/██████ `RDSR(0x05)` █ SR1█

- Bit0 `WIP` ■Write In Progress■1=■■0=■■
- Bit1 `WEL` ■Write Enable Latch■1=■■■■■

Flash WIP/WEL

### 6.3 Flash ■■■■

- `RDID(0x9F)` ████ 3 █ ID
- `WREN(0x06)` ████
- `SE(0x20)` █4KB ████ Flash █ 64KB ████ `0xD8` ███ sector\_size█
- `PP(0x02)` ████
- `RDSR(0x05)` ████

## 7. Flash

Flash

- `base\_addr`
- [REDACTED]/[REDACTED]/CRC

## 8.

- ACK ████ UART ███`--timeout`
- Flash ███ `SE/PP` ███ Flash ███ `sector\_size` ███