I2C LLD Driver API/interface file.
Go to the source code of this file.
Data Structures | |
struct | I2CLLD_Transaction |
I2C Transaction. More... | |
struct | I2CLLD_Message |
I2C Message. More... | |
struct | I2C_ExtendedParams |
Data structure used with I2C_lld_write(), I2C_lld_writeIntr(), I2C_lld_read(), I2C_lld_readIntr() More... | |
struct | I2C_Memory_ExtendedParams |
Data structure used with I2C_lld_mem_write(), I2C_lld_mem_writeIntr(), I2C_lld_mem_read(), I2C_lld_mem_readIntr() More... | |
struct | I2CLLD_targetTransaction |
I2C Target Transaction. More... | |
struct | I2CLLD_Object |
I2C Driver Object. More... | |
Macros | |
#define | I2C_MAX_NUM_OWN_TARGET_ADDR (4U) |
Return status | |
#define | I2C_STS_SUCCESS ((int32_t) 0) |
Return status when the API execution was successful. More... | |
#define | I2C_STS_ERR ((int32_t)-1) |
Return status when the API execution was not successful due to a generic Error. More... | |
#define | I2C_STS_ERR_TIMEOUT ((int32_t)-2) |
Return status when the API execution was not successful due to a time out. More... | |
#define | I2C_STS_ERR_INVALID_PARAM ((int32_t)-3) |
Return status when the API execution failed due invalid parameters. More... | |
#define | I2C_STS_ERR_BUS_BUSY ((int32_t)-4) |
Return status when the API execution failed due to driver busy. More... | |
#define | I2C_STS_ERR_NO_ACK ((int32_t)-5) |
Return status when the API execution failed due to no Acknowledgement from target. More... | |
#define | I2C_STS_ERR_ARBITRATION_LOST ((int32_t)-6) |
Return status when the API execution failed due to loss in arbitration during transmission. More... | |
#define | I2C_STS_ERR_ACCESS_ERROR ((int32_t)-7) |
Timeout values | |
#define | I2C_NO_WAIT ((uint32_t)0) |
Value to use when needing a timeout of zero or NO timeout, return immediately on resource not available. More... | |
#define | I2C_WAIT_FOREVER ((uint32_t)-1) |
Value to use when needing a timeout of infinity or wait forver until resource is available. More... | |
I2C Driver states | |
#define | I2C_STATE_RESET ((uint8_t) 0U) |
I2C driver is in Reset State prior to driver init and post driver deinit. More... | |
#define | I2C_STATE_IDLE ((uint8_t) 1U) |
I2C driver accepts runtime APIs only Ready State, otherwise return error. More... | |
#define | I2C_STATE_BUSY ((uint8_t) 2U) |
I2C driver is busy performing operation with peripherals, return error when APIs are invoked. More... | |
#define | I2C_STATE_ERROR ((uint8_t) 3U) |
I2C driver ran into error, returns error for all APIs other than deinit in this state. More... | |
MACROS used to select one of the standardized bus bit rates for | |
#define | I2C_100KHZ ((uint8_t) 0U) |
I2C bus frequency : 100KHz. More... | |
#define | I2C_400KHZ ((uint8_t) 1U) |
I2C bus frequency : 400KHz. More... | |
#define | I2C_1P0MHZ ((uint8_t) 2U) |
I2C bus frequency : 1.0MHz. More... | |
#define | I2C_3P4MHZ ((uint8_t) 3U) |
I2C bus frequency : 3.4MHz. More... | |
MACROS for the possible values of Memory Write/Read API parameter. | |
#define | I2C_MEM_ADDR_SIZE_8_BITS ((uint8_t) 1U) |
I2C Target Internal Memory address 8 bits. More... | |
#define | I2C_MEM_ADDR_SIZE_16_BITS ((uint8_t) 2U) |
I2C Target Internal Memory address 16 bits. More... | |
MACROS used to define the state of the I2C Driver State Machine | |
#define | I2C_WRITE_STATE ((uint8_t) 10U) |
I2C is in Write state. More... | |
#define | I2C_READ_STATE ((uint8_t) 11U) |
I2C is in Write state. More... | |
#define | I2C_TARGET_XFER_STATE ((uint8_t) 12U) |
I2C is trasferring in target mode. More... | |
#define | I2C_TARGET_RESTART_STATE ((uint8_t) 13U) |
I2C is restarting trasfer in target mode. More... | |
Typedefs | |
typedef uint32_t(* | I2C_Clock_getTicks) (void) |
The definition of a get System Tick function used by the I2C driver to keep track of time. More... | |
typedef uint64_t(* | I2C_Clock_usecToTicks) (uint64_t usecs) |
The definition of a micro seconds to ticks function used by the I2C driver to get ticks from microseconds. More... | |
typedef void(* | I2C_Clock_uSleep) (uint64_t usec) |
The definition of a sleep function used by the I2C driver for delay. More... | |
typedef void(* | I2C_lld_transferCompleteCallback) (void *args, const I2CLLD_Message *msg, int32_t transferStatus) |
The definition of a transfer completion callback function used by the I2C driver when used in Controller Callback Mode. More... | |
typedef void(* | I2C_lld_targetTransferCompleteCallback) (void *args, const I2CLLD_targetTransaction *targetTxn, int32_t transferStatus) |
The definition of a transfer completion callback function used by the I2C driver when used in Target Mode. More... | |
typedef struct I2CLLD_Object * | I2CLLD_Handle |
Functions | |
int32_t | I2C_lld_init (I2CLLD_Handle handle) |
This API Initializes the I2C instance. More... | |
int32_t | I2C_lld_deInit (I2CLLD_Handle handle) |
This API De-Initializes the I2C instance. More... | |
int32_t | I2C_lld_Transaction_init (I2CLLD_Transaction *transaction) |
API to set default values of I2CLLD_Transaction in transaction. More... | |
int32_t | I2C_lld_Message_init (I2CLLD_Message *msg) |
API to set default values of I2CLLD_Message in msg. More... | |
int32_t | I2C_lld_write (I2CLLD_Handle handle, I2C_ExtendedParams *extendedParams, uint32_t timeout) |
API to initiate the write transaction in polled mode. More... | |
int32_t | I2C_lld_writeIntr (I2CLLD_Handle handle, I2C_ExtendedParams *extendedParams) |
API to initiate the write transaction in Interrupt mode. More... | |
int32_t | I2C_lld_read (I2CLLD_Handle handle, I2C_ExtendedParams *extendedParams, uint32_t timeout) |
API to initiate the read transaction in polled mode. More... | |
int32_t | I2C_lld_readIntr (I2CLLD_Handle handle, I2C_ExtendedParams *extendedParams) |
API to initiate the read transaction in Interrupt mode. More... | |
int32_t | I2C_lld_mem_write (I2CLLD_Handle handle, I2C_Memory_ExtendedParams *mem_extendedParams, uint32_t timeout) |
Function to initiate a transfer from I2C in interrupt mode. More... | |
int32_t | I2C_lld_mem_writeIntr (I2CLLD_Handle handle, I2C_Memory_ExtendedParams *mem_extendedParams) |
Function to initiate a transfer from I2C in interrupt mode. More... | |
int32_t | I2C_lld_mem_read (I2CLLD_Handle handle, I2C_Memory_ExtendedParams *mem_extendedParams, uint32_t timeout) |
Function to initiate a transfer from I2C in interrupt mode. More... | |
int32_t | I2C_lld_mem_readIntr (I2CLLD_Handle handle, I2C_Memory_ExtendedParams *mem_extendedParams) |
Function to initiate a transfer from I2C in interrupt mode. More... | |
int32_t | I2C_lld_transferPoll (I2CLLD_Handle handle, I2CLLD_Message *msg) |
Function to initiate a transfer from I2C in polled mode. More... | |
int32_t | I2C_lld_transferIntr (I2CLLD_Handle handle, I2CLLD_Message *msg) |
Function to initiate a transfer from I2C in interrupt mode. More... | |
int32_t | I2C_lld_targetTransferIntr (I2CLLD_Handle handle, I2CLLD_targetTransaction *txn) |
Function to initiate a transfer from I2C in target mode. More... | |
int32_t | I2C_lld_probe (I2CLLD_Handle handle, uint32_t targetAddr) |
Function to probe I2C. More... | |
int32_t | I2C_lld_setBusFrequency (I2CLLD_Handle handle, uint32_t busFrequency) |
Function to set the bus frequency. More... | |
int32_t | I2C_lld_recoverBus (I2CLLD_Handle handle, uint32_t i2cDelay) |
Function to recover the bus in case of lockup. More... | |
void | I2C_lld_controllerIsr (void *args) |
This is the I2C Controller ISR and can be used as IRQ handler in Controller mode. More... | |
void | I2C_lld_targetIsr (void *args) |
This is the I2C Target ISR and can be used as IRQ handler in Target mode. More... | |