

# Serial Peripheral Interface (SPI) Slave

2.20

### **Features**

- 3- to 16-bit data width
- Four SPI modes
- Bit rate up to 5 Mbps<sup>1</sup>



# **General Description**

The SPI Slave provides an industry-standard, 4-wire slave SPI interface. It can also provide a 3-wire (bidirectional) SPI interface. Both interfaces support all four SPI operating modes, allowing communication with any SPI master device. In addition to the standard 8-bit word length, the SPI Slave supports a configurable 3- to 16-bit word length for communicating with nonstandard SPI word lengths.

SPI signals include the standard Serial Clock (SCLK), Master In Slave Out (MISO), Master Out Slave In (MOSI), bidirectional Serial Data (SDAT), and Slave Select (SS).

#### When to Use the SPI Slave

You can use the SPI Slave component any time a PSoC device is required to interface with an SPI Master device. In addition to SPI Master labeled devices, you can use the SPI Slave with many devices implementing a shift register type interface.

Use the SPI Master component in instances requiring a PSoC device to communicate with an SPI Slave device. Use the Shift Register component in situations where its low-level flexibility provides hardware capabilities not available in the SPI Slave component.

<sup>&</sup>lt;sup>1</sup> This value is valid only for MOSI+MISO (Full Duplex) interfacing mode (see the DC and AC Electrical Characteristics section for details) and is restricted up to 1 Mbps in Bidirectional mode because of internal bidirectional pin constraints.

# **Input/Output Connections**

This section describes the various input and output connections for the SPI. An asterisk (\*) in the list of I/Os indicates that the I/O may be hidden on the symbol under the conditions listed in the description of that I/O.

### mosi - Input \*

The mosi input carries the Master Output Slave Input (MOSI) signal from a master device. This input is visible when the **Data Lines** parameter is set to "MOSI + MISO." If visible, this input must be connected.

#### sdat - Inout \*

The sdat inout carries the Serial Data (SDAT) signal. This input is used when the **Data Lines** parameter is set to **Bidirectional**. For both PSoC 3 and PSoC 5 silicon an asynchronous clock crossing warning will be reported between the component clock and the SCLK signal when timing analysis is performed. The following is an example of such a message: "Path(s) exist between clocks IntClock and SCLK(0)\_PAD, but the clocks are not synchronous to each other." This message applies to a path from the register that controls the direction and the sampling of data by SCLK. SCLK should not be running when the direction is being changed. As long as this rule is followed, there is no problem and you can ignore this message.

Figure 1. SPI Bidirectional Mode (data transmission from Master to Slave)





Page 2 of 37 Document Number: 001-68058 Rev. \*A

SPI Master SPI Slave yfb yfb SDAT Tx Shift Register Tx Shift Register ENB ENB Rx Shift Register Rx Shift Register "O" oe SCLK SS Internal loopback

Figure 2. SPI Bidirectional Mode (data transmission from Slave to Master)

## sclk-Input

The sclk input carries the Serial Clock (SCLK) signal. It provides the slave synchronization clock input to the device. This input is always visible and must be connected.

**Note** Some SPI Master devices (such as the TotalPhase Aardvark I2C/SPI host adapter) drive the sclk output in a specific way. For the SPI Slave component to function properly with such devices in modes 1 and 3 (when CPOL = 1), the sclk pin should be set to resistive pull-up drive mode. Otherwise, it puts out corrupted data. See the Functional Description section for more information about modes.

## ss - Input

The ss input carries the Slave Select (SS) signal to the device. This input is always visible and must be connected.

The following diagrams show the timing correlation between SCLK and SS signals CPHA = 0:





Document Number: 001-68058 Rev. \*A

**Note** The SS timing shown in these diagrams is valid for the PSoC Creator SPI Master. Generally, 0.5 of the SCLK period is enough delay between the SS negative edge and the first SCLK edge for the SPI Slave to work correctly in all supported bit-rate ranges.

### reset - Input

The reset input resets the SPI Slave. It deletes any data that was currently being transmitted or received, but does not clear data from the FIFO that has already been received or is ready to be transmitted. PSoC 5 and PSoC 3 ES2 silicon do not support this reset functionality, so this input is ignored when used with those devices. Use of the reset input results in an asynchronous clock crossing warning being reported between the clock that generates the Reset input and the SCLK signal when timing analysis is performed. The following is an example of such a message: "Path(s) exist between clocks BUS\_CLK and SCLK(0)\_PAD, but the clocks are not synchronous to each other." This message applies to a path from the Reset signal to the operation of the SPI component clocked by SCLK. SCLK should not be running when the Reset signal is changed. As long as this rule is followed, there is no problem and you can ignore this message.

The reset input may be left floating with no external connection. If nothing is connected to the reset line the component will assign it a constant logic 0.

### clock - Input \*

The clock input defines the sampling rate of the status register. All data clocking happens on the sclk input, so the clock input does **not** handle the bit-rate of the SPI Slave.

The clock input is visible when the **Clock Selection** parameter is set to **External**. If visible, this input must be connected.

## miso - Output \*

The miso output carries the Master In Slave Out (MISO) signal to the master device on the bus. This output is visible when the **Data Lines** parameter is set to **MOSI + MISO**.

## interrupt - Output

The interrupt output is the logical OR of the group of possible interrupt sources. This signal goes high while any of the enabled interrupt sources are true.

## **Schematic Macro Information**

By default, the PSoC Creator Component Catalog contains Schematic Macro implementations for the SPI Slave component. These macros contain already connected and adjusted input and output pins and clock source. Schematic Macros are available for 4-wire (Full Duplex), 3-wire (Bidirectional), and Full Duplex Multislave SPI interfacing.

Figure 3. 4-wire (Full Duplex) Interfacing Schematic Macro



Figure 4. 3-wire (Bidirectional) Interfacing Schematic Macro



Figure 5. Multislave Mode Schematic Macro

**Note** If you do not use a Schematic Macro, configure the Pins component to deselect the **Input Synchronized** parameter for each of your assigned input pins (MOSI, SCLK and SS). The parameter is located under the **Pins > Input** tab of the applicable Pins Configure dialog.



Document Number: 001-68058 Rev. \*A

# **Component Parameters**

Drag an SPI Slave component onto the design. Double click the component symbol to open the **Configure** dialog.

The following sections describe the SPI Slave parameters, and how they are configured using the Configure dialog. They also indicate whether the options are hardware or software.

## **Hardware vs. Software Options**

Hardware configuration options change the way the project is synthesized and placed in the hardware. You must rebuild the hardware if you make changes to any of these options. Software configuration options do not affect synthesis or placement. When setting these parameters before build time you are setting their initial value, which may be modified at any time with the provided APIs. Hardware-only parameters are marked with an asterisk (\*).

## **Configure Tab**

The **Configure** tab contains basic parameters required for every SPI component.



**Note** The sample signal in the waveform is not an input or output of the system; it simply indicates when the data is sampled at the master and slave for the mode settings selected.

#### Mode \*

The **Mode** parameter defines the desired clock phase and clock polarity mode used in the communication. The options are **Mode 0** (default), **Mode 1**, **Mode 2**, and **Mode 3**. These modes are defined in the following table. Refer also to the Functional Description section of this datasheet.

| Mode | СРНА | CPOL |
|------|------|------|
| 0    | 0    | 0    |
| 1    | 0    | 1    |
| 2    | 1    | 0    |
| 3    | 1    | 1    |

#### **Data Lines**

The **Data Lines** parameter defines which interface is used for SPI communication – 4-wire (**MOSI + MISO**) or 3-wire (**Bidirectional**).

#### Data Bits \*

The number of **Data Bits** defines the bit-width of a single transfer as transferred with the SPIS\_ReadRxData() and SPIS\_WriteTxData() APIs. The default number of bits is a single byte (8 bits). Any integer from 3 to 16 is a valid value.

#### **Shift Direction \***

