diff options
Diffstat (limited to 'os/hal/ports/TIVA/LLD/pal_lld.c')
-rw-r--r-- | os/hal/ports/TIVA/LLD/pal_lld.c | 420 |
1 files changed, 276 insertions, 144 deletions
diff --git a/os/hal/ports/TIVA/LLD/pal_lld.c b/os/hal/ports/TIVA/LLD/pal_lld.c index 657f982..50a9a82 100644 --- a/os/hal/ports/TIVA/LLD/pal_lld.c +++ b/os/hal/ports/TIVA/LLD/pal_lld.c @@ -30,94 +30,206 @@ /* Driver local definitions. */ /*===========================================================================*/ -#define RCGCGPIOA (1 << 0) -#define RCGCGPIOB (1 << 1) -#define RCGCGPIOC (1 << 2) -#define RCGCGPIOD (1 << 3) -#define RCGCGPIOE (1 << 4) -#define RCGCGPIOF (1 << 5) +#if TIVA_HAS_GPIOA || defined(__DOXYGEN__) +#define GPIOA_BIT (1 << 0) +#if TIVA_GPIO_GPIOA_USE_AHB && defined(TM4C123x) +#define GPIOA_AHB_BIT (1 << 0) +#else +#define GPIOA_AHB_BIT 0 +#endif +#else +#define GPIOA_BIT 0 +#define GPIOA_AHB_BIT 0 +#endif + +#if TIVA_HAS_GPIOB || defined(__DOXYGEN__) +#define GPIOB_BIT (1 << 1) +#if TIVA_GPIO_GPIOB_USE_AHB && defined(TM4C123x) +#define GPIOB_AHB_BIT (1 << 1) +#else +#define GPIOB_AHB_BIT 0 +#endif +#else +#define GPIOB_BIT 0 +#define GPIOB_AHB_BIT 0 +#endif + +#if TIVA_HAS_GPIOC || defined(__DOXYGEN__) +#define GPIOC_BIT (1 << 2) +#if TIVA_GPIO_GPIOC_USE_AHB && defined(TM4C123x) +#define GPIOC_AHB_BIT (1 << 2) +#else +#define GPIOC_AHB_BIT 0 +#endif +#else +#define GPIOC_BIT 0 +#define GPIOC_AHB_BIT 0 +#endif + +#if TIVA_HAS_GPIOD || defined(__DOXYGEN__) +#define GPIOD_BIT (1 << 3) +#if TIVA_GPIO_GPIOD_USE_AHB && defined(TM4C123x) +#define GPIOD_AHB_BIT (1 << 3) +#else +#define GPIOD_AHB_BIT 0 +#endif +#else +#define GPIOD_BIT 0 +#define GPIOD_AHB_BIT 0 +#endif + +#if TIVA_HAS_GPIOE || defined(__DOXYGEN__) +#define GPIOE_BIT (1 << 4) +#if TIVA_GPIO_GPIOE_USE_AHB && defined(TM4C123x) +#define GPIOE_AHB_BIT (1 << 4) +#else +#define GPIOE_AHB_BIT 0 +#endif +#else +#define GPIOE_BIT 0 +#define GPIOE_AHB_BIT 0 +#endif + +#if TIVA_HAS_GPIOF || defined(__DOXYGEN__) +#define GPIOF_BIT (1 << 5) +#if TIVA_GPIO_GPIOF_USE_AHB && defined(TM4C123x) +#define GPIOF_AHB_BIT (1 << 5) +#else +#define GPIOF_AHB_BIT 0 +#endif +#else +#define GPIOF_BIT 0 +#define GPIOF_AHB_BIT 0 +#endif #if TIVA_HAS_GPIOG || defined(__DOXYGEN__) -#define RCGCGPIOG (1 << 6) +#define GPIOG_BIT (1 << 6) +#if TIVA_GPIO_GPIOG_USE_AHB && defined(TM4C123x) +#define GPIOG_AHB_BIT (1 << 6) +#else +#define GPIOG_AHB_BIT 0 +#endif #else -#define RCGCGPIOG 0 +#define GPIOG_BIT 0 +#define GPIOG_AHB_BIT 0 #endif #if TIVA_HAS_GPIOH || defined(__DOXYGEN__) -#define RCGCGPIOH (1 << 7) +#define GPIOH_BIT (1 << 7) +#if TIVA_GPIO_GPIOH_USE_AHB && defined(TM4C123x) +#define GPIOH_AHB_BIT (1 << 7) +#else +#define GPIOH_AHB_BIT 0 +#endif #else -#define RCGCGPIOH 0 +#define GPIOH_BIT 0 +#define GPIOH_AHB_BIT 0 #endif #if TIVA_HAS_GPIOJ || defined(__DOXYGEN__) -#define RCGCGPIOJ (1 << 8) +#define GPIOJ_BIT (1 << 8) +#if TIVA_GPIO_GPIOJ_USE_AHB && defined(TM4C123x) +#define GPIOJ_AHB_BIT (1 << 8) #else -#define RCGCGPIOJ 0 +#define GPIOJ_AHB_BIT 0 +#endif +#else +#define GPIOJ_BIT 0 +#define GPIOJ_AHB_BIT 0 #endif #if TIVA_HAS_GPIOK || defined(__DOXYGEN__) -#define RCGCGPIOK (1 << 9) +#define GPIOK_BIT (1 << 9) +#define GPIOK_AHB_BIT (1 << 9) #else -#define RCGCGPIOK 0 +#define GPIOK_BIT 0 +#define GPIOK_AHB_BIT 0 #endif #if TIVA_HAS_GPIOL || defined(__DOXYGEN__) -#define RCGCGPIOL (1 << 10) +#define GPIOL_BIT (1 << 10) +#define GPIOL_AHB_BIT (1 << 10) #else -#define RCGCGPIOL 0 +#define GPIOL_BIT 0 +#define GPIOL_AHB_BIT 0 #endif #if TIVA_HAS_GPIOM || defined(__DOXYGEN__) -#define RCGCGPIOM (1 << 11) +#define GPIOM_BIT (1 << 11) +#define GPIOM_AHB_BIT (1 << 11) #else -#define RCGCGPIOM 0 +#define GPIOM_BIT 0 +#define GPIOM_AHB_BIT 0 #endif #if TIVA_HAS_GPION || defined(__DOXYGEN__) -#define RCGCGPION (1 << 12) +#define GPION_BIT (1 << 12) +#define GPION_AHB_BIT (1 << 12) #else -#define RCGCGPION 0 +#define GPION_BIT 0 +#define GPION_AHB_BIT 0 #endif #if TIVA_HAS_GPIOP || defined(__DOXYGEN__) -#define RCGCGPIOP (1 << 13) +#define GPIOP_BIT (1 << 13) +#define GPIOP_AHB_BIT (1 << 13) #else -#define RCGCGPIOP 0 +#define GPIOP_BIT 0 +#define GPIOP_AHB_BIT 0 #endif #if TIVA_HAS_GPIOQ || defined(__DOXYGEN__) -#define RCGCGPIOQ (1 << 14) +#define GPIOQ_BIT (1 << 14) +#define GPIOQ_AHB_BIT (1 << 14) #else -#define RCGCGPIOQ 0 +#define GPIOQ_BIT 0 +#define GPIOQ_AHB_BIT 0 #endif #if TIVA_HAS_GPIOR || defined(__DOXYGEN__) -#define RCGCGPIOR (1 << 15) +#define GPIOR_BIT (1 << 15) +#define GPIOR_AHB_BIT (1 << 15) #else -#define RCGCGPIOR 0 +#define GPIOR_BIT 0 +#define GPIOR_AHB_BIT 0 #endif #if TIVA_HAS_GPIOS || defined(__DOXYGEN__) -#define RCGCGPIOS (1 << 16) +#define GPIOS_BIT (1 << 16) +#define GPIOS_AHB_BIT (1 << 16) #else -#define RCGCGPIOS 0 +#define GPIOS_BIT 0 +#define GPIOS_AHB_BIT 0 #endif #if TIVA_HAS_GPIOT || defined(__DOXYGEN__) -#define RCGCGPIOT (1 << 17) +#define GPIOT_BIT (1 << 17) +#define GPIOT_AHB_BIT (1 << 17) #else -#define RCGCGPIOT 0 +#define GPIOT_BIT 0 +#define GPIOT_AHB_BIT 0 #endif -#define RCGCGPIO_VALUE (RCGCGPIOA | RCGCGPIOB | RCGCGPIOC | RCGCGPIOD | \ - RCGCGPIOE | RCGCGPIOF | RCGCGPIOG | RCGCGPIOH | \ - RCGCGPIOJ | RCGCGPIOK | RCGCGPIOL | RCGCGPIOM | \ - RCGCGPION | RCGCGPIOP | RCGCGPIOQ | RCGCGPIOR | \ - RCGCGPIOS | RCGCGPIOT) +#define RCGCGPIO_MASK (GPIOA_BIT | GPIOB_BIT | GPIOC_BIT | GPIOD_BIT | \ + GPIOE_BIT | GPIOF_BIT | GPIOG_BIT | GPIOH_BIT | \ + GPIOJ_BIT | GPIOK_BIT | GPIOL_BIT | GPIOM_BIT | \ + GPION_BIT | GPIOP_BIT | GPIOQ_BIT | GPIOR_BIT | \ + GPIOS_BIT | GPIOR_BIT) + +#define GPIOHBCTL_MASK (GPIOA_AHB_BIT | GPIOB_AHB_BIT | GPIOC_AHB_BIT | \ + GPIOD_AHB_BIT | GPIOE_AHB_BIT | GPIOF_AHB_BIT | \ + GPIOG_AHB_BIT | GPIOH_AHB_BIT | GPIOJ_AHB_BIT | \ + GPIOK_AHB_BIT | GPIOL_AHB_BIT | GPIOM_AHB_BIT | \ + GPION_AHB_BIT | GPIOP_AHB_BIT | GPIOQ_AHB_BIT | \ + GPIOR_AHB_BIT | GPIOS_AHB_BIT | GPIOT_AHB_BIT) /* GPIO lock password.*/ #define TIVA_GPIO_LOCK_PWD 0x4C4F434B +#define GPIOC_JTAG_MASK (0x0F) +#define GPIOD_NMI_MASK (0x80) +#define GPIOF_NMI_MASK (0x01) + /*===========================================================================*/ /* Driver exported variables. */ /*===========================================================================*/ @@ -130,21 +242,40 @@ /* Driver local functions. */ /*===========================================================================*/ -void gpio_init (GPIO_TypeDef *gpiop, const tiva_gpio_setup_t *config) +/** + * @brief Initializes the port with the port configuration. + * + * @param[in] port the port identifier + * @param[in] config the port configuration + */ +static void gpio_init(ioportid_t port, const tiva_gpio_setup_t *config) +{ + port->DATA = config->data; + port->DIR = config->dir; + port->AFSEL = config->afsel; + port->DR2R = config->dr2r; + port->DR4R = config->dr4r; + port->DR8R = config->dr8r; + port->ODR = config->odr; + port->PUR = config->pur; + port->PDR = config->pdr; + port->SLR = config->slr; + port->DEN = config->den; + port->AMSEL = config->amsel; + port->PCTL = config->pctl; +} + +/** + * @brief Unlocks the masked pins of the GPIO peripheral. + * @note This function is only useful for PORTC0-3, PORTD7 and PORTF0. + * + * @param[in] port the port identifier + * @param[in] mask the pin mask + */ +static void gpio_unlock(ioportid_t port, ioportmask_t mask) { - gpiop->DATA = config->data; - gpiop->DIR = config->dir; - gpiop->AFSEL = config->afsel; - gpiop->DR2R = config->dr2r; - gpiop->DR4R = config->dr4r; - gpiop->DR8R = config->dr8r; - gpiop->ODR = config->odr; - gpiop->PUR = config->pur; - gpiop->PDR = config->pdr; - gpiop->SLR = config->slr; - gpiop->DEN = config->den; - gpiop->AMSEL = config->amsel; - gpiop->PCTL = config->pctl; + port->LOCK = TIVA_GPIO_LOCK_PWD; + port->CR = mask; } /*===========================================================================*/ @@ -156,86 +287,87 @@ void gpio_init (GPIO_TypeDef *gpiop, const tiva_gpio_setup_t *config) /*===========================================================================*/ /** - * @brief TIVA I/O ports configuration. + * @brief Tiva I/O ports configuration. * @details Ports A-F (G, H, J, K, L, M, N, P, Q, R, S, T) clocks enabled. * - * @param[in] config the TIVA ports configuration + * @param[in] config the Tiva ports configuration * * @notapi */ void _pal_lld_init(const PALConfig *config) { - SYSCTL->RCGCGPIO = RCGCGPIO_VALUE; + /* + * Enables all GPIO clocks. + */ + SYSCTL->RCGCGPIO = RCGCGPIO_MASK; +#if defined(TM4C123x) + SYSCTL->GPIOHBCTL = GPIOHBCTL_MASK; +#endif - __NOP(); - __NOP(); - __NOP(); + /* Wait until all GPIO modules are ready */ + while (!((SYSCTL->PRGPIO & RCGCGPIO_MASK) == RCGCGPIO_MASK)) + ; +#if TIVA_HAS_GPIOA gpio_init(GPIOA, &config->PAData); - +#endif +#if TIVA_HAS_GPIOB gpio_init(GPIOB, &config->PBData); - - GPIOC->LOCK = TIVA_GPIO_LOCK_PWD; - GPIOC->CR = 0x01; +#endif +#if TIVA_HAS_GPIOC + /* Unlock JTAG pins.*/ + gpio_unlock(GPIOC, GPIOC_JTAG_MASK); gpio_init(GPIOC, &config->PCData); - GPIOC->LOCK = 0; - +#endif +#if TIVA_HAS_GPIOD + /* Unlock NMI pin.*/ + gpio_unlock(GPIOD, GPIOD_NMI_MASK); gpio_init(GPIOD, &config->PDData); - +#endif +#if TIVA_HAS_GPIOE gpio_init(GPIOE, &config->PEData); - - GPIOF->LOCK = TIVA_GPIO_LOCK_PWD; - GPIOF->CR = 0x01; +#endif +#if TIVA_HAS_GPIOF + /* Unlock NMI pin.*/ + gpio_unlock(GPIOF, GPIOF_NMI_MASK); gpio_init(GPIOF, &config->PFData); - GPIOF->LOCK = 0; - +#endif #if TIVA_HAS_GPIOG || defined(__DOXYGEN__) gpio_init(GPIOG, &config->PGData); -#endif /* TIVA_HAS_GPIOG.*/ - +#endif #if TIVA_HAS_GPIOH || defined(__DOXYGEN__) gpio_init(GPIOH, &config->PHData); -#endif /* TIVA_HAS_GPIOH.*/ - +#endif #if TIVA_HAS_GPIOJ || defined(__DOXYGEN__) gpio_init(GPIOJ, &config->PJData); -#endif /* TIVA_HAS_GPIOJ.*/ - +#endif #if TIVA_HAS_GPIOK || defined(__DOXYGEN__) gpio_init(GPIOK, &config->PKData); -#endif /* TIVA_HAS_GPIOK.*/ - +#endif #if TIVA_HAS_GPIOL || defined(__DOXYGEN__) gpio_init(GPIOL, &config->PLData); -#endif /* TIVA_HAS_GPIOL.*/ - +#endif #if TIVA_HAS_GPIOM || defined(__DOXYGEN__) gpio_init(GPIOM, &config->PMData); -#endif /* TIVA_HAS_GPIOM.*/ - +#endif #if TIVA_HAS_GPION || defined(__DOXYGEN__) gpio_init(GPION, &config->PNData); -#endif /* TIVA_HAS_GPION.*/ - +#endif #if TIVA_HAS_GPIOP || defined(__DOXYGEN__) gpio_init(GPIOP, &config->PPData); -#endif /* TIVA_HAS_GPIOP.*/ - +#endif #if TIVA_HAS_GPIOQ || defined(__DOXYGEN__) gpio_init(GPIOQ, &config->PQData); -#endif /* TIVA_HAS_GPIOQ.*/ - +#endif #if TIVA_HAS_GPIOR || defined(__DOXYGEN__) gpio_init(GPIOR, &config->PRData); -#endif /* TIVA_HAS_GPIOR.*/ - +#endif #if TIVA_HAS_GPIOS || defined(__DOXYGEN__) gpio_init(GPIOS, &config->PSData); -#endif /* TIVA_HAS_GPIOS.*/ - +#endif #if TIVA_HAS_GPIOT || defined(__DOXYGEN__) gpio_init(GPIOT, &config->PTData); -#endif /* TIVA_HAS_GPIOT.*/ +#endif } /** @@ -249,61 +381,61 @@ void _pal_lld_init(const PALConfig *config) * * @notapi */ -void _pal_lld_setgroupmode(ioportid_t port, - ioportmask_t mask, - iomode_t mode) +void _pal_lld_setgroupmode(ioportid_t port, ioportmask_t mask, iomode_t mode) { - /* TODO: What does this function exactly do? The pins are already configured - * in board.h and initialized by the pal driver. */ - - (void) port; - (void) mask; - (void) mode; - - /* - switch (mode) { - case PAL_MODE_UNCONNECTED: - case PAL_MODE_INPUT_PULLUP: - port->PUR |= mask; - case PAL_MODE_INPUT: - port->AFSEL &= ~mask; - port->DIR &= ~mask; - port->ODR &= ~mask; - port->DEN |= mask; - break; - - case PAL_MODE_INPUT_PULLDOWN: - port->AFSEL &= ~mask; - port->DIR &= ~mask; - port->ODR &= ~mask; - port->DEN |= mask; - port->PDR |= mask; - break; - - case PAL_MODE_RESET: - case PAL_MODE_INPUT_ANALOG: - port->AFSEL &= ~mask; - port->DIR &= ~mask; - port->ODR &= ~mask; - port->DEN &= ~mask; - port->PUR &= ~mask; - port->PDR &= ~mask; - break; - - case PAL_MODE_OUTPUT_PUSHPULL: - port->AFSEL &= ~mask; - port->DIR |= mask; - port->ODR &= ~mask; - port->DEN |= mask; - break; - - case PAL_MODE_OUTPUT_OPENDRAIN: - port->AFSEL &= ~mask; - port->DIR |= mask; - port->ODR |= mask; - port->DEN |= mask; - break; - }*/ + uint32_t dir = (mode & PAL_TIVA_DIR_MASK) >> 0; + uint32_t afsel = (mode & PAL_TIVA_AFSEL_MASK) >> 1; + uint32_t dr2r = (mode & PAL_TIVA_DR2R_MASK) >> 2; + uint32_t dr4r = (mode & PAL_TIVA_DR4R_MASK) >> 3; + uint32_t dr8r = (mode & PAL_TIVA_DR8R_MASK) >> 4; + uint32_t odr = (mode & PAL_TIVA_ODR_MASK) >> 5; + uint32_t pur = (mode & PAL_TIVA_PUR_MASK) >> 6; + uint32_t pdr = (mode & PAL_TIVA_PDR_MASK) >> 7; + uint32_t slr = (mode & PAL_TIVA_SLR_MASK) >> 8; + uint32_t den = (mode & PAL_TIVA_DEN_MASK) >> 9; + uint32_t amsel = (mode & PAL_TIVA_AMSEL_MASK) >> 10; + uint32_t pctl = (mode & PAL_TIVA_PCTL_MASK) >> 11; + uint32_t bit = 0; + + while(TRUE) { + uint32_t pctl_mask = (7 << (4 * bit)); + uint32_t bit_mask = (1 << bit); + + if ((mask & 1) != 0) { + port->DIR = (port->DIR & ~bit_mask) | dir; + port->AFSEL = (port->AFSEL & ~bit_mask) | afsel; + port->DR2R = (port->DR2R & ~bit_mask) | dr2r; + port->DR4R = (port->DR4R & ~bit_mask) | dr4r; + port->DR8R = (port->DR8R & ~bit_mask) | dr8r; + port->ODR = (port->ODR & ~bit_mask) | odr; + port->PUR = (port->PUR & ~bit_mask) | pur; + port->PDR = (port->PDR & ~bit_mask) | pdr; + port->SLR = (port->SLR & ~bit_mask) | slr; + port->DEN = (port->DEN & ~bit_mask) | den; + port->AMSEL = (port->AMSEL & ~bit_mask) | amsel; + port->PCTL = (port->PCTL & ~pctl_mask) | pctl; + } + + mask >>= 1; + if (!mask) { + return; + } + + dir <<= 1; + afsel <<= 1; + dr2r <<= 1; + dr4r <<= 1; + dr8r <<= 1; + odr <<= 1; + pur <<= 1; + pdr <<= 1; + slr <<= 1; + den <<= 1; + amsel <<= 1; + pctl <<= 4; + + bit++; + } } #endif /* HAL_USE_PAL */ |