# **TE0320 SPI Interface**

TE0320 has a flexible SPI bus on-board as outlined in the figure below.



#### SPI bus topology.

SPI signals on the TE0320 are listed and described in the table below.

| na<br>me   | definition               | description                                                                                                                                                                                                        |  |  |  |  |  |
|------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| SPI<br>_Q  | serial<br>data<br>output | This output signal is used to transfer data serially out of the device. Data is shifted out on the falling edge of SPI_/C.                                                                                         |  |  |  |  |  |
| SPI<br>_D  | serial<br>data input     | This input signal is used to transfer data serially into the device. It receives instructions, addresses, and the data to be programmed. Values are latched on the rising edge of SPI_/C                           |  |  |  |  |  |
| SPI<br>_/C | serial<br>clock          | This input signal provides the timing of the serial interface. Instructions, addresses, or data present at SPI_D are latched on the rising edge of SPI_/C. Data on SPI_Q changes after the falling edge of SPI_/C. |  |  |  |  |  |
| SPI<br>_/S | chip<br>select           | When this input signal is <b>high</b> , the device is <b>disabled</b> and SPI_Q is at high impedance (Z).                                                                                                          |  |  |  |  |  |
|            |                          | When this input signal is <b>low</b> , the device is <b>enabled.</b>                                                                                                                                               |  |  |  |  |  |
|            |                          | After power-up, a falling edge on SPI_/S is required prior to the start of any instruction to the Flash memory.                                                                                                    |  |  |  |  |  |

SPI signal pin-out of the TE0320 is summarized in the table below.

| name   | FPGA ball | JM5 pin |  |
|--------|-----------|---------|--|
| SPI_Q  | AF24      | 18      |  |
| SPI_D  | AB15      | 12      |  |
| SPI_/C | AE24      | 22      |  |
| SPI_/S | AA7       | 20      |  |

SPI pin-out summary.

SPI pins on B2B connector JM5 cannot be used as GPIOs (general purpose I/Os).

The SPI bus can be used during configuration and operation in a plurality of ways as summarized respectively in Table A (SPI bus for configuration) and Table B (SPI bus for operation).



### SPI bus for configuration

The SPI bus is used for configuration in two ways by default:

- 1. EZ-USB â-<sup>o</sup> Flashthe USB FX2 microcontroller (master) writes the PROM file (containing the FPGA configuration bitstream) to the SPI serial Flash memory (slave)
- 2. FPGA â-, Flashthe FPGA (master) configures itself in Master SPI mode from the SPI serial Flash memory (slave).

In case (a), the FPGA shall be turned off to release its shared SPI pins.

In case (b), the USB FX2 microcontroller shall three-state (Z = high impedance) its shared SPI pins.

| description       | usage              | EZ-USB FX2LP          | FPGA                                   | B2B JM5                | serial Flash |
|-------------------|--------------------|-----------------------|----------------------------------------|------------------------|--------------|
| EZ-USB â-º Flash  | OpenFU<br>T<br>API | master                | off<br>(S2 = FX2PON,<br>FX2_PS_EN = 0) | deselected             | slave        |
| FPGA â—" Flash    | OpenFU<br>T<br>API | inactive<br>SPI_* = Z | master<br>(SPI_/S = 1)                 | deselected             | slave        |
| B2B JM5 â-º Flash | custom             | inactive<br>SPI_* = Z | off<br>(S2 = FX2PON,<br>FX2_PS_EN = 0) | master<br>(SPI_/S = 0) | slave        |

Table A: SPI bus modes for configuration.

The PROM file (containing the FPGA configuration bitstream) can be written to the SPI serial Flash memory (slave) also through the SPI pins of B2B connector JM5 (attached device set to master mode). In this case, the FPGA shall be turned off or three-stated to release its shared SPI pins and the USB FX2 microcontroller shall three-state (Z = high impedance) its shared SPI pins.

## SPI bus for operation

A plurality of usage combinations of the SPI bus during operation is made available to the user as suggested in Table B below.

description usage EZ-USB FX2LP FPGA B2B JM5 serial Flash

| EZ-USB â—"â-º Flash   | custom | master                | off<br>(S2 = FX2PON,<br>FX2_PS_EN = 0) | deselected             | slave      |
|-----------------------|--------|-----------------------|----------------------------------------|------------------------|------------|
| FPGA â—"â-º Flash     | custom | inactive<br>SPI_* = Z | master<br>(SPI_/S = 1)                 | deselected             | slave      |
| B2B JM5 â—"â-⁰ Flash  | custom | inactive<br>SPI_* = Z | off<br>(S2 = FX2PON,<br>FX2_PS_EN = 0) | master<br>(SPI_/S = 0) | slave      |
| EZ-USB â—"â-º B2B JM5 | custom | master<br>SPI_/S = 1  | off<br>(S2 = FX2PON,<br>FX2_PS_EN = 0) | slave                  | deselected |
| EZ-USB â—"â-º B2B JM5 | custom | slave<br>SPI_/C = Z   | off<br>(S2 = FX2PON,<br>FX2_PS_EN = 0) | master<br>(SPI_/S = 1) | deselected |

### Table B: SPI bus modes for operation.

① Other combinations of master and slave units are neither supported nor recommended.