![]() |
MAX32690 Peripheral Driver API
Peripheral Driver API for the MAX32690
|
Modules | |
SPI External Flash Master (SPIXFM) | |
SPI External Flash Controller (SPIXFC) | |
SPI External Flash Controller FIFO (SPIXFC_FIFO) | |
Data Structures | |
struct | mxc_spixf_cfg_t |
struct | mxc_spixf_req_t |
Typedefs | |
typedef void(* | spixr_complete_cb_t) (mxc_spixf_req_t *, int) |
Enumerations | |
enum | mxc_spixf_ssel_t |
enum | mxc_spixf_hdr_direction_t |
enum | mxc_spixf_sspol_t |
enum | mxc_spixf_cmd_t |
enum | mxc_spixf_mode_t |
enum | mxc_spixf_page_size_t |
enum | mxc_spixf_hdr_units_t |
enum | mxc_spixf_width_t |
enum | mxc_spixf_ssact_t |
enum | mxc_spixf_ssiact_t |
enum | mxc_spixf_spiwidth_t |
enum | mxc_spixf_pup_t |
enum | mxc_spixf_ds_t |
struct mxc_spixf_cfg_t |
MXC_SPIXF configuration type.
Data Fields | |
mxc_spixf_mode_t | mode |
mxc_spixf_sspol_t | ssel_pol |
uint32_t | hz |
struct mxc_spixf_req |
MXC_SPIXF Transaction request.
Data Fields | |
uint8_t | deass |
uint8_t | wait_tx |
const uint8_t * | tx_data |
uint8_t * | rx_data |
mxc_spixf_width_t | width |
unsigned | len |
unsigned | read_num |
unsigned | write_num |
spixr_complete_cb_t | callback |
typedef void(* spixr_complete_cb_t) (mxc_spixf_req_t *, int) |
Callback for asynchronous request.
mxc_spixf_req_t* | Pointer to the transaction request. |
int | Error code. |
enum mxc_spixf_mode_t |
SPIXF mode.
enum mxc_spixf_ssiact_t |
enum mxc_spixf_width_t |
int MXC_SPIXF_AbortAsync | ( | mxc_spixf_req_t * | req | ) |
Abort asynchronous request.
req | Pointer to request for a MXC_SPIXF transaction. |
int MXC_SPIXF_BBDataOutputDisable | ( | uint8_t | mask | ) |
Disable bits to not be in bit bang output mode.
[in] | mask | Disable output bit bang on specific bits so bit 3 set will disable bit 3 |
int MXC_SPIXF_BBDataOutputEnable | ( | uint8_t | mask | ) |
Enable bits to be in bit bang output mode.
[in] | mask | Enable output bit bang on specific bits so bit 3 set will enable bit 3 |
uint8_t MXC_SPIXF_BBDataOutputIsEnabled | ( | void | ) |
Get if bit bang output mode is enabled or disabled for all bits.
int MXC_SPIXF_BitBangModeDisable | ( | void | ) |
Disable bit bang mode.
int MXC_SPIXF_BitBangModeEnable | ( | void | ) |
Enable bit bang mode.
int MXC_SPIXF_BitBangModeIsEnabled | ( | void | ) |
Is Bit bang mode enabled or disabled.
int MXC_SPIXF_ClearFlags | ( | uint32_t | flags | ) |
Clear Flags that have been set.
[in] | flags | The flags to be cleared |
int MXC_SPIXF_Clocks | ( | uint32_t | len, |
uint8_t | deass | ||
) |
Send Clock cycles on SCK without reading or writing.
len | Number of clock cycles to send. |
deass | De-assert slave select at the end of the transaction. |
int MXC_SPIXF_Disable | ( | void | ) |
Disables SPIXF but doesnt change any configurations.
int MXC_SPIXF_DisableInt | ( | uint32_t | mask | ) |
Disable Interrupts.
[in] | mask | The mask for the interrupts to enable |
int MXC_SPIXF_Enable | ( | void | ) |
Enables SPIXF but doesnt change any configurations.
int MXC_SPIXF_EnableInt | ( | uint32_t | mask | ) |
Enable Interrupts.
[in] | mask | The mask for the interrupts to enable |
mxc_spixf_spiwidth_t MXC_SPIXF_GetAddrWidth | ( | void | ) |
Get number of data I/O expected to be used for address.
uint8_t MXC_SPIXF_GetBBDataInputValue | ( | void | ) |
Get Input data value.
uint8_t MXC_SPIXF_GetBBDataOutputValue | ( | void | ) |
Get Output data value.
unsigned int MXC_SPIXF_GetBusIdle | ( | void | ) |
Get Bus Idle time.
unsigned int MXC_SPIXF_GetBytesPerAddr | ( | void | ) |
Get number of bytes in address.
mxc_spixf_cmd_t MXC_SPIXF_GetCmdMode | ( | void | ) |
Get Command mode.
mxc_spixf_spiwidth_t MXC_SPIXF_GetCmdWidth | ( | void | ) |
Get number of data I/O expected to be used for commands.
mxc_spixf_spiwidth_t MXC_SPIXF_GetDataWidth | ( | void | ) |
Get number of data I/O expected to be used for data.
int MXC_SPIXF_GetFlags | ( | void | ) |
Get Flags of Interrupts of Flags that have been set.
uint8_t MXC_SPIXF_GetIoctrlSCLKDrive | ( | void | ) |
Get IOCTRL SCLK Drive.
uint8_t MXC_SPIXF_GetIoctrlSDIODrive | ( | void | ) |
Get IOCTRL SDIO Drive.
uint8_t MXC_SPIXF_GetIoctrlSSDrive | ( | void | ) |
Get IOCTRL SS Drive.
mxc_spixf_mode_t MXC_SPIXF_GetMode | ( | void | ) |
Get which mode that spixf is currently set for.
uint8_t MXC_SPIXF_GetModeClk | ( | void | ) |
Get number of SPI clocks being used for the mode/dummy phase of fetch.
uint16_t MXC_SPIXF_GetModeData | ( | void | ) |
Get the data that is supposed to send with the dummy clocks.
mxc_spixf_page_size_t MXC_SPIXF_GetPageSize | ( | void | ) |
Get the current page size for a transaction.
uint8_t MXC_SPIXF_GetPuPdCtrl | ( | void | ) |
Get what setting the pull up pull down is set to.
uint8_t MXC_SPIXF_GetSampleOutputValue | ( | void | ) |
Get bit bang sample output value.
uint8_t MXC_SPIXF_GetSCKDrive | ( | void | ) |
Get if SCK is high or low.
int MXC_SPIXF_GetSCKInverted | ( | void | ) |
Get weather SCK is inverted or non-inverted.
uint8_t MXC_SPIXF_GetSCKSampleDelay | ( | void | ) |
Get the Number of clocks being delayed before sampling SDIO.
uint32_t MXC_SPIXF_GetSPIFrequency | ( | void | ) |
Get the current SPI clock frequency. If the read and write clock frequencies have been set to different values, this function will return the read frequency.
uint32_t MXC_SPIXF_GetSPIFrequencyRead | ( | void | ) |
Get the current SPI clock frequency for read operations.
uint32_t MXC_SPIXF_GetSPIFrequencyWrite | ( | void | ) |
Get the current SPI clock frequency for write operations.
mxc_spixf_ssact_t MXC_SPIXF_GetSSActiveTime | ( | void | ) |
Get the slave select active timing setting.
uint8_t MXC_SPIXF_GetSSDriveOutput | ( | void | ) |
Get current slave select output.
mxc_spixf_ssiact_t MXC_SPIXF_GetSSInactiveTime | ( | void | ) |
Get slave select inactive timing to delay from de-assertion of slave select to re-assertion of slave select for another spi transaction.
int MXC_SPIXF_GetSSPolarity | ( | void | ) |
Get the current slave select polarity.
void MXC_SPIXF_Handler | ( | void | ) |
MXC_SPIXF interrupt handler.
This function should be called by the application from the interrupt handler if MXC_SPIXF interrupts are enabled. Alternately, this function can be periodically called by the application if MXC_SPIXF interrupts are disabled.
int MXC_SPIXF_Init | ( | uint32_t | cmdval, |
uint32_t | frequency | ||
) |
Setup MXC_SPIXF for Execute in Place.
cmdval | command for the external flash chip. |
frequency | Frequency of transmission |
void MXC_SPIXF_IOCtrl | ( | mxc_spixf_ds_t | sclk_ds, |
mxc_spixf_ds_t | ss_ds, | ||
mxc_spixf_ds_t | sdio_ds, | ||
mxc_spixf_pup_t | pupdctrl | ||
) |
Setup Drive Strength on the I/O pins.
sclk_ds | SCLK drive strength |
ss_ds | Slave Select Drive Strength |
sdio_ds | SDIO Drive Strength |
pupdctrl | IO Pullup/Pulldown Control |
int MXC_SPIXF_IsEnabled | ( | void | ) |
Is SPIXF Enabled or Disabled.
int MXC_SPIXF_ReadyForSleep | ( | void | ) |
Attempt to prepare the MXC_SPIXF for sleep.
int MXC_SPIXF_RXFIFODisable | ( | void | ) |
RX FIFO (results fifo) disable.
int MXC_SPIXF_RXFIFOEnable | ( | void | ) |
RX FIFO (results fifo) enable.
int MXC_SPIXF_RXFIFOIsEnabled | ( | void | ) |
Is RX FIFO (results fifo) enabled or disabled.
int MXC_SPIXF_SampleOutputDisable | ( | uint8_t | mask | ) |
Disable bit bang sample output mode on spefic bits.
[in] | mask | Disable sample output bit bang mode. so bit 3 set will disable bit 3 |
int MXC_SPIXF_SampleOutputEnable | ( | uint8_t | mask | ) |
Enable bit bang sample output mode on spefic bits.
[in] | mask | Enable sample output bit bang mode. so bit 3 set will enable bit 3 |
uint8_t MXC_SPIXF_SampleOutputIsEnabled | ( | void | ) |
Get if sample output bit bang is enabled or disabled.
int MXC_SPIXF_SCKFeebackDisable | ( | void | ) |
Disable SCK Feedback.
int MXC_SPIXF_SCKFeebackIsEnabled | ( | void | ) |
Get if SCK Feedback is enabled or disabled.
int MXC_SPIXF_SCKFeedbackEnable | ( | void | ) |
Enable SCK Feedback.
int MXC_SPIXF_Set3ByteAddr | ( | void | ) |
Set address mode to be 3 byte address.
int MXC_SPIXF_Set4ByteAddr | ( | void | ) |
Set address mode to be 4 byte address.
int MXC_SPIXF_SetAddrWidth | ( | mxc_spixf_spiwidth_t | width | ) |
Set Number of data I/O used to send address.
[in] | width | Enum that corresponds to single, dual, quad SDIO. |
int MXC_SPIXF_SetBusIdle | ( | unsigned int | busidle | ) |
Set bus idle to a time where ss will be deactivated if timer runs out.
[in] | busidle | The time before the timer runs out |
int MXC_SPIXF_SetCmdModeEveryTrans | ( | void | ) |
Set command mode to send read a command every time a spi transaction is initiated.
int MXC_SPIXF_SetCmdValue | ( | uint8_t | cmdval | ) |
Set command value for spi transaction.
[in] | cmdval |
int MXC_SPIXF_SetCmdWidth | ( | mxc_spixf_spiwidth_t | width | ) |
Set Number of data I/O used to send commands.
[in] | width | Enum that corresponds to single, dual, quad SDIO. |
int MXC_SPIXF_SetDataWidth | ( | mxc_spixf_spiwidth_t | width | ) |
Set Number of data I/O used to send data.
[in] | width | Enum that corresponds to single, dual, quad SDIO. |
int MXC_SPIXF_SetMode | ( | mxc_spixf_mode_t | mode | ) |
Sets the SPI Mode.
[in] | mode | The enum that corresponds to the SPI Mode |
int MXC_SPIXF_SetModeClk | ( | uint8_t | mdclk | ) |
Set number of SPI clocks needed during the mode/dummy phase of fetch.
[in] | mdclk | The number of clocks from 0-15 |
int MXC_SPIXF_SetModeData | ( | uint16_t | data | ) |
Set the data to send with the dummy clocks.
[in] | data | The data to send |
void MXC_SPIXF_SetPageSize | ( | mxc_spixf_page_size_t | size | ) |
Set Page Size for transactions.
[in] | size | The size of a transaction in bytes |
void MXC_SPIXF_SetPuPdCtrl | ( | mxc_spixf_pup_t | pupd | ) |
Set pull up pull down.
[in] | pupd | The enum corresponding to Pull up pull down states |
void MXC_SPIXF_SetSCKDriveHigh | ( | void | ) |
Drive SCK High.
void MXC_SPIXF_SetSCKDriveLow | ( | void | ) |
Drive SCK Low.
int MXC_SPIXF_SetSCKInverted | ( | void | ) |
Set SCK to be inverted.
int MXC_SPIXF_SetSCKNonInverted | ( | void | ) |
Set SCK to be non-inverted.
int MXC_SPIXF_SetSCKSampleDelay | ( | uint8_t | delay | ) |
Set SPI clock periods to delay before sampling SDIO input. This value must be less than or equal to HICLK.
[in] | delay | The number of clocks to delay between 0-15 |
int MXC_SPIXF_SetSPIFrequency | ( | unsigned int | hz | ) |
Sets both the read and write SPI clock frequency to the given value.
[in] | hz | The frequency the spi will communicating at. |
int MXC_SPIXF_SetSPIFrequencyRead | ( | unsigned int | hz | ) |
Sets the SPI clock frequency for read operations.
[in] | hz | The frequency the spi will communicating at. |
int MXC_SPIXF_SetSPIFrequencyWrite | ( | unsigned int | hz | ) |
Sets the SPI clock frequency for write operations.
[in] | hz | The frequency the spi will communicating at. |
int MXC_SPIXF_SetSSActiveTime | ( | mxc_spixf_ssact_t | ssact | ) |
Set the slave select active timing. This will control the delay from assertion of slave select to start of the SCK pulse and delay from the end of SCK pulse to de-assertion of slave select.
[in] | ssact | The enum that corresponds with 0,2,4,8 clocks of delay |
int MXC_SPIXF_SetSSInactiveTime | ( | mxc_spixf_ssiact_t | ssiact | ) |
Set slave select inactive timing to delay from de-assertion of slave select to re-assertion of slave select for another spi transaction.
[in] | ssiact | The enum that corresponds to a 1,3,5,9 clock delay |
int MXC_SPIXF_SetSSPolActiveHigh | ( | void | ) |
Set the slave select polarity to high or low.
int MXC_SPIXF_SetSSPolActiveLow | ( | void | ) |
Set the slave select polarity to high or low.
int MXC_SPIXF_SimpleModeDisable | ( | void | ) |
Disable Simple Mode.
int MXC_SPIXF_SimpleModeEnable | ( | void | ) |
Enable Simple Mode.
int MXC_SPIXF_SimpleModeIsEnabled | ( | void | ) |
Get if Simple mode is enabled or disabled.
int MXC_SPIXF_SimpleRXDisable | ( | void | ) |
Set to Receive only in simple mode.
int MXC_SPIXF_SimpleRXEnabled | ( | void | ) |
Set to Receive only in simple mode.
int MXC_SPIXF_SimpleRXIsEnabled | ( | void | ) |
Get Receive only mode setting.
int MXC_SPIXF_Transaction | ( | mxc_spixf_req_t * | req | ) |
Read/write MXC_SPIXF data. Will block until transaction is complete.
req | Request for a MXC_SPIXF transaction. |
int MXC_SPIXF_TransactionAsync | ( | mxc_spixf_req_t * | req | ) |
Asynchronously read/write MXC_SPIXF data.
req | Request for a MXC_SPIXF transaction. |
int MXC_SPIXF_TXFIFODisable | ( | void | ) |
TX FIFO (Transaction FIFO) disable.
int MXC_SPIXF_TXFIFOEnable | ( | void | ) |
TX FIFO (Transaction FIFO) enable.
int MXC_SPIXF_TXFIFOIsEnabled | ( | void | ) |
Is TX FIFO (Transaction FIFO) Enabled or Disabled.