The **Shift Direction** parameter defines the direction the serial data is transmitted. When set to **MSB First**, the most significant bit is transmitted first. This is implemented by shifting the data left. When set to **LSB First**, the least significant bit is transmitted first. This is implemented by shifting the data right.

#### Bit Rate \*

If the Clock Selection parameter (on the Advanced tab) is set to Internal Clock, the Bit Rate parameter defines the SCLK speed in Hertz. The clock frequency of the internal clock is 2x the SCLK rate. This parameter has no effect if the Clock Selection parameter is set to External Clock.

Document Number: 001-68058 Rev. \*A Page 7 of 37

#### Advanced Tab



#### **Clock Selection**

The **Clock Selection** parameter specifies whether to use an internal clock or external clock. Refer to the Clock Selection section later in this datasheet for more information.

#### Rx Buffer Size \*

The **Rx Buffer Size** parameter defines the size (in bytes/words) of memory allocated for a circular data buffer. If this parameter is set to 1 to 4, the fourth byte/word of the FIFO is implemented in the hardware. Values 1 to 3 are available only for compatibility with previous versions; using them causes an error message saying that the value is incorrect. All other values up to 255 use the 4-byte/word FIFO and a memory array controlled by the supplied API.

#### Tx Buffer Size \*

The **Tx Buffer Size** parameter defines the size (in bytes/words) of memory allocated for a circular data buffer. If this parameter is set to 1 to 4, the fourth byte/word of FIFO is implemented in the hardware. Values 1 to 3 are available only for compatibility with previous versions; setting them causes an error message saying that the value is incorrect. All other values up to 255 use the 4-byte/word FIFO and a memory array controlled by the supplied API.



### **Enable Tx/Rx Internal Interrupt**

The **Enable Tx/Rx Internal Interrupt** options allow you to use the predefined Tx and Rx ISRs of the SPI Slave component, or supply your own custom ISRs. If these options are enabled, you may add your own code to these predefined ISRs if small changes are required. If the internal interrupt is deselected, you may supply an external interrupt component with custom code connected to the interrupt outputs of the SPI Slave.

If the Rx or Tx buffer size is greater than 4, the component automatically sets the appropriate parameters, as the internal ISR is needed to handle the transfer of data from the hardware FIFO to the Rx or Tx buffer, or both. The interrupt output pins of the SPI Slave are always visible and usable, outputting the same signal that goes to the internal interrupt. This output can then be used as a DMA request source or as a digital signal to be used as required in the programmable digital system.

#### Notes:

- When Rx buffer size is greater than 4 bytes/words, the 'Rx FIFO NOT EMPTY' interrupt is always enabled and cannot be disabled, because it causes incorrect buffer functionality.
- When Tx buffer size is greater than 4 bytes/words, the 'Tx FIFO NOT FULL' interrupt is always enabled and cannot be disabled, because it causes incorrect buffer functionality.
- For buffer sizes greater than 4 bytes/words, the global interrupt and component's interrupt must be enabled for proper buffer handling.

### Interrupts

The **Interrupts** selection parameters allow you to configure the internal events that are enabled to cause an interrupt. Interrupt generation is a masked OR of all of the enabled Tx and Rx status register bits. The bits chosen with these parameters define the mask implemented with the initial component configuration.

#### **Enable Multi-Slave mode**

This setting is used when the current SPI Slave component is connected to the shared bus with other SPI Slave devices. The MISO\_OE output becomes visible on the component symbol. The external BUF\_OE component should be connected to the MISO output in this mode. This mode allows you to turn MISO output to a high-impedance state when SS line is high. The multi-slave mode macro can be used to provide all necessary connections quickly.

#### **Enable Fixed Placement**

This setting is used to improve SPI Slave component performance in comparison with unconstrained placement. Fixed placement offers a single placement for a component. This means that only one instance of a component can be used in a single design. Placement of the pins connected to the component is not controlled, but it is preferable to use pins from P[0] to achieve the best performance.



Document Number: 001-68058 Rev. \*A Page 9 of 37

The fixed placement aspect of the component removes the variability that is accounted for with the "Maximum with All Routing" case (see DC and AC Electrical Characteristics for details). It also allows the fixed placement to continue to operate the same as a non-fixed placed design would in a fairly empty design.

## **Clock Selection**

When the internal clock configuration is selected, PSoC Creator calculates the required frequency and clock source, and generates the clocking resource needed for implementation. Otherwise, you must supply the clock component and calculate the required clock frequency. That frequency is, at a minimum, 2x the maximum bit-rate and SCLK frequency.

**Note** When setting the bit-rate or external clock frequency value, make sure that this value can be provided by PSoC Creator using the current system clock frequency. Otherwise, a warning about the clock accuracy range will be generated while building the project. This warning contains the real clock value set by PSoC Creator. Choose whether the system clock or component clock should be changed to fit the clocking system requirements and achieve an optimal value.

## **Placement**

The SPI Slave component is placed into the UDB array and all placement information is provided to the API through the *cyfitter.h* file.

## Resources

|                                        |                   |                | Digital Blo     | API Memory<br>(Bytes) |                               |       |     |                            |
|----------------------------------------|-------------------|----------------|-----------------|-----------------------|-------------------------------|-------|-----|----------------------------|
| Configuration                          | Datapath<br>Cells | Macro<br>cells | Status<br>Cells | Sync Cells            | Control/<br>Counter7<br>Cells | Flash | RAM | Pins (per<br>External I/O) |
| SPI Slave<br>8-bit<br>(MOSI+MISO)      | 1                 | 15             | 2               | 3                     | 1                             | 1436  | 30  | 7                          |
| SPI Slave<br>8-bit<br>(Bidirectional)  | 1                 | 17             | 2               | 3                     | 1                             | 1436  | 30  | 6                          |
| SPI Slave<br>16-bit<br>(MOSI+MISO)     | 2                 | 15             | 2               | 3                     | 1                             | 1571  | 38  | 7                          |
| SPI Slave<br>16-bit<br>(Bidirectional) | 2                 | 17             | 2               | 3                     | 1                             | 1571  | 38  | 6                          |



Page 10 of 37 Document Number: 001-68058 Rev. \*A

|                                                            | Digital Blocks    |                |                 |            |                               |       | Memory<br>Sytes) |                            |
|------------------------------------------------------------|-------------------|----------------|-----------------|------------|-------------------------------|-------|------------------|----------------------------|
| Configuration                                              | Datapath<br>Cells | Macro<br>cells | Status<br>Cells | Sync Cells | Control/<br>Counter7<br>Cells | Flash | RAM              | Pins (per<br>External I/O) |
| SPI Slave<br>8-bit<br>(MOSI+MISO,<br>Multislave Mode)      | 1                 | 15             | 2               | 3          | 1                             | 1436  | 30               | 8                          |
| SPI Slave<br>8-bit<br>(Bidirectional,<br>Multislave Mode)  | 1                 | 17             | 2               | 3          | 1                             | 1436  | 30               | 7                          |
| SPI Slave<br>16-bit<br>(MOSI+MISO,<br>Multislave Mode)     | 2                 | 15             | 2               | 3          | 1                             | 1571  | 38               | 8                          |
| SPI Slave<br>16-bit<br>(Bidirectional,<br>Multislave Mode) | 2                 | 17             | 2               | 3          | 1                             | 1571  | 38               | 7                          |

# **Application Programming Interface**

Application Programming Interface (API) routines allow you to configure the component using software. The following table lists and describes the interface to each function. The subsequent sections cover each function in more detail.

By default, PSoC Creator assigns the instance name "SPIS\_1" to the first instance of a component in a given design. You can rename the instance to any unique value that follows the syntactic rules for identifiers. The instance name becomes the prefix of every global function name, variable, and constant symbol. For readability, the instance name used in the following table is "SPIS."

