The SPI protocol is a shift register protocol with a possible register size of range from 8 bits to 16 bits. The communication protocol is designed to keep the size of the datagram ref less or equal to the register size. This is to ensure a simple protocol between the Tiva and FPGA which is still able to utilise the full duplex capabilities of a SPI protocol.

The communicatio protocol uses the master-slave principle with the Tiva as the master and the FPGA as the slave.

When the Tiva initialise communication Slave Enable is driven low and 1 SPI clock cycle later data will be read on rising edge from the SPI clock, as seen in figure 1.

Each datagram is 16 bits in size and the datagram format send by the Tiva can be observed in table 2 and the package format send by the FPGA can be observed in table 4. In the package format the bit number indicates the order of transmission starting with 0.

Hvordan refererer vi til Tiva

| Data       | Data type       |
|------------|-----------------|
| PWM        | 9 bit signed    |
| Position   | 12 bit signed   |
| Velocity   | 12 bit signed   |
| Amps       | 12 bit unsigned |
| Home Index | 1 bit           |

Table 1: Data types

| 0           | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9       | 10   | 11       | 12           | 13 | 14 | 15 |
|-------------|---|---|---|---|---|---|---|---|---------|------|----------|--------------|----|----|----|
| PWM - 9bits |   |   |   |   |   |   |   | M | Resp. R |      | Reserved |              |    |    |    |
|             |   |   |   |   |   |   |   |   | S       | se-  |          | $\mathbf{S}$ |    |    |    |
|             |   |   |   |   |   |   |   |   |         | lect | t        |              |    |    |    |

Table 2: Package format - Tiva

| MS              | Motor Select   |    |
|-----------------|----------------|----|
| Response select |                |    |
|                 | Position       | 00 |
|                 | Velocity       | 01 |
|                 | Acceleration   | 10 |
|                 | Amps           | 11 |
| RS              | Reset Position |    |

 Table 3: Package format extended

Table 4: Package format - FPGA

| 0  | 1 | 2 | 3 | 4           | 5 | 6 | 7 | 8 | 9 | 10   | 11  | 12 | 13 | 14 | 15 |
|----|---|---|---|-------------|---|---|---|---|---|------|-----|----|----|----|----|
| Re | S | Н | Н | I Requested |   |   |   |   |   | ed D | ata |    |    |    |    |
|    |   | S | S |             |   |   |   |   |   |      |     |    |    |    |    |
|    |   | 1 | 0 |             |   |   |   |   |   |      |     |    |    |    |    |



Figure 1: SPI timing diagram