72 #include <ti/csl/soc.h> 85 #define SPI_CMD_RESERVED (32U) 86 #define OSPI_CMD_RESERVED (32U) 100 #define SPI_STATUS_RESERVED (-((int32_t)32)) 108 #define SPI_STATUS_SUCCESS (int32_t)(0) 116 #define SPI_STATUS_ERROR (-((int32_t)1)) 125 #define SPI_STATUS_UNDEFINEDCMD (-((int32_t)2)) 130 #define SPI_WAIT_FOREVER (~(0U)) 140 typedef enum SPI_Status_s {
157 typedef struct SPI_Transaction_s {
185 typedef enum SPI_Mode_s {
194 typedef enum SPI_FrameFormat_s {
213 typedef enum SPI_TransferMode_s {
234 typedef struct SPI_Params_s {
299 typedef struct SPI_FxnTable_s {
333 typedef struct SPI_Config_s {
344 #define SPI_MAX_CONFIG_CNT (CSL_MCSPI_PER_CNT) 345 #define SPI_MAX_DOMAIN_CNT (CSL_MCSPI_DOMAIN_CNT) 351 typedef enum OSPI_Status_s {
368 typedef struct OSPI_Transaction_s {
399 typedef enum OSPI_Mode_s {
408 typedef enum OSPI_FrameFormat_s {
427 typedef enum OSPI_TransferMode_s {
448 typedef struct OSPI_Params_s {
514 typedef struct OSPI_FxnTable_s {
548 typedef struct OSPI_Config_s {
559 #define OSPI_MAX_CONFIG_CNT (CSL_OSPI_PER_CNT) 560 #define OSPI_MAX_DOMAIN_CNT (CSL_OSPI_DOMAIN_CNT) void * txBuf
Definition: SPI.h:371
OSPI_FrameFormat frameFormat
Definition: SPI.h:457
void(* SPI_TransferCancelFxn)(SPI_Handle handle)
A function pointer to a driver specific implementation of SPI_transferCancel().
Definition: SPI.h:292
bool(* SPI_TransferFxn)(SPI_Handle handle, SPI_Transaction *transaction)
A function pointer to a driver specific implementation of SPI_transfer().
Definition: SPI.h:285
The definition of a SPI function table that contains the required set of functions to control a speci...
Definition: SPI.h:299
SPI_FxnTable const * fxnTablePtr
Definition: SPI.h:335
int32_t OSPI_control(OSPI_Handle handle, uint32_t cmd, void *arg)
Function performs implementation specific features on a given OSPI_Handle.
OSPI_TransferFxn transferFxn
Definition: SPI.h:528
OSPI_ControlFxn controlFxn
Definition: SPI.h:519
OSPI_ServiceISRFxn serviceISRFxn
Definition: SPI.h:534
uint32_t dataSize
Definition: SPI.h:242
void SPI_init(void)
This function initializes the SPI module.
uint32_t transferTimeout
Definition: SPI.h:236
SPI_Mode
Definitions for various SPI modes of operation.
Definition: SPI.h:185
SPI_CallbackFxn transferCallbackFxn
Definition: SPI.h:239
SPI_FrameFormat frameFormat
Definition: SPI.h:243
void OSPI_init(void)
This function initializes the SPI module.
SPI_FrameFormat
Definitions for various SPI data frame formats.
Definition: SPI.h:194
void SPI_Params_init(SPI_Params *params)
Function to initialize the SPI_Params struct to its defaults.
OSPI_Mode mode
Definition: SPI.h:454
SPI_Status status
Definition: SPI.h:167
SPI Parameters.
Definition: SPI.h:234
SPI_Handle(* SPI_OpenFxn)(SPI_Handle handle, const SPI_Params *params)
A function pointer to a driver specific implementation of SPI_open().
Definition: SPI.h:272
OSPI_CallbackFxn transferCallbackFxn
Definition: SPI.h:453
#define SPI_MAX_DOMAIN_CNT
Definition: SPI.h:345
struct SPI_Config_s * SPI_Handle
A handle that is returned from a SPI_open() call.
Definition: SPI.h:135
void(* SPI_CloseFxn)(SPI_Handle handle)
A function pointer to a driver specific implementation of SPI_close().
Definition: SPI.h:252
SPI_CloseFxn closeFxn
Definition: SPI.h:301
int32_t(* OSPI_ControlFxn)(OSPI_Handle handle, uint32_t cmd, const void *arg)
A function pointer to a driver specific implementation of OSPI_control().
Definition: SPI.h:472
OSPI_InitFxn spiInitFxn
Definition: SPI.h:522
void OSPI_close(OSPI_Handle handle)
Function to close a OSPI peripheral specified by the OSPI handle.
SPI_TransferMode transferMode
Definition: SPI.h:235
#define OSPI_MAX_DOMAIN_CNT
Definition: SPI.h:560
bool OSPI_transfer(OSPI_Handle handle, OSPI_Transaction *spiTrans)
Function to perform SPI transactions.
SPI_TransferFxn transferFxn
Definition: SPI.h:313
#define SPI_MAX_CONFIG_CNT
Definition: SPI.h:344
void OSPI_Params_init(OSPI_Params *params)
Function to initialize the OSPI_Params struct to its defaults.
OSPI_Status
Status codes that are set by the SPI driver.
Definition: SPI.h:351
void(* SPI_CallbackFxn)(SPI_Handle handle, SPI_Transaction *transaction)
The definition of a callback function used by the SPI driver when used in SPI_MODE_CALLBACK.
Definition: SPI.h:179
uint32_t bitRate
Definition: SPI.h:241
void(* OSPI_TransferCancelFxn)(OSPI_Handle handle)
A function pointer to a driver specific implementation of OSPI_transferCancel().
Definition: SPI.h:506
size_t count
Definition: SPI.h:370
void(* SPI_InitFxn)(SPI_Handle handle)
A function pointer to a driver specific implementation of SPI_init().
Definition: SPI.h:266
void SPI_close(SPI_Handle handle)
Function to close a SPI peripheral specified by the SPI handle.
OSPI_Status status
Definition: SPI.h:376
void * arg
Definition: SPI.h:164
void * custom
Definition: SPI.h:458
OSPI Global configuration.
Definition: SPI.h:548
void * rxBuf
Definition: SPI.h:163
uint64_t txDmaBuf
Definition: SPI.h:160
void(* OSPI_CallbackFxn)(OSPI_Handle handle, OSPI_Transaction *transaction)
The definition of a callback function used by the SPI driver when used in SPI_MODE_CALLBACK.
Definition: SPI.h:393
SPI_TransferCancelFxn transferCancelFxn
Definition: SPI.h:316
void * object
Definition: SPI.h:553
void(* OSPI_ServiceISRFxn)(OSPI_Handle handle)
A function pointer to a driver specific implementation of SPI_serviceISR().
Definition: SPI.h:493
OSPI Parameters.
Definition: SPI.h:448
OSPI_FxnTable const * fxnTablePtr
Definition: SPI.h:550
OSPI_TransferMode transferMode
Definition: SPI.h:449
SPI_ControlFxn controlFxn
Definition: SPI.h:304
OSPI_FrameFormat
Definitions for various SPI data frame formats.
Definition: SPI.h:408
SPI_OpenFxn openFxn
Definition: SPI.h:310
void * object
Definition: SPI.h:338
A SPI_Transaction data structure is used with OSPI_transfer(). It indicates how many SPI_FrameFormat ...
Definition: SPI.h:368
SPI_ServiceISRFxn serviceISRFxn
Definition: SPI.h:319
void SPI_transferCancel(SPI_Handle handle)
Function to cancel SPI transactions.
void(* OSPI_InitFxn)(OSPI_Handle handle)
A function pointer to a driver specific implementation of OSPI_init().
Definition: SPI.h:480
SPI_TransferMode
SPI transfer mode determines the whether the SPI controller operates synchronously or asynchronously....
Definition: SPI.h:213
void * rxBuf
Definition: SPI.h:372
SPI_Handle SPI_open(uint32_t domain, uint32_t idx, SPI_Params *params)
This function opens a given SPI peripheral.
SPI_InitFxn spiInitFxn
Definition: SPI.h:307
gptp_ipc_command_t cmd
Definition: gptpipc.h:140
void * custom
Definition: SPI.h:244
SPI_Status
Status codes that are set by the SPI driver.
Definition: SPI.h:140
The definition of a SPI function table that contains the required set of functions to control a speci...
Definition: SPI.h:514
uint32_t dataSize
Definition: SPI.h:456
domgrp_t domain
Definition: tisci_pm_core.h:130
bool(* OSPI_TransferFxn)(OSPI_Handle handle, OSPI_Transaction *transaction)
A function pointer to a driver specific implementation of OSPI_transfer().
Definition: SPI.h:499
SPI_Config SPI_config_list[SPI_MAX_DOMAIN_CNT][SPI_MAX_CONFIG_CNT]
Definition: SPI.h:346
OSPI_Handle OSPI_open(uint32_t domain, uint32_t idx, OSPI_Params *params)
This function opens a given OSPI peripheral.
OSPI_TransferCancelFxn transferCancelFxn
Definition: SPI.h:531
OSPI_OpenFxn openFxn
Definition: SPI.h:525
SPI_Mode mode
Definition: SPI.h:240
OSPI_CloseFxn closeFxn
Definition: SPI.h:516
void(* OSPI_CloseFxn)(OSPI_Handle handle)
A function pointer to a driver specific implementation of OSPI_close().
Definition: SPI.h:466
OSPI_Mode
Definitions for various SPI modes of operation.
Definition: SPI.h:399
bool SPI_transfer(SPI_Handle handle, SPI_Transaction *spiTrans)
Function to perform SPI transactions.
void SPI_serviceISR(SPI_Handle handle)
Function to service the SPI module's interrupt service routine.
void * arg
Definition: SPI.h:373
uint64_t rxDmaBuf
Definition: SPI.h:161
OSPI_Handle(* OSPI_OpenFxn)(OSPI_Handle handle, const OSPI_Params *params)
A function pointer to a driver specific implementation of SPI_open().
Definition: SPI.h:486
int32_t(* SPI_ControlFxn)(SPI_Handle handle, uint32_t cmd, const void *arg)
A function pointer to a driver specific implementation of SPI_control().
Definition: SPI.h:258
void(* SPI_ServiceISRFxn)(SPI_Handle handle)
A function pointer to a driver specific implementation of SPI_serviceISR().
Definition: SPI.h:279
struct OSPI_Config_s * OSPI_Handle
A handle that is returned from a SPI_open() call.
Definition: SPI.h:384
OSPI_TransferMode
SPI transfer mode determines the whether the SPI controller operates synchronously or asynchronously....
Definition: SPI.h:427
size_t count
Definition: SPI.h:159
uint32_t transferTimeout
Definition: SPI.h:450
void const * hwAttrs
Definition: SPI.h:556
void const * hwAttrs
Definition: SPI.h:341
uint32_t bitRate
Definition: SPI.h:455
void * txBuf
Definition: SPI.h:162
OSPI_Config OSPI_config_list[OSPI_MAX_DOMAIN_CNT][OSPI_MAX_CONFIG_CNT]
Definition: SPI.h:561
A SPI_Transaction data structure is used with SPI_transfer(). It indicates how many SPI_FrameFormat f...
Definition: SPI.h:157
SPI Global configuration.
Definition: SPI.h:333
#define OSPI_MAX_CONFIG_CNT
Definition: SPI.h:559
int32_t SPI_control(SPI_Handle handle, uint32_t cmd, void *arg)
Function performs implementation specific features on a given SPI_Handle.