| Function            | Description                                                                                         |
|---------------------|-----------------------------------------------------------------------------------------------------|
| SPIS_Start()        | Calls both SPIS_Init() and SPIS_Enable(). Should be called the first time the component is started. |
| SPIS_Stop()         | Disables SPIS operation.                                                                            |
| SPIS_EnableTxInt()  | Enables the internal Tx interrupt irq.                                                              |
| SPIS_EnableRxInt()  | Enables the internal Rx interrupt irq.                                                              |
| SPIS_DisableTxInt() | Disables the internal Tx interrupt irq.                                                             |
| SPIS_DisableRxInt() | Disables the internal Rx interrupt irq.                                                             |



Document Number: 001-68058 Rev. \*A Page 11 of 37

| Function                  | Description                                                                                         |
|---------------------------|-----------------------------------------------------------------------------------------------------|
| SPIS_SetTxInterruptMode() | Configures the Tx interrupt sources enabled.                                                        |
| SPIS_SetRxInterruptMode() | Configures the Rx interrupt sources enabled.                                                        |
| SPIS_ReadTxStatus()       | Returns the current state of the Tx status register.                                                |
| SPIS_ReadRxStatus()       | Returns the current state of the Rx status register.                                                |
| SPIS_WriteTxData()        | Places a byte/word in the transmit buffer that will be sent at the next available bus time.         |
| SPIS_WriteTxDataZero()    | Places a byte/word in the shift register directly. This is required for SPI Modes 00 and 01.        |
| SPIS_ReadRxData()         | Returns the next byte/word of received data available in the receive buffer.                        |
| SPIS_GetRxBufferSize()    | Returns the size (in bytes/words) of received data in the Rx memory buffer.                         |
| SPIS_GetTxBufferSize()    | Returns the size (in bytes/words) of data waiting to transmit in the Tx memory buffer.              |
| SPIS_ClearRxBuffer()      | Clears the Rx buffer memory array and Rx FIFO of all received data.                                 |
| SPIS_ClearTxBuffer()      | Clears the Tx buffer memory array and Tx FIFO of all transmit data.                                 |
| SPIS_TxEnable()           | If configured for bidirectional mode, sets the SDAT inout to transmit.                              |
| SPIS_TxDisable()          | If configured for bidirectional mode, sets the SDAT inout to receive.                               |
| SPIS_PutArray()           | Places an array of data into the transmit buffer.                                                   |
| SPIS_ClearFIFO()          | Clears any received data from the Rx hardware FIFO.                                                 |
| SPIS_Sleep()              | Prepares SPIS component for low-power modes by calling SPIS_SaveConfig() and SPIS_Stop() functions. |
| SPIS_Wakeup()             | Restores and re-enables the SPIS component after waking from low-power mode.                        |
| SPIS_Init()               | Initializes and restores the default SPIS configuration.                                            |
| SPIS_Enable()             | Enables the SPIS to start operation.                                                                |
| SPIS_SaveConfig()         | Saves SPIS hardware configuration.                                                                  |
| SPIS_RestoreConfig()      | Restores SPIS hardware configuration.                                                               |

## **Global Variables**

| Function           | Description                                                                                                                                                                                                                                                                       |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPIS_initVar       | SPIS_initVar indicates whether the SPI Slave component has been initialized. The variable is initialized to 0 and set to 1 the first time SPIS_Start() is called. This allows the component to restart without reinitialization after the first call to the SPIS_Start() routine. |
|                    | If reinitialization of the component is required, then the SPIS_Init() function can be called before the SPIS_Start() or SPIS_Enable() function.                                                                                                                                  |
| SPIS_txBufferWrite | Transmit buffer location of the last data written into the buffer by the API.                                                                                                                                                                                                     |



Page 12 of 37 Document Number: 001-68058 Rev. \*A

| Function           | Description                                                                                       |
|--------------------|---------------------------------------------------------------------------------------------------|
| SPIS_txBufferRead  | Transmit buffer location of the last data read from the buffer and transmitted by SPIS hardware.  |
| SPIS_rxBufferWrite | Receive buffer location of the last data written into the buffer after received by SPIS hardware. |
| SPIS_rxBufferRead  | Receive buffer location of the last data read from the buffer by the API.                         |
| SPIS_rxBufferFull  | Indicates the software buffer has overflowed.                                                     |
| SPIS_RXBUFFER[]    | Used to store received data.                                                                      |
| SPIS_TXBUFFER[]    | Used to store data for sending.                                                                   |

## void SPIS\_Start(void)

**Description:** This is the preferred method to begin component operation. SPIS\_Start() sets the initVar

variable, calls the SPIS\_Init() function, and then calls the SPIS\_Enable() function.

Parameters: None
Return Value: None
Side Effects: None

## void SPIS\_Stop(void)

**Description:** Disables the SPI Slave component interrupts. Has no affect on the SPIS operation.

Parameters: None
Return Value: None
Side Effects: None

# void SPIS\_EnableTxInt(void)

**Description:** Enables the internal Tx interrupt irq.



## void SPIS\_EnableRxInt(void)

**Description:** Enables the internal Rx interrupt irq.

Parameters: None
Return Value: None
Side Effects: None

## void SPIS\_DisableTxInt(void)

**Description:** Disables the internal Tx interrupt irq

Parameters: None
Return Value: None
Side Effects: None

## void SPIS\_DisableRxInt(void)

**Description:** Disables the internal Rx interrupt irq

Parameters: None
Return Value: None
Side Effects: None

## void SPIS\_SetTxInterruptMode(uint8 intSrc)

**Description:** Configures the Tx interrupt sources that are enabled. **Parameters:** uint8 intSrc: Bit field containing the interrupts to enable.

| Bit                       | Description                                |
|---------------------------|--------------------------------------------|
| SPIS_STS_SPI_DONE         | Enable interrupt due to SPI done           |
| SPIS_STS_TX_FIFO_EMPTY    | Enable interrupt due to Tx FIFO empty      |
| SPIS_STS_TX_FIFO_NOT_FULL | Enable interrupt due to Tx FIFO not full   |
| SPIS_STS_BYTE_COMPLETE    | Enable interrupt due to byte/word complete |

Based on the bit-field arrangement of the Tx status register. This value must be a combination of Tx status register bit-masks defined in the header file.

For more information, refer to the Defines section in this datasheet.

Return Value: None
Side Effects: None



Page 14 of 37 Document Number: 001-68058 Rev. \*A

## void SPIS\_SetRxInterruptMode(uint8 intSrc)

**Description:** Configures the Rx interrupt sources that are enabled. **Parameters:** uint8 intSrc: Bit field containing the interrupts to enable.

| Bit                        | Description                               |
|----------------------------|-------------------------------------------|
| SPIS_STS_RX_FIFO_EMPTY     | Enable interrupt due to Rx FIFO empty     |
| SPIS_STS_RX_FIFO_NOT_EMPTY | Enable interrupt due to Rx FIFO not empty |
| SPIS_STS_RX_FIFO_OVERRUN   | Enable interrupt due to Rx Buf overrun    |
| SPIS_STS_RX_FIFO_FULL      | Enable interrupt due to Rx FIFO full      |

Based on the bit-field arrangement of the Rx status register. This value must be a combination of Rx status register bit-masks defined in the header file.

For more information, refer to the Defines section in this datasheet.

Return Value: None
Side Effects: None

## uint8 SPIS\_ReadTxStatus(void)

**Description:** Returns the current state of the Tx status register. For more information, see the Status

Register Bits section of this datasheet.

Parameters: None

Return Value: uint8: Current Tx status register value

| Bit                       | Description        |
|---------------------------|--------------------|
| SPIS_STS_SPI_DONE         | SPI done           |
| SPIS_STS_TX_FIFO_EMPTY    | TX FIFO empty      |
| SPIS_STS_TX_FIFO_NOT_FULL | TX FIFO not full   |
| SPIS_STS_BYTE_COMPLETE    | Byte/Word complete |

**Side Effects:** Tx status register bits are clear on read.

Document Number: 001-68058 Rev. \*A Page 15 of 37

