From 317b7efc7f70e3e4292ccbc3e1a564623a316445 Mon Sep 17 00:00:00 2001 From: Gregory Nutt Date: Mon, 5 Jan 2015 13:15:40 -0600 Subject: [PATCH] Tiva: Fixes to support building Tiva TM4C129X I2C driver --- arch/arm/src/tiva/chip/tiva_i2c.h | 72 +++++++++++++++---------------- arch/arm/src/tiva/tiva_i2c.c | 16 +++---- 2 files changed, 44 insertions(+), 44 deletions(-) diff --git a/arch/arm/src/tiva/chip/tiva_i2c.h b/arch/arm/src/tiva/chip/tiva_i2c.h index 434db64e1d..d60a6c4007 100644 --- a/arch/arm/src/tiva/chip/tiva_i2c.h +++ b/arch/arm/src/tiva/chip/tiva_i2c.h @@ -917,74 +917,74 @@ /* I2C Slave Interrupt Mask (I2CS_IMR) */ -#define I2CM_IMR_DATAIM (1 << 0) /* Bit 0: Data Interrupt Mask */ +#define I2CS_IMR_DATAIM (1 << 0) /* Bit 0: Data Interrupt Mask */ #if defined(CONFIG_ARCH_CHIP_TM4C) -# define I2CM_IMR_STARTIM (1 << 1) /* Bit 1: Start Condition Interrupt Mask */ -# define I2CM_IMR_STOPIM (1 << 2) /* Bit 2: Stop Condition Interrupt Mask */ +# define I2CS_IMR_STARTIM (1 << 1) /* Bit 1: Start Condition Interrupt Mask */ +# define I2CS_IMR_STOPIM (1 << 2) /* Bit 2: Stop Condition Interrupt Mask */ #endif #if defined(CONFIG_ARCH_CHIP_TM4C129) -# define I2CM_IMR_DMARXIM (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ -# define I2CM_IMR_DMATXIM (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ -# define I2CM_IMR_TXIM (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ -# define I2CM_IMR_RXIM (1 << 6) /* Bit 6: Receive FIFO Request Interrupt Mask */ -# define I2CM_IMR_TXFEIM (1 << 7) /* Bit 7: Transmit FIFO Empty Interrupt Mask */ -# define I2CM_IMR_RXFFIM (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */ +# define I2CS_IMR_DMARXIM (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ +# define I2CS_IMR_DMATXIM (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ +# define I2CS_IMR_TXIM (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ +# define I2CS_IMR_RXIM (1 << 6) /* Bit 6: Receive FIFO Request Interrupt Mask */ +# define I2CS_IMR_TXFEIM (1 << 7) /* Bit 7: Transmit FIFO Empty Interrupt Mask */ +# define I2CS_IMR_RXFFIM (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */ #endif /* I2C Slave Raw Interrupt Status (I2CS_RIS) */ -#define I2CM_RIS_DATARIS (1 << 0) /* Bit 0: Data Raw Interrupt Status */ +#define I2CS_RIS_DATARIS (1 << 0) /* Bit 0: Data Raw Interrupt Status */ #if defined(CONFIG_ARCH_CHIP_TM4C) -# define I2CM_RIS_STARTRIS (1 << 1) /* Bit 1: Start Condition Raw Interrupt Status */ -# define I2CM_RIS_STOPRIS (1 << 2) /* Bit 2: Stop Condition Raw Interrupt Status */ +# define I2CS_RIS_STARTRIS (1 << 1) /* Bit 1: Start Condition Raw Interrupt Status */ +# define I2CS_RIS_STOPRIS (1 << 2) /* Bit 2: Stop Condition Raw Interrupt Status */ #endif #if defined(CONFIG_ARCH_CHIP_TM4C129) -# define I2CM_RIS_DMARXRIS (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ -# define I2CM_RIS_DMATXRIS (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ -# define I2CM_RIS_TXRIS (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ -# define I2CM_RIS_RXRIS (1 << 6) /* Bit 6: Receive FIFO Request Interrupt Mask */ -# define I2CM_RIS_TXFERIS (1 << 7) /* Bit 7: Transmit FIFO Empty Interrupt Mask */ -# define I2CM_RIS_RXFFRIS (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */ +# define I2CS_RIS_DMARXRIS (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ +# define I2CS_RIS_DMATXRIS (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ +# define I2CS_RIS_TXRIS (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ +# define I2CS_RIS_RXRIS (1 << 6) /* Bit 6: Receive FIFO Request Interrupt Mask */ +# define I2CS_RIS_TXFERIS (1 << 7) /* Bit 7: Transmit FIFO Empty Interrupt Mask */ +# define I2CS_RIS_RXFFRIS (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */ #endif /* I2C Slave Masked Interrupt Status (I2CS_MIS) */ -#define I2CM_MIS_DATAMIS (1 << 0) /* Bit 0: Data Masked Interrupt Status */ +#define I2CS_MIS_DATAMIS (1 << 0) /* Bit 0: Data Masked Interrupt Status */ #if defined(CONFIG_ARCH_CHIP_TM4C) -# define I2CM_MIS_STARTMIS (1 << 1) /* Bit 1: Start Condition Masked Interrupt Status */ -# define I2CM_MIS_STOPMIS (1 << 2) /* Bit 2: Stop Condition Masked Interrupt Status */ +# define I2CS_MIS_STARTMIS (1 << 1) /* Bit 1: Start Condition Masked Interrupt Status */ +# define I2CS_MIS_STOPMIS (1 << 2) /* Bit 2: Stop Condition Masked Interrupt Status */ #endif #if defined(CONFIG_ARCH_CHIP_TM4C129) -# define I2CM_MIS_DMARXMIS (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ -# define I2CM_MIS_DMATXMIS (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ -# define I2CM_MIS_TXMIS (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ -# define I2CM_MIS_RXMIS (1 << 6) /* Bit 6: Receive FIFO Request Interrupt Mask */ -# define I2CM_MIS_TXFEMIS (1 << 7) /* Bit 7: Transmit FIFO Empty Interrupt Mask */ -# define I2CM_MIS_RXFFMIS (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */ +# define I2CS_MIS_DMARXMIS (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ +# define I2CS_MIS_DMATXMIS (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ +# define I2CS_MIS_TXMIS (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ +# define I2CS_MIS_RXMIS (1 << 6) /* Bit 6: Receive FIFO Request Interrupt Mask */ +# define I2CS_MIS_TXFEMIS (1 << 7) /* Bit 7: Transmit FIFO Empty Interrupt Mask */ +# define I2CS_MIS_RXFFMIS (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */ #endif /* I2C Slave Interrupt Clear (I2CS_ICR) */ -#define I2CM_ICR_DATAIC (1 << 0) /* Bit 0: Data Interrupt Clear */ +#define I2CS_ICR_DATAIC (1 << 0) /* Bit 0: Data Interrupt Clear */ #if defined(CONFIG_ARCH_CHIP_TM4C) -# define I2CM_ICR_STARTIC (1 << 1) /* Bit 1: Start Condition Interrupt Clear */ -# define I2CM_ICR_STOPIC (1 << 2) /* Bit 2: Stop Condition Interrupt Clear */ +# define I2CS_ICR_STARTIC (1 << 1) /* Bit 1: Start Condition Interrupt Clear */ +# define I2CS_ICR_STOPIC (1 << 2) /* Bit 2: Stop Condition Interrupt Clear */ #endif #if defined(CONFIG_ARCH_CHIP_TM4C129) -# define I2CM_ICR_DMARXIC (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ -# define I2CM_ICR_DMATXIC (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ -# define I2CM_ICR_TXIC (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ -# define I2CM_ICR_RXIC (1 << 6) /* Bit 6: Receive FIFO Request Interrupt Mask */ -# define I2CM_ICR_TXFEIC (1 << 7) /* Bit 7: Transmit FIFO Empty Interrupt Mask */ -# define I2CM_ICR_RXFFIC (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */ +# define I2CS_ICR_DMARXIC (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ +# define I2CS_ICR_DMATXIC (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ +# define I2CS_ICR_TXIC (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ +# define I2CS_ICR_RXIC (1 << 6) /* Bit 6: Receive FIFO Request Interrupt Mask */ +# define I2CS_ICR_TXFEIC (1 << 7) /* Bit 7: Transmit FIFO Empty Interrupt Mask */ +# define I2CS_ICR_RXFFIC (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */ #endif /* I2C Slave Own Address 2 */ diff --git a/arch/arm/src/tiva/tiva_i2c.c b/arch/arm/src/tiva/tiva_i2c.c index 1779e7e2de..69e44feb61 100644 --- a/arch/arm/src/tiva/tiva_i2c.c +++ b/arch/arm/src/tiva/tiva_i2c.c @@ -515,7 +515,7 @@ static const struct tiva_i2c_config_s tiva_i2c6_config = .devno = 6, }; -static struct tiva_i2c_priv_s tiva_i2c7_priv; +static struct tiva_i2c_priv_s tiva_i2c6_priv; #endif #ifdef CONFIG_TIVA_I2C7 @@ -537,7 +537,7 @@ static const struct tiva_i2c_config_s tiva_i2c7_config = .devno = 7, }; -static struct tiva_i2c_priv_s tiva_i2c8_priv; +static struct tiva_i2c_priv_s tiva_i2c7_priv; #endif #ifdef CONFIG_TIVA_I2C8 @@ -559,7 +559,7 @@ static const struct tiva_i2c_config_s tiva_i2c8_config = .devno = 8, }; -static struct tiva_i2c_priv_s tiva_i2c9_priv; +static struct tiva_i2c_priv_s tiva_i2c8_priv; #endif #ifdef CONFIG_TIVA_I2C9 @@ -581,7 +581,7 @@ static const struct tiva_i2c_config_s tiva_i2c9_config = .devno = 9, }; -static struct tiva_i2c_priv_s tiva_i2c0_priv; +static struct tiva_i2c_priv_s tiva_i2c9_priv; #endif /* Device Structures, Instantiation */ @@ -1872,10 +1872,10 @@ static uint32_t tiva_i2c_setclock(struct tiva_i2c_priv_s *priv, uint32_t frequen * speed that is less than or equal to 3.4 Mbps. */ - regval = tiva_i2c_putreg(priv, TIVA_I2CSC_PP_OFFSET); + regval = tiva_i2c_getreg(priv, TIVA_I2CSC_PP_OFFSET); if ((regval & I2CSC_PP_HS) != 0) { - tmp = (2 * 3 * 3400000) + tmp = (2 * 3 * 3400000); regval = (((SYSCLK_FREQUENCY + tmp - 1) / tmp) - 1) << I2CM_TPR_SHIFT; tiva_i2c_putreg(priv, TIVA_I2CM_TPR_OFFSET, I2CM_TPR_HS | regval); @@ -2264,13 +2264,13 @@ struct i2c_dev_s *up_i2cinitialize(int port) break; #endif #ifdef CONFIG_TIVA_I2C8 - case 7: + case 8: priv = &tiva_i2c8_priv; config = &tiva_i2c8_config; break; #endif #ifdef CONFIG_TIVA_I2C9 - case 0: + case 9: priv = &tiva_i2c9_priv; config = &tiva_i2c9_config; break;