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) | |
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.
bool cy_stc_scb_spi_config_t::dropOnParityError |
Sets if the SPI will drop data when there is a parity error.
uint32_t cy_stc_scb_spi_config_t::oversample |
Oversample factor for SPI.
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.
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.
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.
cy_en_scb_spi_ss_setup_delay_t cy_stc_scb_spi_config_t::ssSetupDelay |
Sets the SPI Select setup delay.
cy_en_scb_spi_ss_hold_delay_t cy_stc_scb_spi_config_t::ssHoldDelay |
Sets the SPI Select hold delay.
cy_en_scb_spi_ss_interframe_delay_t cy_stc_scb_spi_config_t::ssInterDataframeDelay |
Sets the SPI Select inter-dataframe delay.
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.
bool cy_stc_scb_spi_config_t::mosiIdleHigh |
Sets if the the MOSI line stays high when not in use.
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.
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.