### uint8 SPIS\_ReadRxStatus(void)

**Description:** Returns the current state of the Rx status register. For more information see the Status

Register Bits section of this datasheet.

Parameters: None

Return Value: uint8: Current Rx status register value

| Bit                        | Description       |
|----------------------------|-------------------|
| SPIS_STS_RX_FIFO_EMPTY     | Rx FIFO empty     |
| SPIS_STS_RX_FIFO_NOT_EMPTY | Rx FIFO not empty |
| SPIS_STS_RX_FIFO_OVERRUN   | Rx Buf overrun    |
| SPIS_STS_RX_FIFO_FULL      | Rx FIFO full      |

**Side Effects:** Rx status register bits are clear on read.

## void SPIS\_WriteTxData(uint8/uint16 txData)

**Description:** Places a byte in the transmit buffer which will be sent at the next available bus time.

Parameters: uint8/uint16: txData: The data value to send across the SPI

Return Value: None

Side Effects: Data may be placed in the memory buffer and will not be transmitted until all other previous

data has been transmitted. This function blocks until there is space in the output memory

buffer.

Clears the Tx status register of the component.

## void SPIS\_WriteTxDataZero(uint8/uint16 txData)

**Description:** Places a byte/word directly into the shift register for transmission. This byte/word will be sent

from the master device during the next clock phase.

Parameters: uint8/uint16: txData: The data value to send across the SPI

Return Value: None

Side Effects: Required for Modes 0 and 1 (CPHA == 0) where data must be in the shift register before the

first clock edge. Firmware must control this if there is already data being shifted out and if there is more data in the FIFO. This routine should not to be used for Mode 2 or Mode 3

where CPHA == 1.



## uint8/uint16 SPIS\_ReadRxData(void)

**Description:** Reads the next byte of data received across the SPI.

Parameters: None

Return Value: uint8/uint16: The next byte/word of data read from the FIFO

Side Effects: Will return invalid data if the FIFO is empty. Call SPIS GetRxBufferSize() and if it returns a

nonzero value then it is safe to call the SPIS ReadRxData() function.

### uint8 SPIS GetRxBufferSize(void)

**Description:** Returns the number of bytes/words of received data currently held in the Rx buffer.

If the Rx software buffer is disabled, this function returns 0 = FIFO empty or 1 = FIFO not empty.

If the Rx software buffer is enabled, this function returns the size of data in the Rx software buffer. FIFO data not included in this count.

Parameters: None

**Return Value:** uint8: Integer count of the number of bytes/words in the Rx buffer.

**Side Effects:** Clears the Rx status register of the component.

## uint8 SPIS\_GetTxBufferSize(void)

**Description:** Returns the number of bytes/words of data ready to transmit currently held in the Tx buffer.

■ If Tx software buffer is disabled, this function returns 0 = FIFO empty, 1 = FIFO not full, or 4 = FIFO full.

If the Tx software buffer is enabled, this function returns the size of data in the Tx software buffer. FIFO data not included in this count.

Parameters: None

Return Value: uint8: Integer count of the number of bytes/words in the Tx buffer

**Side Effects:** Clears the Tx status register of the component.

## void SPIS\_ClearRxBuffer(void)

**Description:** Clears the Rx buffer memory array of data waiting to transmit. Clears the Rx RAM buffer by

setting both the read and write pointers to zero. Setting the pointers to zero indicates that there is no data to transmit. Thus, writing will resume at address 0, overwriting any data that

may have remained in the RAM.

Parameters: None Return Value: None

Side Effects: Any received data not read from the RAM buffer and FIFO will be lost when overwritten by

new data.

## void SPIS\_ClearTxBuffer(void)

**Description:** Clears the memory array of all transmit data. Clears the Tx RAM buffer by setting the read

and write pointers both to zero. Setting the pointers to zero makes the system believe there is no data to read, Thus, writing will resume at address 0, overwriting any data that may have

remained in the RAM.

Parameters: None Return Value: None

Side Effects: Will not clear data already placed in the Tx FIFO. Any data not yet transmitted from the RAM

buffer will be lost when overwritten by new data.

## void SPIS\_TxEnable(void)

**Description:** If the SPI Slave is configured to use a single bidirectional pin, this will set the bidirectional pin

to transmit.

Parameters: None
Return Value: None
Side Effects: None

## void SPIS\_TxDisable(void)

**Description:** If the SPI Slave is configured to use a single bidirectional pin, this will set the bidirectional pin

to receive.



### void SPIS PutArray(uint8/uint16 \*buffer, uint8 byteCount)

**Description:** Writes available data from RAM/ROM to the Tx buffer while space is available. Keep trying

until all data is passed to the Tx buffer. If using Mode 00 or 01, call the

SPIS\_WriteTxDataZero() function before calling the SPIS\_PutArray() function.

Parameters: uint8/uint16 \*buffer: Pointer to the location in RAM containing the data to be sent

uint8 byteCount: The number of bytes/words to move to the transmit buffer

Return Value: None

Side Effects: The system will stay in this function until all data has been transmitted to the buffer. This

function is blocking if there is not enough room in the Tx buffer. It may get locked in this loop

if data is not being transmitted by the Slave and the Tx buffer is full.

### void SPIS\_ClearFIFO(void)

**Description:** Clears any received data from the Rx FIFO.

Parameters: None Return Value: None

**Side Effects:** Clears the status register of the component.

## void SPIS\_Sleep(void)

**Description:** This is the preferred routine to prepare the component for low-power modes. The

SPIS Sleep() routine saves the current component state. Then it calls the SPIS Stop()

function and calls SPIS SaveConfig() to save the hardware configuration.

Call the SPIS\_Sleep() function before calling the CyPmSleep() or the CyPmHibernate() function. Refer to the PSoC Creator *System Reference Guide* for more information about

power management functions.



### void SPIS Wakeup(void)

**Description:** This is the preferred routine to restore the component to the state when SPIS\_Sleep() was

called. The SPIS\_Wakeup() function calls the SPIS\_RestoreConfig() function to restore the configuration. If the component was enabled before the SPIS\_Sleep() function was called, the SPIS\_Wakeup() function will also re-enable the component. Clears all data from Rx

buffer, Tx buffer, and hardware FIFOs.

Parameters: None Return Value: None

Side Effects: Calling the SPIS\_Wakeup() function without first calling the SPIS\_Sleep() or

SPIS\_SaveConfig() function may produce unexpected behavior.

### void SPIS\_Init(void)

**Description:** Initializes or restores the component according to the customizer Configure dialog settings. It

is not necessary to call SPIS Init() because the SPIS Start() routine calls this function and is

the preferred method to begin component operation.

Parameters: None Return Value: None

**Side Effects:** When this function is called, it initializes all of the necessary parameters for execution. These

include setting the initial interrupt mask, configuring the interrupt service routine, configuring

the bit-counter parameters and clearing the FIFO and Status Register.

## void SPIS\_Enable(void)

**Description:** Enables SPIS to start operation. Starts the internal clock if so configured. If an external clock

is configured it must be started separately before calling this API. The SPIS\_Enable() function should be called before SPIS interrupts are enabled. This is because this function configures the interrupt sources and clears any pending interrupts from device configuration, and then enables the internal interrupts if so configured. A SPIS\_Init() function must have

been previously called.



## void SPIS\_SaveConfig(void)

**Description:** This function saves the component configuration and nonretention registers. It also saves the

current component parameter values, as defined in the Configure dialog or as modified by

appropriate APIs. This function is called by the SPIS\_Sleep() function.

Parameters: None
Return Value: None
Side Effects: None

## void SPIS\_RestoreConfig(void)

**Description:** Restores SPIS hardware configuration saved by the SPIS\_SaveConfig() function after

waking from a lower-power mode.

Parameters: None Return Value: None

Side Effects: If this function is called without first calling SPIS\_SaveConfig() then in the following registers

will be default values from the Configure dialog:

SPIS\_STATUS\_MASK\_REG SPIS COUNTER PERIOD REG

