CAT2 Peripheral Driver Library
cy_stc_scb_spi_config_t Struct Reference

Description

SPI configuration structure.

Data Fields

cy_en_scb_spi_mode_t spiMode
 Specifies the mode of operation.
 
cy_en_scb_spi_sub_mode_t subMode
 Specifies the submode of SPI operation.
 
cy_en_scb_spi_sclk_mode_t sclkMode
 Configures the SCLK operation for Motorola sub-mode, ignored for all other submodes.
 
cy_en_scb_spi_parity_t parity
 Sets the SPI parity. More...
 
bool dropOnParityError
 Sets if the SPI will drop data when there is a parity error. More...
 
uint32_t oversample
 Oversample factor for SPI. More...
 
uint32_t rxDataWidth
 The width of RX data (valid range 4-16). More...
 
uint32_t txDataWidth
 The width of TX data (valid range 4-16). More...
 
bool enableMsbFirst
 Enables the hardware to shift out the data element MSB first, otherwise, LSB first.
 
bool enableFreeRunSclk
 Enables the master to generate a continuous SCLK regardless of whether there is data to send.
 
bool enableInputFilter
 Enables a digital 3-tap median filter to be applied to the input of the RX FIFO to filter glitches on the line.
 
bool enableMisoLateSample
 Enables the master to sample MISO line one half clock later to allow better timings.
 
bool enableTransferSeperation
 Enables the master to transmit each data element separated by a de-assertion of the slave select line (only applicable for the master mode)
 
uint32_t ssPolarity
 Sets active polarity of each SS line. More...
 
cy_en_scb_spi_ss_setup_delay_t ssSetupDelay
 Sets the SPI Select setup delay. More...
 
cy_en_scb_spi_ss_hold_delay_t ssHoldDelay
 Sets the SPI Select hold delay. More...
 
cy_en_scb_spi_ss_interframe_delay_t ssInterDataframeDelay
 Sets the SPI Select inter-dataframe delay. More...
 
bool enableWakeFromSleep
 When set, the slave will wake the device when the slave select line becomes active. More...
 
bool mosiIdleHigh
 Sets if the the MOSI line stays high when not in use. More...
 
uint32_t rxFifoTriggerLevel
 When there are more entries in the RX FIFO then this level the RX trigger output goes high. More...
 
uint32_t rxFifoIntEnableMask
 Bits set in this mask will allow events to cause an interrupt (See SPI RX FIFO Statuses for the set of constant)
 
uint32_t txFifoTriggerLevel
 When there are fewer entries in the TX FIFO then this level the TX trigger output goes high. More...
 
uint32_t txFifoIntEnableMask
 Bits set in this mask allow events to cause an interrupt (See SPI TX FIFO Statuses for the set of constants)
 
uint32_t masterSlaveIntEnableMask
 Bits set in this mask allow events to cause an interrupt (See SPI Master and Slave Statuses for the set of constants)
 

Field Documentation

◆ parity

cy_en_scb_spi_parity_t cy_stc_scb_spi_config_t::parity

Sets the SPI parity.

The parity can be disabled or set to even or odd. When the parity is set to even or odd the parity is enabled.

Note
Only applicable for PSOC 4100S Max.

◆ dropOnParityError

bool cy_stc_scb_spi_config_t::dropOnParityError

Sets if the SPI will drop data when there is a parity error.

Note
Only applicable for PSOC 4100S Max.

◆ oversample

uint32_t cy_stc_scb_spi_config_t::oversample

Oversample factor for SPI.

  • For the master mode, the data rate is the SCB clock / oversample (the valid range is 4 to 16, when MISO is used; if MISO is not used then the valid range is 2 to 16).
  • For the slave mode, the oversample value is ignored. The data rate is determined by the SCB clock frequency.

◆ rxDataWidth

uint32_t cy_stc_scb_spi_config_t::rxDataWidth

The width of RX data (valid range 4-16).

It must be the same as txDataWidth except in National sub-mode.

◆ txDataWidth

uint32_t cy_stc_scb_spi_config_t::txDataWidth

The width of TX data (valid range 4-16).

It must be the same as rxDataWidth except in National sub-mode.

◆ ssPolarity

uint32_t cy_stc_scb_spi_config_t::ssPolarity

Sets active polarity of each SS line.

This is a bit mask: bit 0 corresponds to SS0 and so on to SS3. 1 means active high, a 0 means active low.

◆ ssSetupDelay

cy_en_scb_spi_ss_setup_delay_t cy_stc_scb_spi_config_t::ssSetupDelay

Sets the SPI Select setup delay.

Note
Only applicable for PSOC 4100S Max.

◆ ssHoldDelay

cy_en_scb_spi_ss_hold_delay_t cy_stc_scb_spi_config_t::ssHoldDelay

Sets the SPI Select hold delay.

Note
Only applicable for PSOC 4100S Max.

◆ ssInterDataframeDelay

cy_en_scb_spi_ss_interframe_delay_t cy_stc_scb_spi_config_t::ssInterDataframeDelay

Sets the SPI Select inter-dataframe delay.

Note
Only applicable for PSOC 4100S Max.

◆ enableWakeFromSleep

bool cy_stc_scb_spi_config_t::enableWakeFromSleep

When set, the slave will wake the device when the slave select line becomes active.

Note that not all SCBs support this mode. Consult the device datasheet to determine which SCBs support wake from Deep Sleep.

◆ mosiIdleHigh

bool cy_stc_scb_spi_config_t::mosiIdleHigh

Sets if the the MOSI line stays high when not in use.

Note
Only applicable for PSOC 4100S Max.

◆ rxFifoTriggerLevel

uint32_t cy_stc_scb_spi_config_t::rxFifoTriggerLevel

When there are more entries in the RX FIFO then this level the RX trigger output goes high.

This output can be connected to a DMA channel through a trigger mux. Also, it controls the CY_SCB_SPI_RX_TRIGGER interrupt source.

◆ txFifoTriggerLevel

uint32_t cy_stc_scb_spi_config_t::txFifoTriggerLevel

When there are fewer entries in the TX FIFO then this level the TX trigger output goes high.

This output can be connected to a DMA channel through a trigger mux. Also, it controls the CY_SCB_SPI_TX_TRIGGER interrupt source.