Tiva: Fixes to support building Tiva TM4C129X I2C driver

This commit is contained in:
Gregory Nutt 2015-01-05 13:15:40 -06:00
parent b6fbf41925
commit 317b7efc7f
2 changed files with 44 additions and 44 deletions

View File

@ -917,74 +917,74 @@
/* I2C Slave Interrupt Mask (I2CS_IMR) */ /* 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) #if defined(CONFIG_ARCH_CHIP_TM4C)
# define I2CM_IMR_STARTIM (1 << 1) /* Bit 1: Start Condition Interrupt Mask */ # define I2CS_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_STOPIM (1 << 2) /* Bit 2: Stop Condition Interrupt Mask */
#endif #endif
#if defined(CONFIG_ARCH_CHIP_TM4C129) #if defined(CONFIG_ARCH_CHIP_TM4C129)
# define I2CM_IMR_DMARXIM (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ # define I2CS_IMR_DMARXIM (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */
# define I2CM_IMR_DMATXIM (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ # define I2CS_IMR_DMATXIM (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */
# define I2CM_IMR_TXIM (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ # define I2CS_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 I2CS_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 I2CS_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_RXFFIM (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */
#endif #endif
/* I2C Slave Raw Interrupt Status (I2CS_RIS) */ /* 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) #if defined(CONFIG_ARCH_CHIP_TM4C)
# define I2CM_RIS_STARTRIS (1 << 1) /* Bit 1: Start Condition Raw Interrupt Status */ # define I2CS_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_STOPRIS (1 << 2) /* Bit 2: Stop Condition Raw Interrupt Status */
#endif #endif
#if defined(CONFIG_ARCH_CHIP_TM4C129) #if defined(CONFIG_ARCH_CHIP_TM4C129)
# define I2CM_RIS_DMARXRIS (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ # define I2CS_RIS_DMARXRIS (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */
# define I2CM_RIS_DMATXRIS (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ # define I2CS_RIS_DMATXRIS (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */
# define I2CM_RIS_TXRIS (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ # define I2CS_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 I2CS_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 I2CS_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_RXFFRIS (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */
#endif #endif
/* I2C Slave Masked Interrupt Status (I2CS_MIS) */ /* 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) #if defined(CONFIG_ARCH_CHIP_TM4C)
# define I2CM_MIS_STARTMIS (1 << 1) /* Bit 1: Start Condition Masked Interrupt Status */ # define I2CS_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_STOPMIS (1 << 2) /* Bit 2: Stop Condition Masked Interrupt Status */
#endif #endif
#if defined(CONFIG_ARCH_CHIP_TM4C129) #if defined(CONFIG_ARCH_CHIP_TM4C129)
# define I2CM_MIS_DMARXMIS (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ # define I2CS_MIS_DMARXMIS (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */
# define I2CM_MIS_DMATXMIS (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ # define I2CS_MIS_DMATXMIS (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */
# define I2CM_MIS_TXMIS (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ # define I2CS_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 I2CS_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 I2CS_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_RXFFMIS (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */
#endif #endif
/* I2C Slave Interrupt Clear (I2CS_ICR) */ /* 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) #if defined(CONFIG_ARCH_CHIP_TM4C)
# define I2CM_ICR_STARTIC (1 << 1) /* Bit 1: Start Condition Interrupt Clear */ # define I2CS_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_STOPIC (1 << 2) /* Bit 2: Stop Condition Interrupt Clear */
#endif #endif
#if defined(CONFIG_ARCH_CHIP_TM4C129) #if defined(CONFIG_ARCH_CHIP_TM4C129)
# define I2CM_ICR_DMARXIC (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */ # define I2CS_ICR_DMARXIC (1 << 3) /* Bit 3: Receive DMA Interrupt Mask */
# define I2CM_ICR_DMATXIC (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */ # define I2CS_ICR_DMATXIC (1 << 4) /* Bit 4: Transmit DMA Interrupt Mask */
# define I2CM_ICR_TXIC (1 << 5) /* Bit 5: Transmit FIFO Request Interrupt Mask */ # define I2CS_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 I2CS_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 I2CS_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_RXFFIC (1 << 8) /* Bit 8: Receive FIFO Full Interrupt Mask */
#endif #endif
/* I2C Slave Own Address 2 */ /* I2C Slave Own Address 2 */

View File

@ -515,7 +515,7 @@ static const struct tiva_i2c_config_s tiva_i2c6_config =
.devno = 6, .devno = 6,
}; };
static struct tiva_i2c_priv_s tiva_i2c7_priv; static struct tiva_i2c_priv_s tiva_i2c6_priv;
#endif #endif
#ifdef CONFIG_TIVA_I2C7 #ifdef CONFIG_TIVA_I2C7
@ -537,7 +537,7 @@ static const struct tiva_i2c_config_s tiva_i2c7_config =
.devno = 7, .devno = 7,
}; };
static struct tiva_i2c_priv_s tiva_i2c8_priv; static struct tiva_i2c_priv_s tiva_i2c7_priv;
#endif #endif
#ifdef CONFIG_TIVA_I2C8 #ifdef CONFIG_TIVA_I2C8
@ -559,7 +559,7 @@ static const struct tiva_i2c_config_s tiva_i2c8_config =
.devno = 8, .devno = 8,
}; };
static struct tiva_i2c_priv_s tiva_i2c9_priv; static struct tiva_i2c_priv_s tiva_i2c8_priv;
#endif #endif
#ifdef CONFIG_TIVA_I2C9 #ifdef CONFIG_TIVA_I2C9
@ -581,7 +581,7 @@ static const struct tiva_i2c_config_s tiva_i2c9_config =
.devno = 9, .devno = 9,
}; };
static struct tiva_i2c_priv_s tiva_i2c0_priv; static struct tiva_i2c_priv_s tiva_i2c9_priv;
#endif #endif
/* Device Structures, Instantiation */ /* 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. * 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) if ((regval & I2CSC_PP_HS) != 0)
{ {
tmp = (2 * 3 * 3400000) tmp = (2 * 3 * 3400000);
regval = (((SYSCLK_FREQUENCY + tmp - 1) / tmp) - 1) << I2CM_TPR_SHIFT; regval = (((SYSCLK_FREQUENCY + tmp - 1) / tmp) - 1) << I2CM_TPR_SHIFT;
tiva_i2c_putreg(priv, TIVA_I2CM_TPR_OFFSET, I2CM_TPR_HS | regval); 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; break;
#endif #endif
#ifdef CONFIG_TIVA_I2C8 #ifdef CONFIG_TIVA_I2C8
case 7: case 8:
priv = &tiva_i2c8_priv; priv = &tiva_i2c8_priv;
config = &tiva_i2c8_config; config = &tiva_i2c8_config;
break; break;
#endif #endif
#ifdef CONFIG_TIVA_I2C9 #ifdef CONFIG_TIVA_I2C9
case 0: case 9:
priv = &tiva_i2c9_priv; priv = &tiva_i2c9_priv;
config = &tiva_i2c9_config; config = &tiva_i2c9_config;
break; break;