### **Defines**

### SPIS\_TX\_INIT\_INTERRUPTS\_MASK

Defines the initial configuration of the interrupt sources chosen in the Configure dialog. This is a mask of the bits in the Tx status register that have been enabled at configuration as sources for the interrupt. Refer to the Status Register Bits section for bit-field details.

## SPIS\_RX\_INIT\_INTERRUPTS\_MASK

Defines the initial configuration of the interrupt sources chosen in the Configure dialog. This is a mask of the bits in the Rx status register that have been enabled at configuration as sources for the interrupt. Refer to the Status Register Bits section for bit-field details.



## **Status Register Bits**

#### SPIS TXSTATUS

| Bits  | 7         | 6                     | 5      | 4      | 3      | 2                | 1                    | 0        |
|-------|-----------|-----------------------|--------|--------|--------|------------------|----------------------|----------|
| Value | Interrupt | Byte/Word<br>Complete | Unused | Unused | Unused | Tx FIFO<br>Empty | Tx FIFO.<br>Not Full | SPI Done |

#### SPIS RXSTATUS

| Bits  | 7         | 6               | 5                  | 4                | 3                    | 2      | 1      | 0      |
|-------|-----------|-----------------|--------------------|------------------|----------------------|--------|--------|--------|
| Value | Interrupt | Rx FIFO<br>Full | Rx Buf.<br>Overrun | Rx FIFO<br>Empty | Rx FIFO<br>Not Empty | Unused | Unused | Unused |

- Byte/Word Complete: Set when a byte/word transmit has completed.
- Rx FIFO Overrun: Set when Rx Data has overrun the 4-byte/word FIFO without being moved to the Rx buffer memory array (if one exists)
- Rx FIFO Full: Set when the Rx Data FIFO is full (does not indicate the Rx buffer RAM array conditions).
- Rx FIFO Empty: Set when the Rx Data FIFO is empty (does not indicate the Rx buffer RAM array conditions).
- Rx FIFO Not Empty: Set when the Rx Data FIFO is not empty. That is, at least one byte/word is in the Rx FIFO (does not indicate the Rx buffer RAM array conditions).
- Tx FIFO Empty: Set when the Tx Data FIFO is empty (does not indicate the Tx buffer RAM array conditions).
- Tx FIFO Not Full: Set when the Tx Data FIFO is not full (does not indicate the Tx buffer RAM array conditions).
- SPI Done: Set when all of the data in the transmit FIFO has been sent. This may be used to signal a transfer complete instead of using the byte/word complete status. (Set when Byte/Word Complete has been set and Tx Data FIFO is empty.)

### SPIS\_TXBUFFERSIZE

Defines the amount of memory to allocate for the Tx memory array buffer. This does not include the four bytes/words included in the FIFO. If this value is greater than 4, interrupts are implemented that automatically move data to the FIFO from the circular memory buffer.



### SPIS\_RXBUFFERSIZE

Defines the amount of memory to allocate for the Rx memory array buffer. This does not include the four bytes/words included in the FIFO. If this value is greater than 4, interrupts are implemented that automatically move data from the FIFO to the circular memory buffer.

### SPIS DATAWIDTH

Defines the number of bits per data transfer chosen in the Configure dialog.

### **Sample Firmware Source Code**

PSoC Creator provides many example projects that include schematics and example code in the Find Example Project dialog. For component-specific examples, open the dialog from the Component Catalog or an instance of the component in a schematic. For general examples, open the dialog from the Start Page or **File** menu. As needed, use the **Filter Options** in the dialog to narrow the list of projects available to select.

Refer to the "Find Example Project" topic in the PSoC Creator Help for more information.

# **Functional Description**

## **Default Configuration**

The default configuration for the SPIS is as an 8-bit SPIS with Mode 0 configuration.

#### **Modes**

Modes control the component's status bits and the component signal values that are assumed during data transmission. Four waveforms are shown. It is assumed that five data bytes are transmitted (four bytes are written to the SPI Slave's Tx buffer at the beginning of transmission and a fifth is thrown after the first byte has been loaded into the A0 register). Numbers in circles represent the following events (see the following waveforms):

- 1 Tx FIFO Empty has being cleared when four bytes are written to the Tx buffer;
- 2 Tx FIFO Not Full has been cleared because Tx FIFO is full after 4 bytes written;
- 3 Tx FIFO Not Full status is set when the first byte has been loaded into the A0 register and is cleared after the fifth byte has been written to the free place in the Tx buffer.
- 4 The Slave Select line is set to Low, indicating the beginning of the transmission.
- 5 Tx FIFO Not Full status is set when the second bit is loaded to the A0 register. Rx Not Empty status is set when the first received byte has been loaded into the Rx buffer. Byte/Word Complete is set as well.
- 6 Tx FIFO Empty status is set at the moment when the last byte to be sent has been loaded into the A0 register. This is not shown in the waveform details for simplification.



Document Number: 001-68058 Rev. \*A Page 23 of 37

- 7 The moment when the fourth byte has been received so Rx FIFO Full is set along with Byte/Word Complete.
- 8 Byte/Word Complete, SPI Done, and Rx Overrun are set because all bytes have been transmitted and an attempt to load data into the full Rx buffer has been detected.
- 9 The SS line is set to High to indicate that transmission is complete.
- 10 Rx FIFO Full is cleared when the first byte has been read from the Rx buffer and Rx FIFO Empty is set when all of them have been read.

**Note** Because the same register is used to transmit and receive data, the diagram section "Tx/Rx Data (A0)" contains two bit numbers in the following format: "Tx bit number (Rx bit number)."

### SPIS Mode: 0 (CPHA == 0, CPOL == 0)

Mode 0 has the following characteristics:





Page 24 of 37 Document Number: 001-68058 Rev. \*A

## **SPIS Mode: 1 (CPHA == 0, CPOL == 1)**

Mode 1 has the following characteristics:



### SPIS Mode: 2 (CPHA == 1, CPOL == 0)

Mode 2 has the following characteristics:





Document Number: 001-68058 Rev. \*A

### **SPIS Mode: 3 (CPHA == 1, CPOL == 1)**

Mode 3 has the following characteristics:



**Note** Some SPI Master devices (such as the TotalPhase Aardvark I2C/SPI host adapter) drive the sclk output in a specific way. For the SPI Slave component to function properly with such devices in modes 1 and 3 (when CPOL = 1), the sclk pin should be set to resistive pull-up drive mode. Otherwise, it gives out corrupted data.

# **Block Diagram and Configuration**

The SPIS is only available as a UDB configuration of blocks. The API is described above and the registers are described here to define the overall implementation of the SPIS.





The implementation is described in the following block diagram.

# Registers

### **Tx Status**

The Tx status register is a read-only register that contains the various status bits defined for a given instance of the SPIS component. Assuming that an instance of the SPI Slave is named "SPIS," the value of these registers is available from the SPIS\_ReadTxStatus() function call. The interrupt output signal is generated from an ORing of the masked bit-fields within the Tx status register. You can set the mask using the SPIS\_SetTxInterruptMode() function call. Upon receiving an interrupt you can retrieve the interrupt source by reading the Tx Status register with the SPIS\_ReadTxStatus() function call. The Tx Status register is cleared on reading so the interrupt source is held until the SPIS\_ReadTxStatus() function is called. All operations on the Tx status register must use the following defines for the bit-fields, as these bit-fields may be moved within the Tx status register at build time.

There are several bit-field masks defined for the Tx status register. Any of these bit-fields may be included as an interrupt source. The bit fields indicated with an asterisk (\*) are configured as sticky bits in the TX status register; all other bits are configured as real-time indicators of status.

The #defines are available in the generated header file (.h) as follows:

- SPIS\_STS\_SPI\_DONE \* Defined as the bit-mask of the Status register bit SPI Done.
- SPIS\_STS\_TX\_FIFO\_NOT\_FULL Defined as the bit-mask of the Status register bit Transmit FIFO Empty.



