



Fault Pin Straps





| Charte /Payer                       | . /              |         |
|-------------------------------------|------------------|---------|
| Sheet: /Power/                      |                  |         |
| File: ignitionlet-power.sch         |                  |         |
| Title: Powe                         | er               |         |
| Size: A3                            | Date: 2021-07-01 | Rev: 1  |
| KiCad E.D.A. kicad (5.1.10-1-10_14) |                  | ld: 2/3 |
|                                     | 7                | 8       |



## Operating Modes

- FPGA as SPI master (default)

The default operating mode for this board is with the FPGA acting as SPI master. Without anything driving SPLSS this signal is pulled high. On init (after POR or asserting CRESET) the FPGA will sample this pin. With the pin pulled high it will resume its init sequence as SPI master. Consequently it will then assert SPLSS and drive SPLSCK, allowing it to read a bitstream from SPI flash and enter the user application.

- Program the SPI flash from IGNITION\_TARGET\_HDR

The second mode is to program the SPI flash via the IGNITION\_TARGET\_HDR using an FTDI USB programmer. The programmer will assert both SPI\_RESET and SPI\_SS, causing the FPGA to go/stay in reset while selecting the SPI flash as peripheral. The programmer then writes to SPI flash as normal.

- Program the FPGA SRAM from IGNITION\_TARGET\_HDR

The FTDI programmer can program the FPGA SRAM (or NVCM) directly if the user installs a jumper on the FLASH\_RESET signal. This will cause the SPI flash to remain in reset and ignore any SPI traffic. The programmer then asserts SPLSS while toggling SPI\_RESET. This causes the FPGA to (re-)initialize, sampling the SS pin, and initialize as SPI peripheral instead of master when it finds this signal low. The programmer then writes to the FPGA as per Lattice FPGA—TN-02001-3.2.

Holding the flash in reset can potentially be automated by connecting FLASH\_RESET to an additional GPIO pin on the programming adapter and modifying the (open source) programming software to assert this pin during the programming cycle. This may already be supported in software, but is not tested.

- Program the FPGA SRAM from PMOD\_2A

In the same way as stated above the PMOD header can be used to program the FPGA SRAM from an attached Gimletlet using software running on the SP. This mode assumes the SPI flash is disabled during programming, either using the described FLASH\_RESET jumper, or by connecting the FLASH\_RESET signal to an SP GPIO using a Dupont wire, allowing flash reset to happen under software control.