/* * Copyright (c) 2006-2022, RT-Thread Development Team * * SPDX-License-Identifier: Apache-2.0 * * Change Logs: * Date Author Notes * 2011-01-07 onelife Initial creation for EFM32 * 2011-07-11 onelife Add lock (semaphore) to prevent simultaneously access * 2011-08-04 onelife Change the usage of the second parameter of Read * and Write functions from (seldom used) "Offset" to "Slave address" * 2011-08-04 onelife Add a timer to prevent from forever waiting * 2011-12-27 onelife Change IIC read format */ #ifndef __DRV_IIC_H__ #define __DRV_IIC_H__ /* Includes ------------------------------------------------------------------*/ /* Exported types ------------------------------------------------------------*/ struct efm32_iic_int_mode_t { rt_uint8_t *data_ptr; rt_uint8_t data_size; rt_uint32_t read_index, save_index; }; struct efm32_iic_device_t { /* Counter */ rt_uint32_t counter; /* Lock */ struct rt_semaphore *lock; /* Pointer to timer */ rt_timer_t timer; /* Timeout flag */ volatile rt_bool_t timeout; /* State */ rt_uint8_t state; /* Pointer to IIC device structure */ I2C_TypeDef *iic_device; /* Self address */ rt_uint16_t address; /* RX structure */ struct efm32_iic_int_mode_t *rx_buffer; }; struct efm32_iic_control_t { rt_uint8_t config; rt_uint16_t address; }; /* Exported constants --------------------------------------------------------*/ /* Exported macro ------------------------------------------------------------*/ #define IIC_STATE_MASTER (1 << 0) #define IIC_STATE_BROADCAST (1 << 1) //#define IIC_STATE_TX_BUSY (1 << 2) #define IIC_STATE_RX_BUSY (1 << 3) #define IIC_TIMEOUT_PERIOD (RT_TICK_PER_SECOND) #define IIC_OP_READ_ONLY (0xFF) /* Exported functions --------------------------------------------------------*/ void rt_hw_iic_init(void); #endif /* __DRV_IIC_H__ */