Document Number: 001-68058 Rev. \*A Page 27 of 37

- SPIS\_STS\_TX\_FIFO\_EMPTY Defined as the bit-mask of the Status register bit Transmit FIFO Empty.
- SPIS\_STS\_BYTE\_COMPLETE \* Defined as the bit-mask of the Status register bit Byte Complete.

#### **Rx Status**

The Rx status register is a read-only register that contains the various status bits defined for the SPIS. The value of these registers is available from the SPIS\_ReadRxStatus() function call. The interrupt output signal is generated from an ORing of the masked bit-fields within the Rx status register. You can set the mask using the SPIS\_SetRxInterruptMode() function call. Upon receiving an interrupt you can retrieve the interrupt source by reading the Rx Status register with the SPIS\_ReadRxStatus() function call. The Rx Status register is cleared on read so the interrupt source is held until the SPIS\_ReadRxStatus() function is called. All operations on the Rx status register must use the following defines for the bit-fields as these bit-fields may be moved within the Rx status register at build time.

There are several bit-field masks defined for the Rx status register. Any of these bit-fields may be included as an interrupt source. The bit-fields indicated with an asterisk (\*) are configured as sticky bits in the Rx status register; all other bits are configured as real-time indicators of status.

The #defines are available in the generated header file (.h) as follows:

- SPIS\_STS\_RX\_FIFO\_FULL Defined as the bit-mask of the Status register bit Receive FIFO Full.
- SPIS\_STS\_RX\_FIFO\_NOT\_EMPTY Defined as the bit-mask of the Status register bit Receive FIFO Not Empty.
- SPIS\_STS\_RX\_FIFO\_OVERRUN \* Defined as the bit-mask of the Status register bit Receive FIFO Overrun.

#### Tx Data

The Tx data register contains the transmit data value to send. This is implemented as a FIFO in the SPIS. There is a software state machine to control data from the transmit memory buffer to handle much larger portions of data to send. All APIs dealing with transmitting the data must go through this register to place the data onto the bus. If there is data in this register and flow control indicates that data can be sent, then the data will be transmitted on the bus. As soon as this register (FIFO) is empty, no more data will be transmitted on the bus until it is added to the FIFO. DMA may be set up to fill this FIFO when empty, using the TXDATA\_REG address defined in the header file.



#### **Rx Data**

The Rx data register contains the received data. This is implemented as a FIFO in the SPIS. There is a software state machine to control data movement from this receive FIFO into the memory buffer. Typically, the Rx interrupt will indicate that data has been received, at which time that data has several routes to the firmware. DMA may be set up from this register to the memory array or the firmware may simply poll for the data at will. This uses the RXDATA\_REG address defined in the header file.

### **Conditional Compilation Information**

The SPIS requires only one conditional compile definition to handle the 8- or 16-bit Datapath configuration necessary to implement the expected NumberOfDataBits configuration it must support. The API must conditionally compile Data Width defined in the parameter chosen. The API should never use these parameters directly but should use the define listed below.

■ SPIS DATAWIDTH – This defines how many data bits will make up a single "byte" transfer.



Document Number: 001-68058 Rev. \*A Page 29 of 37

## **DC and AC Electrical Characteristics**

The following values indicate expected performance and are based on initial characterization data.

## **Timing Characteristics "Maximum with Nominal Routing"**

| Parameter                                              | Description                 | Config                | Min                   | Тур | Max <sup>2</sup> | Units               |
|--------------------------------------------------------|-----------------------------|-----------------------|-----------------------|-----|------------------|---------------------|
| f <sub>SCLK</sub>                                      | SCLK frequency              | Config 1 3            | _                     | _   | 5                | MHz                 |
|                                                        |                             | Config 2 4            | _                     | _   | 5                | MHz                 |
|                                                        |                             | Config 3 <sup>5</sup> | _                     | _   | 4                | MHz                 |
|                                                        |                             | Config 4 <sup>6</sup> | _                     | _   | 4                | MHz                 |
| f <sub>CLOCK</sub>                                     | Component clock frequency 7 | Config 1 3            | 2 * f <sub>SCLK</sub> | _   | 10               | MHz                 |
|                                                        |                             | Config 2 4            | 2 * f <sub>SCLK</sub> | _   | 10               | MHz                 |
|                                                        |                             | Config 3 <sup>5</sup> | 2 * f <sub>SCLK</sub> | _   | 8                | MHz                 |
|                                                        |                             | Config 4 <sup>6</sup> | 2 * f <sub>SCLK</sub> | _   | 8                | MHz                 |
| t <sub>CKH</sub>                                       | SCLK High time              |                       | -                     | 0.5 | _                | 1/f <sub>SCLK</sub> |
| t <sub>CKL</sub>                                       | SCLK Low time               |                       | _                     | 0.5 | _                | 1/f <sub>SCLK</sub> |
| t <sub>SCLK_MISO</sub>                                 | SCLK to MISO output time    |                       | _                     | _   | 52               | ns                  |
| t <sub>SCLK_SDAT</sub><br>(Bidirectional<br>Mode only) | SCLK to SDAT output time    |                       | _                     | -   | 54               | ns                  |

<sup>&</sup>lt;sup>2</sup> The component maximum component clock frequency is derived from t<sub>SCLK\_MISO</sub> in combination with the routing path delays of the SCLK input and the MISO output (described later in this document). These "Nominal" numbers provide a maximum safe operating frequency of the component under nominal routing conditions. It is possible to run the component at higher clock frequencies, at which point you need to validate the timing requirements with STA results.

<sup>3</sup> Config 1 options:

Data Lines: MOSI+MISO

Data Bits: 8

<sup>4</sup> Config 2 options:

Data Lines: MOSI+MISO

Data Bits: 16

<sup>5</sup> Config 3 options:

Data Lines: Bidirectional

Data Bits: 8

<sup>6</sup> Config 4 options:

Data Lines: Bidirectional

Data Bits: 16

<sup>&</sup>lt;sup>7</sup> Component clock is for status register only; it does not affect base functionality or bit-rate. Routing may limit the maximum frequency of this parameter; therefore, the maximum is listed with nominal routing results.



| Parameter            | Description                  | Config | Min | Тур | Max <sup>2</sup> | Units |
|----------------------|------------------------------|--------|-----|-----|------------------|-------|
| t <sub>s_MOSI</sub>  | MOSI input setup time        |        | 25  | _   | _                | ns    |
| t <sub>H_MOSI</sub>  | MOSI input hold time         |        | _   | 0   |                  | ns    |
| t <sub>ss_sclk</sub> | SS active to SCLK active     |        | -20 | _   | 20               | ns    |
| t <sub>SCLK_SS</sub> | SCLK inactive to SS inactive |        | -20 | _   | 20               | ns    |

## **Timing Characteristics "Maximum with All Routing"**

| Parameter              | Description                  | Config      | Min                   | Тур | Max <sup>8</sup> | Units               |
|------------------------|------------------------------|-------------|-----------------------|-----|------------------|---------------------|
| f <sub>SCLK</sub>      | SCLK frequency               | Config 1 9  | _                     | _   | 4                | MHz                 |
|                        |                              | Config 2 10 | _                     | _   | 4                | MHz                 |
|                        |                              | Config 3 11 | _                     | _   | 2                | MHz                 |
|                        |                              | Config 4 12 | _                     | _   | 2                | MHz                 |
| f <sub>CLOCK</sub>     | Component clock frequency 13 | Config 1 9  | 2 * f <sub>SCLK</sub> | _   | 8                | MHz                 |
|                        |                              | Config 2 10 | 2 * f <sub>SCLK</sub> | _   | 8                | MHz                 |
|                        |                              | Config 3 11 | 2 * f <sub>SCLK</sub> | _   | 4                | MHz                 |
|                        |                              | Config 4 12 | 2 * f <sub>SCLK</sub> | -   | 4                | MHz                 |
| t <sub>CKH</sub>       | SCLK High time               |             | _                     | 0.5 | _                | 1/f <sub>SCLK</sub> |
| t <sub>CKL</sub>       | SCLK Low time                |             | _                     | 0.5 | _                | 1/f <sub>SCLK</sub> |
| t <sub>SCLK_MISO</sub> | SCLK to MISO output time     | ·           | _                     | _   | 52               | ns                  |

