Lines Matching +full:handle +full:- +full:rx +full:- +full:in +full:- +full:isr

4  * SPDX-License-Identifier: Apache-2.0
29 #include "i2c-priv.h"
44 (((const struct i2c_cc32xx_config *const)(dev)->config)->base)
47 /* Since this driver does not explicitly enable the TX/RX FIFOs, there
52 * The ERROR flag is used to convey error status from the ISR back to the
53 * I2C API without having to re-read I2C registers.
78 uint16_t slave_addr; /* Cache slave address for ISR use */
91 return -EINVAL; in i2c_cc32xx_configure()
95 return -EINVAL; in i2c_cc32xx_configure()
106 return -EINVAL; in i2c_cc32xx_configure()
118 struct i2c_cc32xx_data *data = dev->data; in i2c_cc32xx_prime_transfer()
122 data->msg = *msg; in i2c_cc32xx_prime_transfer()
123 data->slave_addr = addr; in i2c_cc32xx_prime_transfer()
125 /* Start transfer in Transmit mode */ in i2c_cc32xx_prime_transfer()
126 if (IS_I2C_MSG_WRITE(data->msg.flags)) { in i2c_cc32xx_prime_transfer()
132 data->state = I2C_CC32XX_WRITE_MODE; in i2c_cc32xx_prime_transfer()
135 MAP_I2CMasterDataPut(base, *((data->msg.buf)++)); in i2c_cc32xx_prime_transfer()
137 /* Start the I2C transfer in master transmit mode */ in i2c_cc32xx_prime_transfer()
141 /* Start transfer in Receive mode */ in i2c_cc32xx_prime_transfer()
146 data->state = I2C_CC32XX_READ_MODE; in i2c_cc32xx_prime_transfer()
148 if (data->msg.len < 2) { in i2c_cc32xx_prime_transfer()
149 /* Start the I2C transfer in master receive mode */ in i2c_cc32xx_prime_transfer()
153 /* Start the I2C transfer in burst receive mode */ in i2c_cc32xx_prime_transfer()
163 struct i2c_cc32xx_data *data = dev->data; in i2c_cc32xx_transfer()
167 k_sem_take(&data->mutex, K_FOREVER); in i2c_cc32xx_transfer()
176 k_sem_take(&data->transfer_complete, K_FOREVER); in i2c_cc32xx_transfer()
179 if (data->state == I2C_CC32XX_ERROR) { in i2c_cc32xx_transfer()
180 retval = -EIO; in i2c_cc32xx_transfer()
189 k_sem_give(&data->mutex); in i2c_cc32xx_transfer()
198 data->msg.len--; in i2c_cc32xx_isr_handle_write()
201 if (data->msg.len) { in i2c_cc32xx_isr_handle_write()
204 MAP_I2CMasterDataPut(base, *(data->msg.buf)); in i2c_cc32xx_isr_handle_write()
205 data->msg.buf++; in i2c_cc32xx_isr_handle_write()
207 if (data->msg.len < 2) { in i2c_cc32xx_isr_handle_write()
236 *(data->msg.buf) = MAP_I2CMasterDataGet(base); in i2c_cc32xx_isr_handle_read()
237 data->msg.buf++; in i2c_cc32xx_isr_handle_read()
240 data->msg.len--; in i2c_cc32xx_isr_handle_read()
241 if (data->msg.len) { in i2c_cc32xx_isr_handle_read()
242 if (data->msg.len > 1) { in i2c_cc32xx_isr_handle_read()
266 struct i2c_cc32xx_data *data = dev->data; in i2c_cc32xx_isr()
280 data->state, err_status, int_status); in i2c_cc32xx_isr()
282 /* Handle errors: */ in i2c_cc32xx_isr()
288 data->state = I2C_CC32XX_ERROR; in i2c_cc32xx_isr()
294 * I2C_MASTER_CMD_BURST_SEND_ERROR_STOP -and- in i2c_cc32xx_isr()
302 k_sem_give(&data->transfer_complete); in i2c_cc32xx_isr()
304 /* Handle Stop: */ in i2c_cc32xx_isr()
307 k_sem_give(&data->transfer_complete); in i2c_cc32xx_isr()
309 /* Handle (read or write) transmit complete: */ in i2c_cc32xx_isr()
311 if (data->state == I2C_CC32XX_WRITE_MODE) { in i2c_cc32xx_isr()
314 if (data->state == I2C_CC32XX_READ_MODE) { in i2c_cc32xx_isr()
320 data->state = I2C_CC32XX_ERROR; in i2c_cc32xx_isr()
321 k_sem_give(&data->transfer_complete); in i2c_cc32xx_isr()
328 const struct i2c_cc32xx_config *config = dev->config; in i2c_cc32xx_init()
329 struct i2c_cc32xx_data *data = dev->data; in i2c_cc32xx_init()
341 error = pinctrl_apply_state(config->pcfg, PINCTRL_STATE_DEFAULT); in i2c_cc32xx_init()
346 k_sem_init(&data->mutex, 1, K_SEM_MAX_LIMIT); in i2c_cc32xx_init()
347 k_sem_init(&data->transfer_complete, 0, K_SEM_MAX_LIMIT); in i2c_cc32xx_init()
349 /* In case of app restart: disable I2C module, clear NVIC interrupt */ in i2c_cc32xx_init()
350 /* Note: this was done *during* pinmux setup in SimpleLink SDK. */ in i2c_cc32xx_init()
354 MAP_IntPendClear((unsigned long)(config->irq_no + 16)); in i2c_cc32xx_init()
364 bitrate_cfg = i2c_map_dt_bitrate(config->bitrate); in i2c_cc32xx_init()
412 irq_enable(config->irq_no); in configure_i2c_irq()