commit
10c4aff6ca
@ -521,9 +521,9 @@
|
|||||||
/* General Purpose Timer (GPT) */
|
/* General Purpose Timer (GPT) */
|
||||||
|
|
||||||
#define GPIO_GPT1_CAPTURE1_1 (GPIO_PERIPH | GPIO_ALT4 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_EMC_24_INDEX))
|
#define GPIO_GPT1_CAPTURE1_1 (GPIO_PERIPH | GPIO_ALT4 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_EMC_24_INDEX))
|
||||||
#define GPIO_GPT1_CAPTURE1_2 (GPIO_PERIPH | GPIO_ALT8 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_B0_05_INDEX))
|
#define GPIO_GPT1_CAPTURE1_2 (GPIO_PERIPH | GPIO_ALT8 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_B1_05_INDEX))
|
||||||
#define GPIO_GPT1_CAPTURE2_1 (GPIO_PERIPH | GPIO_ALT4 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_EMC_23_INDEX))
|
#define GPIO_GPT1_CAPTURE2_1 (GPIO_PERIPH | GPIO_ALT4 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_EMC_23_INDEX))
|
||||||
#define GPIO_GPT1_CAPTURE2_2 (GPIO_PERIPH | GPIO_ALT8 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_B0_06_INDEX))
|
#define GPIO_GPT1_CAPTURE2_2 (GPIO_PERIPH | GPIO_ALT8 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_B1_06_INDEX))
|
||||||
#define GPIO_GPT1_CLK_1 (GPIO_PERIPH | GPIO_ALT1 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_AD_B0_13_INDEX))
|
#define GPIO_GPT1_CLK_1 (GPIO_PERIPH | GPIO_ALT1 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_AD_B0_13_INDEX))
|
||||||
#define GPIO_GPT1_COMPARE1_1 (GPIO_PERIPH | GPIO_ALT2 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_EMC_35_INDEX))
|
#define GPIO_GPT1_COMPARE1_1 (GPIO_PERIPH | GPIO_ALT2 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_EMC_35_INDEX))
|
||||||
#define GPIO_GPT1_COMPARE2_1 (GPIO_PERIPH | GPIO_ALT2 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_EMC_36_INDEX))
|
#define GPIO_GPT1_COMPARE2_1 (GPIO_PERIPH | GPIO_ALT2 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_EMC_36_INDEX))
|
||||||
@ -534,6 +534,7 @@
|
|||||||
#define GPIO_GPT2_CLK_1 (GPIO_PERIPH | GPIO_ALT7 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_AD_B0_09_INDEX))
|
#define GPIO_GPT2_CLK_1 (GPIO_PERIPH | GPIO_ALT7 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_AD_B0_09_INDEX))
|
||||||
#define GPIO_GPT2_COMPARE2_1 (GPIO_PERIPH | GPIO_ALT1 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_AD_B0_07_INDEX))
|
#define GPIO_GPT2_COMPARE2_1 (GPIO_PERIPH | GPIO_ALT1 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_AD_B0_07_INDEX))
|
||||||
#define GPIO_GPT2_COMPARE3_1 (GPIO_PERIPH | GPIO_ALT1 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_AD_B0_08_INDEX))
|
#define GPIO_GPT2_COMPARE3_1 (GPIO_PERIPH | GPIO_ALT1 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_AD_B0_08_INDEX))
|
||||||
|
#define GPIO_GPT2_COMPARE3_2 (GPIO_PERIPH | GPIO_ALT8 | GPIO_PADMUX(IMXRT_PADMUX_GPIO_AD_B1_07_INDEX))
|
||||||
|
|
||||||
/* JTAG */
|
/* JTAG */
|
||||||
|
|
||||||
|
@ -102,7 +102,8 @@ static const uint8_t g_gpio1_padmux[IMXRT_GPIO_NPINS] =
|
|||||||
IMXRT_PADMUX_GPIO_AD_B1_15_INDEX /* GPIO1 Pin 31 */
|
IMXRT_PADMUX_GPIO_AD_B1_15_INDEX /* GPIO1 Pin 31 */
|
||||||
};
|
};
|
||||||
|
|
||||||
#if (defined(CONFIG_ARCH_FAMILY_IMXRT105x) || defined(CONFIG_ARCH_FAMILY_IMXRT106x))
|
#if (defined(CONFIG_ARCH_FAMILY_IMXRT105x) || \
|
||||||
|
defined(CONFIG_ARCH_FAMILY_IMXRT106x))
|
||||||
static const uint8_t g_gpio2_padmux[IMXRT_GPIO_NPINS] =
|
static const uint8_t g_gpio2_padmux[IMXRT_GPIO_NPINS] =
|
||||||
{
|
{
|
||||||
IMXRT_PADMUX_GPIO_B0_00_INDEX, /* GPIO2 Pin 0 */
|
IMXRT_PADMUX_GPIO_B0_00_INDEX, /* GPIO2 Pin 0 */
|
||||||
@ -185,7 +186,8 @@ static const uint8_t g_gpio2_padmux[IMXRT_GPIO_NPINS] =
|
|||||||
# error "Unrecognised IMXRT family member"
|
# error "Unrecognised IMXRT family member"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (defined(CONFIG_ARCH_FAMILY_IMXRT105x) || defined(CONFIG_ARCH_FAMILY_IMXRT106x))
|
#if (defined(CONFIG_ARCH_FAMILY_IMXRT105x) || \
|
||||||
|
defined(CONFIG_ARCH_FAMILY_IMXRT106x))
|
||||||
static const uint8_t g_gpio3_padmux[IMXRT_GPIO_NPINS] =
|
static const uint8_t g_gpio3_padmux[IMXRT_GPIO_NPINS] =
|
||||||
{
|
{
|
||||||
IMXRT_PADMUX_GPIO_SD_B1_00_INDEX, /* GPIO3 Pin 0 */
|
IMXRT_PADMUX_GPIO_SD_B1_00_INDEX, /* GPIO3 Pin 0 */
|
||||||
@ -265,7 +267,8 @@ static const uint8_t g_gpio3_padmux[IMXRT_GPIO_NPINS] =
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (defined(CONFIG_ARCH_FAMILY_IMXRT105x) || defined(CONFIG_ARCH_FAMILY_IMXRT106x))
|
#if (defined(CONFIG_ARCH_FAMILY_IMXRT105x) || \
|
||||||
|
defined(CONFIG_ARCH_FAMILY_IMXRT106x))
|
||||||
static const uint8_t g_gpio4_padmux[IMXRT_GPIO_NPINS] =
|
static const uint8_t g_gpio4_padmux[IMXRT_GPIO_NPINS] =
|
||||||
{
|
{
|
||||||
IMXRT_PADMUX_GPIO_EMC_00_INDEX, /* GPIO4 Pin 0 */
|
IMXRT_PADMUX_GPIO_EMC_00_INDEX, /* GPIO4 Pin 0 */
|
||||||
@ -350,7 +353,8 @@ static FAR const uint8_t *g_gpio_padmux[IMXRT_GPIO_NPORTS + 1] =
|
|||||||
g_gpio1_padmux, /* GPIO1 */
|
g_gpio1_padmux, /* GPIO1 */
|
||||||
g_gpio2_padmux, /* GPIO2 */
|
g_gpio2_padmux, /* GPIO2 */
|
||||||
g_gpio3_padmux, /* GPIO3 */
|
g_gpio3_padmux, /* GPIO3 */
|
||||||
#if (defined(CONFIG_ARCH_FAMILY_IMXRT105x) || defined(CONFIG_ARCH_FAMILY_IMXRT106x))
|
#if (defined(CONFIG_ARCH_FAMILY_IMXRT105x) || \
|
||||||
|
defined(CONFIG_ARCH_FAMILY_IMXRT106x))
|
||||||
g_gpio4_padmux, /* GPIO4 */
|
g_gpio4_padmux, /* GPIO4 */
|
||||||
#else
|
#else
|
||||||
NULL, /* GPIO4 doesn't exist on 102x */
|
NULL, /* GPIO4 doesn't exist on 102x */
|
||||||
@ -365,9 +369,9 @@ static FAR const uint8_t *g_gpio_padmux[IMXRT_GPIO_NPORTS + 1] =
|
|||||||
NULL /* End of list */
|
NULL /* End of list */
|
||||||
};
|
};
|
||||||
|
|
||||||
/************************************************************************************
|
/****************************************************************************
|
||||||
* Public Data
|
* Public Data
|
||||||
************************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/* Look-up table that maps GPIO1..GPIOn indexes into GPIO register base addresses */
|
/* Look-up table that maps GPIO1..GPIOn indexes into GPIO register base addresses */
|
||||||
|
|
||||||
@ -381,7 +385,8 @@ uintptr_t g_gpio_base[IMXRT_GPIO_NPORTS] =
|
|||||||
, IMXRT_GPIO3_BASE
|
, IMXRT_GPIO3_BASE
|
||||||
#endif
|
#endif
|
||||||
#if IMXRT_GPIO_NPORTS > 3
|
#if IMXRT_GPIO_NPORTS > 3
|
||||||
#if (defined(CONFIG_ARCH_FAMILY_IMXRT105x) || defined(CONFIG_ARCH_FAMILY_IMXRT106x))
|
#if (defined(CONFIG_ARCH_FAMILY_IMXRT105x) || \
|
||||||
|
defined(CONFIG_ARCH_FAMILY_IMXRT106x))
|
||||||
, IMXRT_GPIO4_BASE
|
, IMXRT_GPIO4_BASE
|
||||||
#else
|
#else
|
||||||
, 0
|
, 0
|
||||||
@ -419,6 +424,7 @@ static uintptr_t imxrt_padmux_address(unsigned int index)
|
|||||||
{
|
{
|
||||||
return (IMXRT_PAD1MUX_OFFSET(index - IMXRT_PADMUX_GPIO_SPI_B0_00_INDEX));
|
return (IMXRT_PAD1MUX_OFFSET(index - IMXRT_PADMUX_GPIO_SPI_B0_00_INDEX));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
if (index >= IMXRT_PADMUX_WAKEUP_INDEX)
|
if (index >= IMXRT_PADMUX_WAKEUP_INDEX)
|
||||||
{
|
{
|
||||||
@ -439,6 +445,7 @@ static uintptr_t imxrt_padctl_address(unsigned int index)
|
|||||||
{
|
{
|
||||||
return (IMXRT_PAD1CTL_OFFSET(index - IMXRT_PADCTL_GPIO_SPI_B0_00_INDEX));
|
return (IMXRT_PAD1CTL_OFFSET(index - IMXRT_PADCTL_GPIO_SPI_B0_00_INDEX));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
if (index >= IMXRT_PADCTL_WAKEUP_INDEX)
|
if (index >= IMXRT_PADCTL_WAKEUP_INDEX)
|
||||||
{
|
{
|
||||||
@ -492,6 +499,19 @@ static void imxrt_gpio_setoutput(int port, int pin, bool value)
|
|||||||
putreg32(regval, regaddr);
|
putreg32(regval, regaddr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: imxrt_gpio_getpin_status
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
static inline bool imxrt_gpio_get_pinstatus(int port, int pin)
|
||||||
|
{
|
||||||
|
uintptr_t regaddr = IMXRT_GPIO_PSR(port);
|
||||||
|
uint32_t regval;
|
||||||
|
|
||||||
|
regval = getreg32(regaddr);
|
||||||
|
return ((regval & GPIO_PIN(pin)) != 0);
|
||||||
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: imxrt_gpio_getinput
|
* Name: imxrt_gpio_getinput
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -546,6 +566,7 @@ static inline int imxrt_gpio_select(int port, int pin)
|
|||||||
regaddr |= gpr * sizeof(uint32_t);
|
regaddr |= gpr * sizeof(uint32_t);
|
||||||
modifyreg32(regaddr, clearbits, setbits);
|
modifyreg32(regaddr, clearbits, setbits);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
@ -562,6 +583,7 @@ static int imxrt_gpio_configinput(gpio_pinset_t pinset)
|
|||||||
iomux_pinset_t ioset;
|
iomux_pinset_t ioset;
|
||||||
uintptr_t regaddr;
|
uintptr_t regaddr;
|
||||||
unsigned int index;
|
unsigned int index;
|
||||||
|
uint32_t sion = 0;
|
||||||
|
|
||||||
DEBUGASSERT((unsigned int)port < IMXRT_GPIO_NPORTS);
|
DEBUGASSERT((unsigned int)port < IMXRT_GPIO_NPORTS);
|
||||||
|
|
||||||
@ -582,8 +604,15 @@ static int imxrt_gpio_configinput(gpio_pinset_t pinset)
|
|||||||
{
|
{
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
regaddr = imxrt_padmux_address(index);
|
regaddr = imxrt_padmux_address(index);
|
||||||
putreg32(PADMUX_MUXMODE_ALT5, regaddr);
|
|
||||||
|
if ((pinset & GPIO_OUTPUT) == GPIO_OUTPUT)
|
||||||
|
{
|
||||||
|
sion |= (pinset & GPIO_SION_MASK) ? PADMUX_SION : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
putreg32(PADMUX_MUXMODE_ALT5 | sion, regaddr);
|
||||||
|
|
||||||
imxrt_gpio_select(port, pin);
|
imxrt_gpio_select(port, pin);
|
||||||
|
|
||||||
@ -742,13 +771,13 @@ int imxrt_config_gpio(gpio_pinset_t pinset)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************************
|
/****************************************************************************
|
||||||
* Name: imxrt_gpio_write
|
* Name: imxrt_gpio_write
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Write one or zero to the selected GPIO pin
|
* Write one or zero to the selected GPIO pin
|
||||||
*
|
*
|
||||||
************************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
void imxrt_gpio_write(gpio_pinset_t pinset, bool value)
|
void imxrt_gpio_write(gpio_pinset_t pinset, bool value)
|
||||||
{
|
{
|
||||||
@ -763,13 +792,13 @@ void imxrt_gpio_write(gpio_pinset_t pinset, bool value)
|
|||||||
leave_critical_section(flags);
|
leave_critical_section(flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************************
|
/****************************************************************************
|
||||||
* Name: imxrt_gpio_read
|
* Name: imxrt_gpio_read
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Read one or zero from the selected GPIO pin
|
* Read one or zero from the selected GPIO pin
|
||||||
*
|
*
|
||||||
************************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
bool imxrt_gpio_read(gpio_pinset_t pinset)
|
bool imxrt_gpio_read(gpio_pinset_t pinset)
|
||||||
{
|
{
|
||||||
@ -781,7 +810,16 @@ bool imxrt_gpio_read(gpio_pinset_t pinset)
|
|||||||
DEBUGASSERT((unsigned int)port < IMXRT_GPIO_NPORTS);
|
DEBUGASSERT((unsigned int)port < IMXRT_GPIO_NPORTS);
|
||||||
|
|
||||||
flags = enter_critical_section();
|
flags = enter_critical_section();
|
||||||
value = imxrt_gpio_getinput(port, pin);
|
if ((pinset & (GPIO_OUTPUT | GPIO_SION_ENABLE)) ==
|
||||||
leave_critical_section(flags);
|
(GPIO_OUTPUT | GPIO_SION_ENABLE))
|
||||||
|
{
|
||||||
|
value = imxrt_gpio_get_pinstatus(port, pin);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
value = imxrt_gpio_getinput(port, pin);
|
||||||
|
}
|
||||||
|
|
||||||
|
leave_critical_section(flags);
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
@ -130,16 +130,6 @@
|
|||||||
#define LPI2C_MASTER 1
|
#define LPI2C_MASTER 1
|
||||||
#define LPI2C_SLAVE 2
|
#define LPI2C_SLAVE 2
|
||||||
|
|
||||||
#define MKI2C_OUTPUT(p) (((p) & GPIO_PADMUX_MASK) | \
|
|
||||||
IOMUX_OPENDRAIN | IOMUX_DRIVE_33OHM | \
|
|
||||||
IOMUX_SLEW_SLOW | (5 << GPIO_ALT_SHIFT) | \
|
|
||||||
IOMUX_PULL_NONE | GPIO_OUTPUT_ONE)
|
|
||||||
|
|
||||||
#define MKI2C_INPUT(p) (((p) & GPIO_PADMUX_MASK) | \
|
|
||||||
IOMUX_DRIVE_HIZ | IOMUX_SLEW_SLOW | \
|
|
||||||
IOMUX_CMOS_INPUT | (5 << GPIO_ALT_SHIFT) | \
|
|
||||||
IOMUX_PULL_NONE)
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Private Types
|
* Private Types
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -186,8 +176,12 @@ struct imxrt_lpi2c_config_s
|
|||||||
uint16_t busy_idle; /* LPI2C Bus Idle Timeout */
|
uint16_t busy_idle; /* LPI2C Bus Idle Timeout */
|
||||||
uint8_t filtscl; /* Glitch Filter for SCL pin */
|
uint8_t filtscl; /* Glitch Filter for SCL pin */
|
||||||
uint8_t filtsda; /* Glitch Filter for SDA pin */
|
uint8_t filtsda; /* Glitch Filter for SDA pin */
|
||||||
uint32_t scl_pin; /* GPIO configuration for SCL as SCL */
|
uint32_t scl_pin; /* Peripheral configuration for SCL as SCL */
|
||||||
uint32_t sda_pin; /* GPIO configuration for SDA as SDA */
|
uint32_t sda_pin; /* Peripheral configuration for SDA as SDA */
|
||||||
|
#if defined(CONFIG_I2C_RESET)
|
||||||
|
uint32_t reset_scl_pin; /* GPIO configuration for SCL as SCL */
|
||||||
|
uint32_t reset_sda_pin; /* GPIO configuration for SDA as SDA */
|
||||||
|
#endif
|
||||||
uint8_t mode; /* Master or Slave mode */
|
uint8_t mode; /* Master or Slave mode */
|
||||||
#ifndef CONFIG_I2C_POLLED
|
#ifndef CONFIG_I2C_POLLED
|
||||||
uint32_t irq; /* Event IRQ */
|
uint32_t irq; /* Event IRQ */
|
||||||
@ -318,136 +312,152 @@ static const struct i2c_ops_s imxrt_lpi2c_ops =
|
|||||||
#ifdef CONFIG_IMXRT_LPI2C1
|
#ifdef CONFIG_IMXRT_LPI2C1
|
||||||
static const struct imxrt_lpi2c_config_s imxrt_lpi2c1_config =
|
static const struct imxrt_lpi2c_config_s imxrt_lpi2c1_config =
|
||||||
{
|
{
|
||||||
.base = IMXRT_LPI2C1_BASE,
|
.base = IMXRT_LPI2C1_BASE,
|
||||||
.busy_idle = CONFIG_LPI2C1_BUSYIDLE,
|
.busy_idle = CONFIG_LPI2C1_BUSYIDLE,
|
||||||
.filtscl = CONFIG_LPI2C1_FILTSCL,
|
.filtscl = CONFIG_LPI2C1_FILTSCL,
|
||||||
.filtsda = CONFIG_LPI2C1_FILTSDA,
|
.filtsda = CONFIG_LPI2C1_FILTSDA,
|
||||||
.scl_pin = GPIO_LPI2C1_SCL,
|
.scl_pin = GPIO_LPI2C1_SCL,
|
||||||
.sda_pin = GPIO_LPI2C1_SDA,
|
.sda_pin = GPIO_LPI2C1_SDA,
|
||||||
|
#if defined(CONFIG_I2C_RESET)
|
||||||
|
.reset_scl_pin = GPIO_LPI2C1_SCL_RESET,
|
||||||
|
.reset_sda_pin = GPIO_LPI2C1_SDA_RESET,
|
||||||
|
#endif
|
||||||
#ifndef CONFIG_I2C_SLAVE
|
#ifndef CONFIG_I2C_SLAVE
|
||||||
.mode = LPI2C_MASTER,
|
.mode = LPI2C_MASTER,
|
||||||
#else
|
#else
|
||||||
.mode = LPI2C_SLAVE,
|
.mode = LPI2C_SLAVE,
|
||||||
#endif
|
#endif
|
||||||
#ifndef CONFIG_I2C_POLLED
|
#ifndef CONFIG_I2C_POLLED
|
||||||
.irq = IMXRT_IRQ_LPI2C1,
|
.irq = IMXRT_IRQ_LPI2C1,
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct imxrt_lpi2c_priv_s imxrt_lpi2c1_priv =
|
static struct imxrt_lpi2c_priv_s imxrt_lpi2c1_priv =
|
||||||
{
|
{
|
||||||
.ops = &imxrt_lpi2c_ops,
|
.ops = &imxrt_lpi2c_ops,
|
||||||
.config = &imxrt_lpi2c1_config,
|
.config = &imxrt_lpi2c1_config,
|
||||||
.refs = 0,
|
.refs = 0,
|
||||||
.intstate = INTSTATE_IDLE,
|
.intstate = INTSTATE_IDLE,
|
||||||
.msgc = 0,
|
.msgc = 0,
|
||||||
.msgv = NULL,
|
.msgv = NULL,
|
||||||
.ptr = NULL,
|
.ptr = NULL,
|
||||||
.dcnt = 0,
|
.dcnt = 0,
|
||||||
.flags = 0,
|
.flags = 0,
|
||||||
.status = 0
|
.status = 0
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_IMXRT_LPI2C2
|
#ifdef CONFIG_IMXRT_LPI2C2
|
||||||
static const struct imxrt_lpi2c_config_s imxrt_lpi2c2_config =
|
static const struct imxrt_lpi2c_config_s imxrt_lpi2c2_config =
|
||||||
{
|
{
|
||||||
.base = IMXRT_LPI2C2_BASE,
|
.base = IMXRT_LPI2C2_BASE,
|
||||||
.busy_idle = CONFIG_LPI2C2_BUSYIDLE,
|
.busy_idle = CONFIG_LPI2C2_BUSYIDLE,
|
||||||
.filtscl = CONFIG_LPI2C2_FILTSCL,
|
.filtscl = CONFIG_LPI2C2_FILTSCL,
|
||||||
.filtsda = CONFIG_LPI2C2_FILTSDA,
|
.filtsda = CONFIG_LPI2C2_FILTSDA,
|
||||||
.scl_pin = GPIO_LPI2C2_SCL,
|
.scl_pin = GPIO_LPI2C2_SCL,
|
||||||
.sda_pin = GPIO_LPI2C2_SDA,
|
.sda_pin = GPIO_LPI2C2_SDA,
|
||||||
|
#if defined(CONFIG_I2C_RESET)
|
||||||
|
.reset_scl_pin = GPIO_LPI2C2_SCL_RESET,
|
||||||
|
.reset_sda_pin = GPIO_LPI2C2_SDA_RESET,
|
||||||
|
#endif
|
||||||
#ifndef CONFIG_I2C_SLAVE
|
#ifndef CONFIG_I2C_SLAVE
|
||||||
.mode = LPI2C_MASTER,
|
.mode = LPI2C_MASTER,
|
||||||
#else
|
#else
|
||||||
.mode = LPI2C_SLAVE,
|
.mode = LPI2C_SLAVE,
|
||||||
#endif
|
#endif
|
||||||
#ifndef CONFIG_I2C_POLLED
|
#ifndef CONFIG_I2C_POLLED
|
||||||
.irq = IMXRT_IRQ_LPI2C2,
|
.irq = IMXRT_IRQ_LPI2C2,
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct imxrt_lpi2c_priv_s imxrt_lpi2c2_priv =
|
static struct imxrt_lpi2c_priv_s imxrt_lpi2c2_priv =
|
||||||
{
|
{
|
||||||
.ops = &imxrt_lpi2c_ops,
|
.ops = &imxrt_lpi2c_ops,
|
||||||
.config = &imxrt_lpi2c2_config,
|
.config = &imxrt_lpi2c2_config,
|
||||||
.refs = 0,
|
.refs = 0,
|
||||||
.intstate = INTSTATE_IDLE,
|
.intstate = INTSTATE_IDLE,
|
||||||
.msgc = 0,
|
.msgc = 0,
|
||||||
.msgv = NULL,
|
.msgv = NULL,
|
||||||
.ptr = NULL,
|
.ptr = NULL,
|
||||||
.dcnt = 0,
|
.dcnt = 0,
|
||||||
.flags = 0,
|
.flags = 0,
|
||||||
.status = 0
|
.status = 0
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_IMXRT_LPI2C3
|
#ifdef CONFIG_IMXRT_LPI2C3
|
||||||
static const struct imxrt_lpi2c_config_s imxrt_lpi2c3_config =
|
static const struct imxrt_lpi2c_config_s imxrt_lpi2c3_config =
|
||||||
{
|
{
|
||||||
.base = IMXRT_LPI2C3_BASE,
|
.base = IMXRT_LPI2C3_BASE,
|
||||||
.busy_idle = CONFIG_LPI2C3_BUSYIDLE,
|
.busy_idle = CONFIG_LPI2C3_BUSYIDLE,
|
||||||
.filtscl = CONFIG_LPI2C3_FILTSCL,
|
.filtscl = CONFIG_LPI2C3_FILTSCL,
|
||||||
.filtsda = CONFIG_LPI2C3_FILTSDA,
|
.filtsda = CONFIG_LPI2C3_FILTSDA,
|
||||||
.scl_pin = GPIO_LPI2C3_SCL,
|
.scl_pin = GPIO_LPI2C3_SCL,
|
||||||
.sda_pin = GPIO_LPI2C3_SDA,
|
.sda_pin = GPIO_LPI2C3_SDA,
|
||||||
|
#if defined(CONFIG_I2C_RESET)
|
||||||
|
.reset_scl_pin = GPIO_LPI2C3_SCL_RESET,
|
||||||
|
.reset_sda_pin = GPIO_LPI2C3_SDA_RESET,
|
||||||
|
#endif
|
||||||
#ifndef CONFIG_I2C_SLAVE
|
#ifndef CONFIG_I2C_SLAVE
|
||||||
.mode = LPI2C_MASTER,
|
.mode = LPI2C_MASTER,
|
||||||
#else
|
#else
|
||||||
.mode = LPI2C_SLAVE,
|
.mode = LPI2C_SLAVE,
|
||||||
#endif
|
#endif
|
||||||
#ifndef CONFIG_I2C_POLLED
|
#ifndef CONFIG_I2C_POLLED
|
||||||
.irq = IMXRT_IRQ_LPI2C3,
|
.irq = IMXRT_IRQ_LPI2C3,
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct imxrt_lpi2c_priv_s imxrt_lpi2c3_priv =
|
static struct imxrt_lpi2c_priv_s imxrt_lpi2c3_priv =
|
||||||
{
|
{
|
||||||
.ops = &imxrt_lpi2c_ops,
|
.ops = &imxrt_lpi2c_ops,
|
||||||
.config = &imxrt_lpi2c3_config,
|
.config = &imxrt_lpi2c3_config,
|
||||||
.refs = 0,
|
.refs = 0,
|
||||||
.intstate = INTSTATE_IDLE,
|
.intstate = INTSTATE_IDLE,
|
||||||
.msgc = 0,
|
.msgc = 0,
|
||||||
.msgv = NULL,
|
.msgv = NULL,
|
||||||
.ptr = NULL,
|
.ptr = NULL,
|
||||||
.dcnt = 0,
|
.dcnt = 0,
|
||||||
.flags = 0,
|
.flags = 0,
|
||||||
.status = 0
|
.status = 0
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_IMXRT_LPI2C4
|
#ifdef CONFIG_IMXRT_LPI2C4
|
||||||
static const struct imxrt_lpi2c_config_s imxrt_lpi2c4_config =
|
static const struct imxrt_lpi2c_config_s imxrt_lpi2c4_config =
|
||||||
{
|
{
|
||||||
.base = IMXRT_LPI2C4_BASE,
|
.base = IMXRT_LPI2C4_BASE,
|
||||||
.busy_idle = CONFIG_LPI2C4_BUSYIDLE,
|
.busy_idle = CONFIG_LPI2C4_BUSYIDLE,
|
||||||
.filtscl = CONFIG_LPI2C4_FILTSCL,
|
.filtscl = CONFIG_LPI2C4_FILTSCL,
|
||||||
.filtsda = CONFIG_LPI2C4_FILTSDA,
|
.filtsda = CONFIG_LPI2C4_FILTSDA,
|
||||||
.scl_pin = GPIO_LPI2C4_SCL,
|
.scl_pin = GPIO_LPI2C4_SCL,
|
||||||
.sda_pin = GPIO_LPI2C4_SDA,
|
.sda_pin = GPIO_LPI2C4_SDA,
|
||||||
|
#if defined(CONFIG_I2C_RESET)
|
||||||
|
.reset_scl_pin = GPIO_LPI2C4_SCL_RESET,
|
||||||
|
.reset_sda_pin = GPIO_LPI2C4_SDA_RESET,
|
||||||
|
#endif
|
||||||
#ifndef CONFIG_I2C_SLAVE
|
#ifndef CONFIG_I2C_SLAVE
|
||||||
.mode = LPI2C_MASTER,
|
.mode = LPI2C_MASTER,
|
||||||
#else
|
#else
|
||||||
.mode = LPI2C_SLAVE,
|
.mode = LPI2C_SLAVE,
|
||||||
#endif
|
#endif
|
||||||
#ifndef CONFIG_I2C_POLLED
|
#ifndef CONFIG_I2C_POLLED
|
||||||
.irq = IMXRT_IRQ_LPI2C4,
|
.irq = IMXRT_IRQ_LPI2C4,
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct imxrt_lpi2c_priv_s imxrt_lpi2c4_priv =
|
static struct imxrt_lpi2c_priv_s imxrt_lpi2c4_priv =
|
||||||
{
|
{
|
||||||
.ops = &imxrt_lpi2c_ops,
|
.ops = &imxrt_lpi2c_ops,
|
||||||
.config = &imxrt_lpi2c4_config,
|
.config = &imxrt_lpi2c4_config,
|
||||||
.refs = 0,
|
.refs = 0,
|
||||||
.intstate = INTSTATE_IDLE,
|
.intstate = INTSTATE_IDLE,
|
||||||
.msgc = 0,
|
.msgc = 0,
|
||||||
.msgv = NULL,
|
.msgv = NULL,
|
||||||
.ptr = NULL,
|
.ptr = NULL,
|
||||||
.dcnt = 0,
|
.dcnt = 0,
|
||||||
.flags = 0,
|
.flags = 0,
|
||||||
.status = 0
|
.status = 0
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1235,11 +1245,17 @@ static int imxrt_lpi2c_isr_process(struct imxrt_lpi2c_priv_s *priv)
|
|||||||
|
|
||||||
imxrt_lpi2c_tracenew(priv, status);
|
imxrt_lpi2c_tracenew(priv, status);
|
||||||
|
|
||||||
/* Continue with either sending or reading data */
|
/* After an error we can get an SDF */
|
||||||
|
|
||||||
|
if (priv->intstate == INTSTATE_DONE && (status & LPI2C_MSR_SDF) != 0)
|
||||||
|
{
|
||||||
|
imxrt_lpi2c_traceevent(priv, I2CEVENT_STOP, 0);
|
||||||
|
imxrt_lpi2c_putreg(priv, IMXRT_LPI2C_MSR_OFFSET, LPI2C_MSR_SDF);
|
||||||
|
}
|
||||||
|
|
||||||
/* Check if there is more bytes to send */
|
/* Check if there is more bytes to send */
|
||||||
|
|
||||||
if (((priv->flags & I2C_M_READ) == 0) && (status & LPI2C_MSR_TDF) != 0)
|
else if (((priv->flags & I2C_M_READ) == 0) && (status & LPI2C_MSR_TDF) != 0)
|
||||||
{
|
{
|
||||||
if (priv->dcnt > 0)
|
if (priv->dcnt > 0)
|
||||||
{
|
{
|
||||||
@ -1298,8 +1314,8 @@ static int imxrt_lpi2c_isr_process(struct imxrt_lpi2c_priv_s *priv)
|
|||||||
{
|
{
|
||||||
if (priv->msgc > 0 && priv->msgv != NULL)
|
if (priv->msgc > 0 && priv->msgv != NULL)
|
||||||
{
|
{
|
||||||
priv->ptr = priv->msgv->buffer;
|
priv->ptr = priv->msgv->buffer;
|
||||||
priv->dcnt = priv->msgv->length;
|
priv->dcnt = priv->msgv->length;
|
||||||
priv->flags = priv->msgv->flags;
|
priv->flags = priv->msgv->flags;
|
||||||
|
|
||||||
if ((priv->msgv->flags & I2C_M_NOSTART) == 0)
|
if ((priv->msgv->flags & I2C_M_NOSTART) == 0)
|
||||||
@ -1354,6 +1370,10 @@ static int imxrt_lpi2c_isr_process(struct imxrt_lpi2c_priv_s *priv)
|
|||||||
#ifndef CONFIG_I2C_POLLED
|
#ifndef CONFIG_I2C_POLLED
|
||||||
if (priv->intstate == INTSTATE_WAITING)
|
if (priv->intstate == INTSTATE_WAITING)
|
||||||
{
|
{
|
||||||
|
/* Update Status once at the end */
|
||||||
|
|
||||||
|
priv->status = status;
|
||||||
|
|
||||||
/* inform the thread that transfer is complete
|
/* inform the thread that transfer is complete
|
||||||
* and wake it up
|
* and wake it up
|
||||||
*/
|
*/
|
||||||
@ -1362,6 +1382,7 @@ static int imxrt_lpi2c_isr_process(struct imxrt_lpi2c_priv_s *priv)
|
|||||||
priv->intstate = INTSTATE_DONE;
|
priv->intstate = INTSTATE_DONE;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
priv->status = status;
|
||||||
priv->intstate = INTSTATE_DONE;
|
priv->intstate = INTSTATE_DONE;
|
||||||
#endif
|
#endif
|
||||||
/* Mark that this transaction stopped */
|
/* Mark that this transaction stopped */
|
||||||
@ -1402,6 +1423,10 @@ static int imxrt_lpi2c_isr_process(struct imxrt_lpi2c_priv_s *priv)
|
|||||||
#ifndef CONFIG_I2C_POLLED
|
#ifndef CONFIG_I2C_POLLED
|
||||||
if (priv->intstate == INTSTATE_WAITING)
|
if (priv->intstate == INTSTATE_WAITING)
|
||||||
{
|
{
|
||||||
|
/* Update Status once at the end */
|
||||||
|
|
||||||
|
priv->status = status;
|
||||||
|
|
||||||
/* inform the thread that transfer is complete
|
/* inform the thread that transfer is complete
|
||||||
* and wake it up
|
* and wake it up
|
||||||
*/
|
*/
|
||||||
@ -1410,11 +1435,11 @@ static int imxrt_lpi2c_isr_process(struct imxrt_lpi2c_priv_s *priv)
|
|||||||
priv->intstate = INTSTATE_DONE;
|
priv->intstate = INTSTATE_DONE;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
priv->status = status;
|
||||||
priv->intstate = INTSTATE_DONE;
|
priv->intstate = INTSTATE_DONE;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
priv->status = status;
|
|
||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1754,8 +1779,8 @@ static int imxrt_lpi2c_reset(FAR struct i2c_master_s *dev)
|
|||||||
|
|
||||||
/* Use GPIO configuration to un-wedge the bus */
|
/* Use GPIO configuration to un-wedge the bus */
|
||||||
|
|
||||||
scl_gpio = MKI2C_OUTPUT(priv->config->scl_pin);
|
scl_gpio = priv->config->reset_scl_pin | GPIO_SION_ENABLE;
|
||||||
sda_gpio = MKI2C_OUTPUT(priv->config->sda_pin);
|
sda_gpio = priv->config->reset_sda_pin | GPIO_SION_ENABLE;
|
||||||
|
|
||||||
imxrt_config_gpio(scl_gpio);
|
imxrt_config_gpio(scl_gpio);
|
||||||
imxrt_config_gpio(sda_gpio);
|
imxrt_config_gpio(sda_gpio);
|
||||||
@ -1818,11 +1843,6 @@ static int imxrt_lpi2c_reset(FAR struct i2c_master_s *dev)
|
|||||||
imxrt_gpio_write(sda_gpio, 1);
|
imxrt_gpio_write(sda_gpio, 1);
|
||||||
up_udelay(10);
|
up_udelay(10);
|
||||||
|
|
||||||
/* Revert the GPIO configuration. */
|
|
||||||
|
|
||||||
sda_gpio = MKI2C_INPUT(sda_gpio);
|
|
||||||
scl_gpio = MKI2C_INPUT(scl_gpio);
|
|
||||||
|
|
||||||
imxrt_config_gpio(sda_gpio);
|
imxrt_config_gpio(sda_gpio);
|
||||||
imxrt_config_gpio(scl_gpio);
|
imxrt_config_gpio(scl_gpio);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user