<sup>&</sup>lt;sup>8</sup> The Maximum for All Routing timing numbers are calculated by derating the Nominal Routing timing numbers by a factor of 2. If your component instance operates at or below these speeds, then meeting timing should not be a concern for this component.

<sup>9</sup> Config 1 options:

Data Lines: MOSI+MISO

Data Bits: 8

<sup>10</sup> Config 2 options:

Data Lines: MOSI+MISO

Data Bits: 16

<sup>11</sup> Config 3 options:

Data Lines: Bidirectional

Data Bits: 8

<sup>12</sup> Config 4 options:

Data Lines: Bidirectional

Data Bits: 16

<sup>&</sup>lt;sup>13</sup> Component clock is for status register only; it does not affect base functionality or bit-rate. Routing may limit the maximum frequency of this parameter; therefore, the maximum is listed with nominal routing results.



Document Number: 001-68058 Rev. \*A Page 31 of 37

| Parameter                                        | Description                     | Config     | Min | Тур | Max <sup>8</sup> | Units |
|--------------------------------------------------|---------------------------------|------------|-----|-----|------------------|-------|
| t <sub>SCLK_SDAT</sub> (Bidirectional Mode only) | SCLK to SDAT output time        |            | -   | -   | 54               | ns    |
| t <sub>s_MOSI</sub>                              | MOSI input setup time (to SCLK) |            | 25  | _   | _                | ns    |
| t <sub>H_MOSI</sub>                              | MOSI input hold time (from SCLK | <u>(</u> ) |     | 0   | _                | ns    |
| t <sub>ss_sclk</sub>                             | SS active to SCLK active        |            | -20 | _   | 20               | ns    |
| t <sub>SCLK_SS</sub>                             | SCLK inactive to SS inactive    |            | -20 | _   | 20               | ns    |

Figure 6. Mode CPHA = 0 Timing Diagram



Figure 7. Mode CPHA = 1 Timing Diagram



#### **How to Use STA Results for Characteristics Data**

Nominal route maximums are gathered through multiple test passes with Static Timing Analysis (STA). The maximums can be calculated for your designs using the STA results with the following mechanisms

The maximum frequency of SCLK (or the maximum bit-rate) is not provided directly in the STA. However, the data provided in the STA results indicates some of the internal logic timing constraints. To calculate the maximum bit-rate, you must take several factors into account. Board layout and slave communication device specs are needed to fully understand the maximum. The main limiting factor in this parameter is the round-trip path delay from the falling edge of SCLK at the pin of the master, to the slave and the path delay of the MISO output of the slave back to the master.

Figure 8. Calculating Maximum f<sub>SCLK</sub> Frequency



In this case, the component must meet the setup time of MISO at the Master using the equation below:

$$\begin{split} t_{\text{RT\_PD}} < 1 \div \left\{ \left[ \frac{1}{2} \times f_{\text{SCLK}} \right] - t_{\text{PD\_SCLK(master)}} - t_{\text{S\_MISO(master)}} \right\} \\ OR \\ f_{\text{SCLK}} < 1 \div \left\{ 2 \times \left[ T_{\text{RT\_PD}} + t_{\text{PD\_SCLK(master)}} + t_{\text{S\_MISO(master)}} \right] \right\} \end{split}$$

Where  $t_{PD\_SCLK(master)} + t_{S\_MISO(Master)}$  must come from the Master Device datasheet.  $t_{RT\_PD}$  is defined as:

$$t_{\text{RT\_PD}} = [\text{SCLK}_{\text{PD\_PCB}} + t_{\text{PD\_SCLK}(\text{slave})} + t_{\text{SCLK\_MISO}(\text{slave})} + \text{MISO}_{\text{PD\_PCB}}]$$



and:

 $SCLK_{PD\_PCB}$  is the PCB path delay of SCLK from the pin of the master component to the pin of the slave component.

 $t_{PD\_SCLK(Slave)}$  is the path delay of the input SCLK to the internal logic;  $t_{SCLK\_MISO(slave)}$  is the SCLK pin to internal logic path delay of the slave component; and  $t_{PD\_MISO(slave)}$  is the path delay of the internal MISO to the pin. The easiest way to find the values for these three parameters is to take the combined path as directly listed in the STA results, shown in the figure below:

#### - Clock To Output Section

#### - SCLK\_1(0)\_PAD

| Source                                        | Destination   | Delay (ns) |
|-----------------------------------------------|---------------|------------|
| \SPIS 1:BSPIS:es3:SPISlave:sR8:Dp:u0\/so comb | MISO 1(0) PAD | 47.895     |

Where  $t_{PD\_SCLK(Slave)}$  is the first two numbers,  $t_{SCLK\_MISO(slave)}$  is the second two numbers, and  $t_{PD\_MISO(slave)}$  is the last two numbers. The full path of the three parameters is 45.889 ns.

MISO<sub>PD\_PCB</sub> is the PCB path delay of the MISO from the pin of the slave component to the pin of the master component.

The final equation that will provide the maximum frequency of SCLK, and therefore the maximum bit-rate is:

$$f_{SCLK} (Max.) = 1 \div \left\{ 2 \times \left[ SCLK_{PD\_PCB} + t_{PD\_SCLK(slave)} + t_{SCLK\_MISO(slave)} + MISO_{PD\_PCB} + t_{PD\_SCLK(master)} + t_{S\_MISO(master)} \right] \right\}$$

**f**<sub>CLOCK</sub> Maximum component clock frequency is provided in the timing results in the clock summary as the IntClock (if internal clock is selected) or the named external clock. An example of the internal clock limitations from the STA report file is below:

## - Clock Summary Section

| Clock              | Type  | Nominal Frequency (MHz) | Required Frequency (MHz) | Maximum Frequency (MHz) | Violation |
|--------------------|-------|-------------------------|--------------------------|-------------------------|-----------|
| BUS CLK            | Sync  | 24.000                  | 24.000                   | N/A                     |           |
| ClockBlock/clk bus | Async | 24.000                  | 24.000                   | N/A                     |           |
| ClockBlock/dclk 0  | Async | 2.000                   | 2.000                    | N/A                     |           |
| ILO                | Async | 0.001                   | 0.001                    | N/A                     |           |
| IMO                | Async | 3.000                   | 3.000                    | N/A                     |           |
| MASTER CLK         | Sync  | 24.000                  | 24.000                   | N/A                     |           |
| PLL OUT            | Async | 24.000                  | 24.000                   | N/A                     |           |
| SCLK 1(0) PAD      | Async | UNKNOWN                 | UNKNOWN                  | 33.636                  |           |
| SPIS 1 IntClock    | Sync  | 2.000                   | 2.000                    | 75.746                  |           |

t<sub>CKH</sub> The SPI Slave component requires a 50-percent duty cycle SCLK.

t<sub>CKL</sub> The SPI Slave component requires a 50-percent duty cycle SCLK.

**t**s\_Mosi To meet the setup time of the internal logic, MOSI must be valid at the pin, before SCLK is valid at the pin, by this amount of time.

**t**<sub>H\_MOSI</sub> To meet the hold time of the internal logic, MOSI must be valid at the pin, after SCLK is valid at the pin, by this amount of time.



- **t**<sub>SS\_SCLK</sub> To meet the internal functionality of the block, Slave Select (SS) must be valid at the pin before SCLK is valid at the pin by this parameter.
- **t**<sub>SCLK\_SS</sub> Maximum to meet the internal functionality of the block. Slave Select (SS) must be valid at the pin after the last falling edge of SCLK at the pin by this parameter.

# **Component Changes**

This section lists the major changes in the component from the previous version.

| Version | Description of Changes                                                                                                                                                                                                                                                                    | Reason for Changes / Impact                                                                                                                                                                                                                     |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.20.a  | Added fixed placement explanation to datasheet                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                 |
| 2.20    | The SPI slave now discards any partial word that has been received and any partial word that has been transferred, if during the transfer the SS pin goes high. Defect appeared on ES3 silicon only.                                                                                      | Verilog defect fixed.                                                                                                                                                                                                                           |
|         | Added Enable Fixed Placement option to customizer                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                 |
| 2.10    | Data Bits range is changed from 2 to 16 bits to 3 to 16                                                                                                                                                                                                                                   | Changes related to status synchronization issues fixed in current version                                                                                                                                                                       |
|         | "Byte transfer complete" checkbox name is changed to the "Byte/Word transfer complete"                                                                                                                                                                                                    | To fit the real meaning                                                                                                                                                                                                                         |
|         | Added characterization data to datasheet                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                 |
|         | Minor datasheet edits and updates                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                 |
| 2.0.a   | Moved component into subfolders of the component catalog.                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                 |
|         | Minor datasheet edits and updates                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                 |
| 2.0     | Added SPIS_Sleep()/SPIS_Wakeup() and SPIS_Init()/SPIS_Enable() APIs.                                                                                                                                                                                                                      | To support low power modes, as well as to provide common interfaces to separate control of initialization and enabling of most components.                                                                                                      |
|         | Number and positions of component outputs have been changed:  The reset input was added;  The interrupt output was removed; rx_interrupt, tx_interrupt outputs were added instead.                                                                                                        | Production PSoC 3 reset functionality was added. Two status interrupt registers (Tx and Rx) are now presented instead of one shared. The changes must be taken into account to prevent binding errors when migrating from previous SPI versions |
|         | Removed SPIS_EnableInt(), SPIS_DisableInt(), SPIS_SetInterruptMode(), and SPIS_ReadStatus() APIs.  Added SPIS_EnableTxInt(), SPIS_EnableRxInt(), SPIS_DisableTxInt(), SPIS_DisableTxInt(), SPIS_DisableRxInt(), SPIS_SetTxInterruptMode(), SPIS_ReadTxStatus(), SPIS_ReadRxStatus() APIs. | The removed APIs are obsolete because the component now contains Rx and TX interrupts instead of one shared interrupt. Also updated the interrupt handler implementation for TX and Rx Buffer.                                                  |



Document Number: 001-68058 Rev. \*A Page 35 of 37

| Version    | Description of Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reason for Changes / Impact                                                                                                                             |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | Renamed SPIS_ReadByte(), SPIS_WriteByte(), and SPIS_WriteByteZero() APIs to SPIS_ReadRxData(), SPIS_WriteTxData(), SPIS_WriteTxDataZero().                                                                                                                                                                                                                                                                                                                                                                                               | Clarifies the APIs and how they should be used.                                                                                                         |
| The follow | wing changes were made to the base SPI Slave comporilog:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | nent B_SPI_Slave_v2_0, which is implemented                                                                                                             |
|            | B_SPI_Slave_v2_0 now contains two separate implementations for ES2 and ES3 silicon.  One datapath is used for 8-bit SPI for Tx and Rx in ES3 silicon instead of two in ES2.                                                                                                                                                                                                                                                                                                                                                              | Requirement that all components support ES2 and ES3 silicon. Use of ES3 feature updates is a requirement and this helps optimize resource usage in ES3. |
|            | Changes in ES2 support implementation: Two status registers are now presented (status are separate on Tx and Rx) instead of using one common status register for both.                                                                                                                                                                                                                                                                                                                                                                   | This provides correct software buffer functionality.                                                                                                    |
|            | 'BidirectMode' boolean parameter is added to base component (Verilog implementation).  Control Register with 'clock' input and SYNC mode bit is now selected to drive 'tx_enable' output for ES3 silicon.  Control Register w/o clock input drives 'tx_enable' when ES2 silicon is selected.  Bufoe component is used on component schematic to support Bidirectional Mode. MOSI output of base component is connected to bufoe 'x' input.  'yfb' is connected to 'miso' input. Bufoe 'y' output is connected to 'sdat' output terminal. | Added Bidirectional Mode support to the component                                                                                                       |
|            | Four udb_clock_enable components are added to Verilog implementation with sync = 'TRUE' parameter. One of them has sync = 'TRUE' (status register clock), other three have sync = 'FALSE'                                                                                                                                                                                                                                                                                                                                                | New requirements for all clocks used in Verilog to indicate functionality so the tool can support synchronization and Static Timing Analysis.           |
|            | Rx datapath configuration changed. 'FIFO FAST' option is set to 'DP" instead of 'BUS'                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Fixes a defect in previous versions of the component where there was a timing window affecting correct component capture of data.                       |
|            | Additional logic to Verilog implementation to change the moments when SPI DONE and BYTE COMPLETE status are generated.                                                                                                                                                                                                                                                                                                                                                                                                                   | Fixes a defect in previous versions of the component where SPI DONE is sometimes not generated even after communication is complete.                    |
|            | Maximum Bit Rate value is changed to 10 Mbps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Bit Rate value more than 10 Mbps is not supported (verified during component characterization)                                                          |
|            | Description of the Bidirectional Mode is added                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Data sheet defect fixed                                                                                                                                 |
|            | Reset input description now contains the note about ES2 silicon incompatibility                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Data sheet defect fixed                                                                                                                                 |



Page 36 of 37 Document Number: 001-68058 Rev. \*A

| Version | Description of Changes                                                    | Reason for Changes / Impact                                 |
|---------|---------------------------------------------------------------------------|-------------------------------------------------------------|
|         | Timing correlation diagram between SS and SCLk signals is changed         | Data sheet defect fixed                                     |
|         | Sample firmware source code is removed                                    | Reference to the component example project is added instead |
|         | SPI Modes diagrams were changed (Tx and Rx FIFO status values were added) | Data sheet defect fixed                                     |

© Cypress Semiconductor Corporation, 2011. The information contained herein is subject to change without notice. Cypress Semiconductor Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in a Cypress product. Nor does it convey or imply any license under patent or other rights. Cypress products are not warranted nor intended to be used for medical, life support, life saving, critical control or safety applications, unless pursuant to an express written agreement with Cypress. Furthermore, Cypress does not authorize its products for use as critical components in life-support systems where a malfunction or failure may reasonably be expected to result in significant injury to the user. The inclusion of Cypress products in life-support systems application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress against all charges.

PSoC® is a registered trademark, and PSoC Creator™ and Programmable System-on-Chip™ are trademarks of Cypress Semiconductor Corp. All other trademarks or registered trademarks referenced herein are property of the respective corporations.

Any Source Code (software and/or firmware) is owned by Cypress Semiconductor Corporation (Cypress) and is protected by and subject to worldwide patent protection (United States and foreign), United States copyright laws and international treaty provisions. Cypress hereby grants to licensee a personal, non-exclusive, non-transferable license to copy, use, modify, create derivative works of, and compile the Cypress Source Code and derivative works for the sole purpose of creating custom software and or firmware in support of licensee product to be used only in conjunction with a Cypress integrated circuit as specified in the applicable agreement. Any reproduction, modification, translation, compilation, or representation of this Source Code except as specified above is prohibited without the express written permission of Cypress.

Disclaimer: CYPRESS MAKES NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. Cypress reserves the right to make changes without further notice to the materials described herein. Cypress does not assume any liability arising out of the application or use of any product or circuit described herein. Cypress does not authorize its products for use as critical components in life-support systems where a malfunction or failure may reasonably be expected to result in significant injury to the user. The inclusion of Cypress' product in a life-support systems application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress against all charges.

Use may be limited by and subject to the applicable Cypress software license agreement.



Document Number: 001-68058 Rev. \*A Page 37 of 37