Macros | |
| #define | SPI_WPMR_WPKEY_PASSWD SPI_WPMR_WPKEY((uint32_t) 0x535049) |
Functions | |
| int16_t | spi_calc_baudrate_div (const uint32_t baudrate, uint32_t mck) |
| Calculate the baudrate divider. More... | |
| void | spi_configure_cs_behavior (Spi *p_spi, uint32_t ul_pcs_ch, uint32_t ul_cs_behavior) |
| Configure CS behavior for SPI transfer (spi_cs_behavior_t). More... | |
| void | spi_disable_clock (Spi *p_spi) |
| Disable SPI clock. More... | |
| void | spi_enable_clock (Spi *p_spi) |
| Enable SPI clock. More... | |
| uint32_t | spi_get_writeprotect_status (Spi *p_spi) |
| Indicate write protect status. More... | |
| spi_status_t | spi_read (Spi *p_spi, uint16_t *us_data, uint8_t *p_pcs) |
| Read the received data and it's peripheral chip select value. While SPI works in fixed peripheral select mode, the peripheral chip select value is meaningless. More... | |
| int16_t | spi_set_baudrate_div (Spi *p_spi, uint32_t ul_pcs_ch, uint8_t uc_baudrate_divider) |
| Set Serial Clock Baud Rate divider value (SCBR). More... | |
| void | spi_set_bits_per_transfer (Spi *p_spi, uint32_t ul_pcs_ch, uint32_t ul_bits) |
| Set number of bits per transfer. More... | |
| void | spi_set_clock_phase (Spi *p_spi, uint32_t ul_pcs_ch, uint32_t ul_phase) |
| Set Data Capture Phase. More... | |
| void | spi_set_clock_polarity (Spi *p_spi, uint32_t ul_pcs_ch, uint32_t ul_polarity) |
| Set clock default state. More... | |
| void | spi_set_delay_between_chip_select (Spi *p_spi, uint32_t ul_delay) |
| Set delay between chip selects (in number of MCK clocks). If DLYBCS <= 6, 6 MCK clocks will be inserted by default. More... | |
| void | spi_set_peripheral_chip_select_value (Spi *p_spi, uint32_t ul_value) |
| Set Peripheral Chip Select (PCS) value. More... | |
| void | spi_set_transfer_delay (Spi *p_spi, uint32_t ul_pcs_ch, uint8_t uc_dlybs, uint8_t uc_dlybct) |
| Configure timing for SPI transfer. More... | |
| void | spi_set_writeprotect (Spi *p_spi, uint32_t ul_enable) |
| Enable or disable write protection of SPI registers. More... | |
| spi_status_t | spi_write (Spi *p_spi, uint16_t us_data, uint8_t uc_pcs, uint8_t uc_last) |
| Write the transmitted data with specified peripheral chip select value. More... | |
See Quickstart guide for SAM SPI driver.
The SPI circuit is a synchronous serial data link that provides communication with external devices in Master or Slave mode. Connection to Peripheral DMA Controller channel capabilities optimizes data transfers.
| #define SPI_WPMR_WPKEY_PASSWD SPI_WPMR_WPKEY((uint32_t) 0x535049) |
| int16_t spi_calc_baudrate_div | ( | const uint32_t | baudrate, |
| uint32_t | mck | ||
| ) |
| void spi_configure_cs_behavior | ( | Spi * | p_spi, |
| uint32_t | ul_pcs_ch, | ||
| uint32_t | ul_cs_behavior | ||
| ) |
Configure CS behavior for SPI transfer (spi_cs_behavior_t).
| p_spi | Pointer to an SPI instance. |
| ul_pcs_ch | Peripheral Chip Select channel (0~3). |
| ul_cs_behavior | Behavior of the Chip Select after transfer. |
| void spi_disable_clock | ( | Spi * | p_spi | ) |
| void spi_enable_clock | ( | Spi * | p_spi | ) |
| uint32_t spi_get_writeprotect_status | ( | Spi * | p_spi | ) |
| spi_status_t spi_read | ( | Spi * | p_spi, |
| uint16_t * | us_data, | ||
| uint8_t * | p_pcs | ||
| ) |
Read the received data and it's peripheral chip select value. While SPI works in fixed peripheral select mode, the peripheral chip select value is meaningless.
| p_spi | Pointer to an SPI instance. |
| data | Pointer to the location where to store the received data word. |
| p_pcs | Pointer to fill Peripheral Chip Select Value. |
| SPI_OK | on Success. |
| SPI_ERROR_TIMEOUT | on Time-out. |
| int16_t spi_set_baudrate_div | ( | Spi * | p_spi, |
| uint32_t | ul_pcs_ch, | ||
| uint8_t | uc_baudrate_divider | ||
| ) |
| void spi_set_bits_per_transfer | ( | Spi * | p_spi, |
| uint32_t | ul_pcs_ch, | ||
| uint32_t | ul_bits | ||
| ) |
| void spi_set_clock_phase | ( | Spi * | p_spi, |
| uint32_t | ul_pcs_ch, | ||
| uint32_t | ul_phase | ||
| ) |
| void spi_set_clock_polarity | ( | Spi * | p_spi, |
| uint32_t | ul_pcs_ch, | ||
| uint32_t | ul_polarity | ||
| ) |
| void spi_set_delay_between_chip_select | ( | Spi * | p_spi, |
| uint32_t | ul_delay | ||
| ) |
| void spi_set_peripheral_chip_select_value | ( | Spi * | p_spi, |
| uint32_t | ul_value | ||
| ) |
Set Peripheral Chip Select (PCS) value.
| p_spi | Pointer to an SPI instance. |
| ul_value | Peripheral Chip Select value. If PCS decode mode is not used, use spi_get_pcs to build the value to use. On reset the decode mode is not enabled. The decode mode can be enabled/disabled by follow functions: spi_enable_peripheral_select_decode, spi_disable_peripheral_select_decode. |
| void spi_set_transfer_delay | ( | Spi * | p_spi, |
| uint32_t | ul_pcs_ch, | ||
| uint8_t | uc_dlybs, | ||
| uint8_t | uc_dlybct | ||
| ) |
| void spi_set_writeprotect | ( | Spi * | p_spi, |
| uint32_t | ul_enable | ||
| ) |
| spi_status_t spi_write | ( | Spi * | p_spi, |
| uint16_t | us_data, | ||
| uint8_t | uc_pcs, | ||
| uint8_t | uc_last | ||
| ) |
Write the transmitted data with specified peripheral chip select value.
| p_spi | Pointer to an SPI instance. |
| us_data | The data to transmit. |
| uc_pcs | Peripheral Chip Select Value while SPI works in peripheral select mode, otherwise it's meaningless. |
| uc_last | Indicate whether this data is the last one while SPI is working in variable peripheral select mode. |
| SPI_OK | on Success. |
| SPI_ERROR_TIMEOUT | on Time-out. |