Merged in v01d/nuttx/lpc43-gpio-fixes (pull request #38)

lpc43 GPIO Interrupts enabled and fixed (not all cases tested)
This commit is contained in:
Gregory Nutt 2016-06-04 07:46:04 -06:00
commit 8126a3d37d
5 changed files with 61 additions and 7 deletions

View File

@ -150,6 +150,13 @@ endchoice # LPC43XX Boot Configuration
menu "LPC43xx Peripheral Support" menu "LPC43xx Peripheral Support"
config GPIO_IRQ
bool "GPIO interrupt support"
default n
---help---
Enable support for GPIO interrupts
config LPC43_ADC0 config LPC43_ADC0
bool "ADC0" bool "ADC0"
default n default n

View File

@ -49,6 +49,10 @@
#include "up_arch.h" #include "up_arch.h"
#include "lpc43_gpio.h" #include "lpc43_gpio.h"
#ifdef CONFIG_GPIO_IRQ
#include "lpc43_gpioint.h"
#endif
/**************************************************************************** /****************************************************************************
* Pre-processor Definitions * Pre-processor Definitions
****************************************************************************/ ****************************************************************************/

View File

@ -143,7 +143,7 @@
* ..CC C... .... .... * ..CC C... .... ....
*/ */
#define GPIO_PININT_SHIFT (10) /* Bits 11-13: Pin interrupt number */ #define GPIO_PININT_SHIFT (11) /* Bits 11-13: Pin interrupt number */
#define GPIO_PININT_MASK (7 << GPIO_PININT_SHIFT) #define GPIO_PININT_MASK (7 << GPIO_PININT_SHIFT)
# define GPIO_PININT0 (0 << GPIO_PININT_SHIFT) # define GPIO_PININT0 (0 << GPIO_PININT_SHIFT)
# define GPIO_PININT1 (1 << GPIO_PININT_SHIFT) # define GPIO_PININT1 (1 << GPIO_PININT_SHIFT)
@ -162,9 +162,9 @@
* .... .III .... .... * .... .III .... ....
*/ */
#define _GPIO_INT_LEVEL (1 << 10) /* Bit 10: 1=Level (vs edge) */ #define _GPIO_INT_EDGE (1 << 10) /* Bit 10: 1=Edge (vs level) */
#define _GPIO_INT_HIGH (1 << 9) /* Bit 9: 1=High level or rising edge */ #define _GPIO_INT_LOW (1 << 9) /* Bit 9: 1=Low level or falling edge */
#define _GPIO_INT_LOW (1 << 8) /* Bit 8: 1=Low level or falling edge */ #define _GPIO_INT_HIGH (1 << 8) /* Bit 8: 1=High level or rising edge */
#define GPIO_INT_SHIFT (8) /* Bits 8-10: Interrupt mode */ #define GPIO_INT_SHIFT (8) /* Bits 8-10: Interrupt mode */
#define GPIO_INT_MASK (7 << GPIO_INT_SHIFT) #define GPIO_INT_MASK (7 << GPIO_INT_SHIFT)
@ -176,8 +176,8 @@
#define GPIO_IS_ACTIVE_HI(p) (((p) & _GPIO_INT_HIGH) != 0) #define GPIO_IS_ACTIVE_HI(p) (((p) & _GPIO_INT_HIGH) != 0)
#define GPIO_IS_ACTIVE_LOW(p) (((p) & _GPIO_INT_LOW) != 0) #define GPIO_IS_ACTIVE_LOW(p) (((p) & _GPIO_INT_LOW) != 0)
#define GPIO_IS_EDGE(p) (((p) & _GPIO_INT_LEVEL) == 0) #define GPIO_IS_LEVEL(p) (((p) & _GPIO_INT_EDGE) == 0)
#define GPIO_IS_LEVEL(p) (((p) & _GPIO_INT_LEVEL) != 0) #define GPIO_IS_EDGE(p) (((p) & _GPIO_INT_EDGE) != 0)
/* GPIO Port Number: /* GPIO Port Number:
* *

View File

@ -57,6 +57,7 @@
#include <arch/board/board.h> #include <arch/board/board.h>
#include <nuttx/config.h> #include <nuttx/config.h>
#include <debug.h>
#include <errno.h> #include <errno.h>
@ -176,7 +177,7 @@ int lpc43_gpioint_grpinitialize(int group, bool anded, bool level)
int lpc43_gpioint_pinconfig(uint16_t gpiocfg) int lpc43_gpioint_pinconfig(uint16_t gpiocfg)
{ {
unsigned int port = ((gpiocfg & GPIO_PORT_MASK) >> GPIO_PORT_SHIFT); unsigned int port = ((gpiocfg & GPIO_PORT_MASK) >> GPIO_PORT_SHIFT);
unsigned int pin = ((gpiocfg & GPIO_PORT_MASK) >> GPIO_PORT_SHIFT); unsigned int pin = ((gpiocfg & GPIO_PIN_MASK) >> GPIO_PIN_SHIFT);
unsigned int pinint = ((gpiocfg & GPIO_PININT_MASK) >> GPIO_PININT_SHIFT); unsigned int pinint = ((gpiocfg & GPIO_PININT_MASK) >> GPIO_PININT_SHIFT);
uint32_t bitmask = (1 << pinint); uint32_t bitmask = (1 << pinint);
uint32_t regval; uint32_t regval;
@ -227,6 +228,8 @@ int lpc43_gpioint_pinconfig(uint16_t gpiocfg)
/* Configure the active high level or rising edge */ /* Configure the active high level or rising edge */
/* TODO: this works for edge sensitive, but not level sensitive, active level is only controlled in IENF */
regval = getreg32(LPC43_GPIOINT_IENR); regval = getreg32(LPC43_GPIOINT_IENR);
if (GPIO_IS_ACTIVE_HI(gpiocfg)) if (GPIO_IS_ACTIVE_HI(gpiocfg))
{ {
@ -321,4 +324,28 @@ int lpc43_gpioint_grpconfig(uint16_t gpiocfg)
return OK; return OK;
} }
/****************************************************************************
* Name: lpc43_gpioint_ack
*
* Description:
* Acknowledge the interrupt for a given pint interrupt number. Call this
* inside the interrupt handler. For edge sensitive interrupts, the interrupt
* status is cleared. For level sensitive interrupts, the active-high/-low
* sensitivity is inverted.
*
* Returned Value:
* Zero on success; a negated errno value on failure.
*
****************************************************************************/
int lpc43_gpioint_ack(uint8_t intnumber)
{
uint32_t regval;
regval = getreg32(LPC43_GPIOINT_IST);
regval |= (1 << intnumber);
putreg32(regval, LPC43_GPIOINT_IST);
return OK;
}
#endif /* CONFIG_GPIO_IRQ */ #endif /* CONFIG_GPIO_IRQ */

View File

@ -136,5 +136,21 @@ int lpc43_gpioint_pinconfig(uint16_t gpiocfg);
int lpc43_gpioint_grpconfig(uint16_t gpiocfg); int lpc43_gpioint_grpconfig(uint16_t gpiocfg);
/****************************************************************************
* Name: lpc43_gpioint_ack
*
* Description:
* Acknowledge the interrupt for a given pint interrupt number. Call this
* inside the interrupt handler. For edge sensitive interrupts, the interrupt
* status is cleared. For level sensitive interrupts, the active-high/-low
* sensitivity is inverted.
*
* Returned Value:
* Zero on success; a negated errno value on failure.
*
****************************************************************************/
int lpc43_gpioint_ack(uint8_t intnumber);
#endif /* CONFIG_GPIO_IRQ */ #endif /* CONFIG_GPIO_IRQ */
#endif /* __ARCH_ARM_SRC_LPC43XX_LPC43_GPIOINT_H */ #endif /* __ARCH_ARM_SRC_LPC43XX_LPC43_GPIOINT_H */