34#define I2C_CTL_STA_SI 0x28UL
35#define I2C_CTL_STA_SI_AA 0x2CUL
36#define I2C_CTL_STO_SI 0x18UL
37#define I2C_CTL_STO_SI_AA 0x1CUL
38#define I2C_CTL_SI 0x08UL
39#define I2C_CTL_SI_AA 0x0CUL
40#define I2C_CTL_STA 0x20UL
41#define I2C_CTL_STO 0x10UL
42#define I2C_CTL_AA 0x04UL
47#define I2C_GCMODE_ENABLE 1
48#define I2C_GCMODE_DISABLE 0
53#define I2C_SMBH_ENABLE 1
54#define I2C_SMBD_ENABLE 0
55#define I2C_PECTX_ENABLE 1
56#define I2C_PECTX_DISABLE 0
73#define I2C_SET_CONTROL_REG(i2c, u8Ctrl) ((i2c)->CTL = ((i2c)->CTL & ~0x3c) | (u8Ctrl))
84#define I2C_START(i2c) ((i2c)->CTL = ((i2c)->CTL & ~I2C_CTL_SI_Msk) | I2C_CTL_STA_Msk)
95#define I2C_WAIT_READY(i2c) while(!((i2c)->CTL & I2C_CTL_SI_Msk))
106#define I2C_GET_DATA(i2c) ((i2c)->DAT)
118#define I2C_SET_DATA(i2c, u8Data) ((i2c)->DAT = (u8Data))
129#define I2C_GET_STATUS(i2c) ((i2c)->STATUS)
141#define I2C_GET_TIMEOUT_FLAG(i2c) ( ((i2c)->TOCTL & I2C_TOCTL_TOIF_Msk) == I2C_TOCTL_TOIF_Msk ? 1:0 )
153#define I2C_GET_WAKEUP_FLAG(i2c) ( ((i2c)->WKSTS & I2C_WKSTS_WKIF_Msk) == I2C_WKSTS_WKIF_Msk ? 1:0 )
164#define I2C_CLEAR_WAKEUP_FLAG(i2c) ((i2c)->WKSTS = I2C_WKSTS_WKIF_Msk)
176#define I2C_SMBUS_GET_STATUS(i2c) ((i2c)->BUSSTS)
188#define I2C_SMBUS_GET_PEC_VALUE(i2c) ((i2c)->PKTCRC)
201#define I2C_SMBUS_SET_PACKET_BYTE_COUNT(i2c, u32PktSize) ((i2c)->PKTSIZE = (u32PktSize))
214#define I2C_SMBUS_ENABLE_ALERT(i2c) ((i2c)->BUSCTL |= I2C_BUSCTL_ALERTEN_Msk)
227#define I2C_SMBUS_DISABLE_ALERT(i2c) ((i2c)->BUSCTL &= ~I2C_BUSCTL_ALERTEN_Msk)
240#define I2C_SMBUS_SET_SUSCON_OUT(i2c) ((i2c)->BUSCTL |= I2C_BUSCTL_SCTLOEN_Msk)
253#define I2C_SMBUS_SET_SUSCON_IN(i2c) ((i2c)->BUSCTL &= ~I2C_BUSCTL_SCTLOEN_Msk)
265#define I2C_SMBUS_SET_SUSCON_HIGH(i2c) ((i2c)->BUSCTL |= I2C_BUSCTL_SCTLOSTS_Msk)
278#define I2C_SMBUS_SET_SUSCON_LOW(i2c) ((i2c)->BUSCTL &= ~I2C_BUSCTL_SCTLOSTS_Msk)
290#define I2C_SMBUS_ACK_MANUAL(i2c) ((i2c)->BUSCTL |= I2C_BUSCTL_ACKMEN_Msk)
302#define I2C_SMBUS_ACK_AUTO(i2c) ((i2c)->BUSCTL &= ~I2C_BUSCTL_ACKMEN_Msk)
314#define I2C_SMBUS_9THBIT_INT_ENABLE(i2c) ((i2c)->BUSCTL |= I2C_BUSCTL_ACKM9SI_Msk)
326#define I2C_SMBUS_9THBIT_INT_DISABLE(i2c) ((i2c)->BUSCTL &= ~I2C_BUSCTL_ACKM9SI_Msk)
338#define I2C_SMBUS_RST_PEC_AT_START_ENABLE(i2c) ((i2c)->BUSCTL |= I2C_BUSCTL_PECCLR_Msk)
350#define I2C_SMBUS_RST_PEC_AT_START_DISABLE(i2c) ((i2c)->BUSCTL &= ~I2C_BUSCTL_PECCLR_Msk)
370 if(u32TimeOutCount == 0)
378void I2C_Trigger(
I2C_T *i2c, uint8_t u8Start, uint8_t u8Stop, uint8_t u8Si, uint8_t u8Ack);
NuMicro peripheral access layer header file.
uint32_t I2C_SMBusGetStatus(I2C_T *i2c)
To get SMBus Status.
void I2C_SMBusIdleTimeout(I2C_T *i2c, uint32_t us, uint32_t u32Hclk)
Calculate Time-out of SMBus idle period.
void I2C_SetSlaveAddrMask(I2C_T *i2c, uint8_t u8SlaveNo, uint8_t u8SlaveAddrMask)
Configure the mask bits of 7-bit Slave Address.
static __INLINE int32_t I2C_STOP(I2C_T *i2c)
The macro is used to set STOP condition of I2C Bus.
void I2C_Close(I2C_T *i2c)
Disable specify I2C Controller.
void I2C_SMBusSetPacketByteCount(I2C_T *i2c, uint32_t u32PktSize)
Set SMBus Bytes Counts of Transmission or Reception.
uint32_t I2C_SetBusClockFreq(I2C_T *i2c, uint32_t u32BusClock)
Set I2C Bus Clock.
void I2C_Trigger(I2C_T *i2c, uint8_t u8Start, uint8_t u8Stop, uint8_t u8Si, uint8_t u8Ack)
Set Control bit of I2C Controller.
void I2C_SMBusClose(I2C_T *i2c)
Disable SMBus function.
void I2C_EnableTimeout(I2C_T *i2c, uint8_t u8LongTimeout)
Enable Time-out Counter Function and support Long Time-out.
void I2C_SMBusClockLoTimeout(I2C_T *i2c, uint32_t ms, uint32_t u32Pclk)
Calculate Cumulative Clock low Time-out of SMBus active period.
void I2C_ClearTimeoutFlag(I2C_T *i2c)
Clear Time-out Counter flag.
void I2C_SetSlaveAddr(I2C_T *i2c, uint8_t u8SlaveNo, uint8_t u8SlaveAddr, uint8_t u8GCMode)
Set 7-bit Slave Address and GC Mode.
void I2C_SetData(I2C_T *i2c, uint8_t u8Data)
Send a byte to I2C Bus.
uint32_t I2C_GetBusClockFreq(I2C_T *i2c)
Get I2C Bus Clock.
void I2C_EnableInt(I2C_T *i2c)
Enable Interrupt of I2C Controller.
void I2C_DisableWakeup(I2C_T *i2c)
Disable I2C Wake-up Function.
uint32_t I2C_GetStatus(I2C_T *i2c)
Get I2C Bus Status Code.
void I2C_DisableInt(I2C_T *i2c)
Disable Interrupt of I2C Controller.
void I2C_SMBusPECTxEnable(I2C_T *i2c, uint8_t u8PECTxEn)
Enable SMBus PEC Transmit Function.
void I2C_EnableWakeup(I2C_T *i2c)
Enable I2C Wake-up Function.
void I2C_SMBusOpen(I2C_T *i2c, uint8_t u8HostDevice)
Init SMBus Host/Device Mode.
uint32_t I2C_GetIntFlag(I2C_T *i2c)
Get Interrupt Flag.
void I2C_SMBusTimeout(I2C_T *i2c, uint32_t ms, uint32_t u32Pclk)
Calculate Time-out of SMBus active period.
uint8_t I2C_GetData(I2C_T *i2c)
Read a Byte from I2C Bus.
uint8_t I2C_SMBusGetPECValue(I2C_T *i2c)
Get SMBus CRC value.
uint32_t I2C_Open(I2C_T *i2c, uint32_t u32BusClock)
Enable specify I2C Controller and set Clock Divider.
void I2C_DisableTimeout(I2C_T *i2c)
Disable Time-out Counter Function.
void I2C_SMBusClearInterruptFlag(I2C_T *i2c, uint8_t u8ClrSMBusIntFlag)
Clear SMBus Interrupt Flag.