42 #if !defined(LPI2C_DRIVER_H)
43 #define LPI2C_DRIVER_H
68 #define LPI2C_MASTER_CMD_QUEUE_SIZE 5U
78 #if(LPI2C_HAS_FAST_PLUS_MODE)
79 LPI2C_FASTPLUS_MODE = 0x2U,
81 #if(LPI2C_HAS_HIGH_SPEED_MODE)
82 LPI2C_HIGHSPEED_MODE = 0x3U,
84 #if(LPI2C_HAS_ULTRA_FAST_MODE)
85 LPI2C_ULTRAFAST_MODE = 0x4U
120 #if(LPI2C_HAS_HIGH_SPEED_MODE)
164 #if(LPI2C_HAS_HIGH_SPEED_MODE)
173 LPI2C_MASTER_COMMAND_TRANSMIT = 0U,
174 LPI2C_MASTER_COMMAND_RECEIVE = 1U,
175 LPI2C_MASTER_COMMAND_STOP = 2U,
176 LPI2C_MASTER_COMMAND_RECEIVE_DISCARD = 3U,
177 LPI2C_MASTER_COMMAND_START = 4U,
178 LPI2C_MASTER_COMMAND_START_NACK = 5U,
179 LPI2C_MASTER_COMMAND_START_HS = 6U,
180 LPI2C_MASTER_COMMAND_START_NACK_HS = 7U,
181 } lpi2c_master_command_t;
188 lpi2c_master_command_t cmd[LPI2C_MASTER_CMD_QUEUE_SIZE];
189 uint8_t data[LPI2C_MASTER_CMD_QUEUE_SIZE];
192 } lpi2c_master_cmd_queue_t;
206 lpi2c_master_cmd_queue_t cmdQueue;
209 const uint8_t * txBuff;
213 uint16_t slaveAddress;
214 volatile bool i2cIdle;
215 #if(LPI2C_HAS_HIGH_SPEED_MODE)
217 bool highSpeedInProgress;
221 semaphore_t idleSemaphore;
242 volatile bool isTransferInProgress;
245 const uint8_t * txBuff;
250 uint8_t repeatedStarts;
251 bool txUnderrunWarning;
252 semaphore_t idleSemaphore;
269 #if defined(__cplusplus)
372 const uint8_t * txBuff,
391 const uint8_t * txBuff,
516 const uint8_t * txBuff,
553 const uint8_t * txBuff,
572 const uint8_t * txBuff,
627 uint32_t *bytesRemaining);
650 #if defined(S32K11x_SERIES)
664 #if defined(__cplusplus)
status_t LPI2C_DRV_SlaveGetTransferStatus(uint32_t instance, uint32_t *bytesRemaining)
Return the current status of the I2C slave transfer.
lpi2c_mode_t operatingMode
status_t LPI2C_DRV_MasterGetTransferStatus(uint32_t instance, uint32_t *bytesRemaining)
Return the current status of the I2C master transfer.
status_t LPI2C_DRV_MasterAbortTransferData(uint32_t instance)
Abort a non-blocking I2C Master transmission or reception.
lpi2c_transfer_type_t transferType
status_t LPI2C_DRV_SlaveReceiveData(uint32_t instance, uint8_t *rxBuff, uint32_t rxSize)
Perform a non-blocking receive transaction on the I2C bus.
status_t LPI2C_DRV_SlaveSendDataBlocking(uint32_t instance, const uint8_t *txBuff, uint32_t txSize, uint32_t timeout)
Perform a blocking send transaction on the I2C bus.
i2c_master_callback_t masterCallback
lpi2c_transfer_type_t transferType
lpi2c_mode_t
I2C operating modes Implements : lpi2c_mode_t_Class.
void LPI2C_DRV_MasterSetSlaveAddr(uint32_t instance, const uint16_t address, const bool is10bitAddr)
Set the slave address for any subsequent I2C communication.
status_t LPI2C_DRV_SlaveSetRxBuffer(uint32_t instance, uint8_t *rxBuff, uint32_t rxSize)
Provide a buffer for receiving data.
void LPI2C_DRV_MasterGetBaudRate(uint32_t instance, lpi2c_baud_rate_params_t *baudRate)
Get the currently configured baud rate.
status_t LPI2C_DRV_MasterReceiveDataBlocking(uint32_t instance, uint8_t *rxBuff, uint32_t rxSize, bool sendStop, uint32_t timeout)
Perform a blocking receive transaction on the I2C bus.
status_t LPI2C_DRV_MasterSendData(uint32_t instance, const uint8_t *txBuff, uint32_t txSize, bool sendStop)
Perform a non-blocking send transaction on the I2C bus.
status_t LPI2C_DRV_SlaveSetTxBuffer(uint32_t instance, const uint8_t *txBuff, uint32_t txSize)
Provide a buffer for transmitting data.
Slave configuration structure.
Slave internal context structure.
void(* i2c_master_callback_t)(i2c_master_event_t event, void *userData)
lpi2c_transfer_type_t
Type of LPI2C transfer (based on interrupts or DMA). Implements : lpi2c_transfer_type_t_Class.
status_t LPI2C_DRV_SlaveSendData(uint32_t instance, const uint8_t *txBuff, uint32_t txSize)
Perform a non-blocking send transaction on the I2C bus.
status_t LPI2C_DRV_SlaveAbortTransferData(uint32_t instance)
Abort a non-blocking I2C Master transmission or reception.
void LPI2C_DRV_MasterIRQHandler(uint32_t instance)
Handle master operation when I2C interrupt occurs.
status_t
Status return codes. Common error codes will be a unified enumeration (C enum) that will contain all ...
status_t LPI2C_DRV_MasterInit(uint32_t instance, const lpi2c_master_user_config_t *userConfigPtr, lpi2c_master_state_t *master)
Initialize the LPI2C master mode driver.
status_t LPI2C_DRV_MasterDeinit(uint32_t instance)
De-initialize the LPI2C master mode driver.
void LPI2C_DRV_SlaveIRQHandler(uint32_t instance)
Handle slave operation when I2C interrupt occurs.
Defines the example structure.
status_t LPI2C_DRV_SlaveDeinit(uint32_t instance)
De-initialize the I2C slave mode driver.
lpi2c_mode_t operatingMode
void(* i2c_slave_callback_t)(i2c_slave_event_t event, void *userData)
void LPI2C_DRV_MasterSetBaudRate(uint32_t instance, const lpi2c_mode_t operatingMode, const lpi2c_baud_rate_params_t baudRate)
Set the baud rate for any subsequent I2C communication.
Master internal context structure.
status_t LPI2C_DRV_MasterReceiveData(uint32_t instance, uint8_t *rxBuff, uint32_t rxSize, bool sendStop)
Perform a non-blocking receive transaction on the I2C bus.
status_t LPI2C_DRV_SlaveReceiveDataBlocking(uint32_t instance, uint8_t *rxBuff, uint32_t rxSize, uint32_t timeout)
Perform a blocking receive transaction on the I2C bus.
status_t LPI2C_DRV_SlaveInit(uint32_t instance, const lpi2c_slave_user_config_t *userConfigPtr, lpi2c_slave_state_t *slave)
Initialize the I2C slave mode driver.
status_t LPI2C_DRV_MasterSendDataBlocking(uint32_t instance, const uint8_t *txBuff, uint32_t txSize, bool sendStop, uint32_t timeout)
Perform a blocking send transaction on the I2C bus.
i2c_slave_callback_t slaveCallback
void LPI2C_DRV_ModuleIRQHandler(uint32_t instance)
Handler for both slave and master operation when I2C interrupt occurs.