Fix button interrupt logic for Open1788; Add button test as option to configs/open1788/nsh
This commit is contained in:
parent
d43857d54f
commit
40d10b47eb
@ -560,6 +560,32 @@ CONFIGURATION
|
|||||||
CONFIG_DEBUG_VERBOSE=y
|
CONFIG_DEBUG_VERBOSE=y
|
||||||
CONFIG_DEBUG_INPUT=y
|
CONFIG_DEBUG_INPUT=y
|
||||||
|
|
||||||
|
7. The button test (apps/examples/buttons) can be built-in by adding
|
||||||
|
the following options. See apps/examples/README.txt for further
|
||||||
|
information about the button test.
|
||||||
|
|
||||||
|
System Type:
|
||||||
|
CONFIG_GPIO_IRQ=y
|
||||||
|
|
||||||
|
Board Selection:
|
||||||
|
CONFIG_ARCH_BUTTONS=y
|
||||||
|
CONFIG_ARCH_IRQBUTTONS=y
|
||||||
|
|
||||||
|
Application Configuration:
|
||||||
|
CONFIG_EXAMPLES_BUTTONS=y
|
||||||
|
CONFIG_EXAMPLES_BUTTONS_MIN=0
|
||||||
|
CONFIG_EXAMPLES_BUTTONS_MAX=7
|
||||||
|
CONFIG_EXAMPLES_IRQBUTTONS_MIN=1
|
||||||
|
CONFIG_EXAMPLES_IRQBUTTONS_MAX=7
|
||||||
|
CONFIG_EXAMPLES_BUTTONS_NAME0="USER1"
|
||||||
|
CONFIG_EXAMPLES_BUTTONS_NAME1="USER2"
|
||||||
|
CONFIG_EXAMPLES_BUTTONS_NAME2="USER3"
|
||||||
|
CONFIG_EXAMPLES_BUTTONS_NAME3="JOYSTICK_A"
|
||||||
|
CONFIG_EXAMPLES_BUTTONS_NAME4="JOYSTICK_B"
|
||||||
|
CONFIG_EXAMPLES_BUTTONS_NAME5="JOYSTICK_C"
|
||||||
|
CONFIG_EXAMPLES_BUTTONS_NAME6="JOYSTICK_D"
|
||||||
|
CONFIG_EXAMPLES_BUTTONS_NAME7="JOYSTICK_CTR"
|
||||||
|
|
||||||
nxlines
|
nxlines
|
||||||
-------
|
-------
|
||||||
Configures the graphics example located at examples/nsh. This
|
Configures the graphics example located at examples/nsh. This
|
||||||
|
@ -258,8 +258,10 @@
|
|||||||
* OFF while sleeping */
|
* OFF while sleeping */
|
||||||
|
|
||||||
/* Button definitions ***************************************************************/
|
/* Button definitions ***************************************************************/
|
||||||
/* The Open1788 supports several buttons. All will read "1" when open and "0"
|
/* The Open1788 supports several buttons. All must be pulled up by the Open1788.
|
||||||
* when closed
|
* When closed, the pins will be pulled to ground. So the buttons will read "1"
|
||||||
|
* when open and "0" when closed. All except USER1 are capable of generating
|
||||||
|
* interrupts.
|
||||||
*
|
*
|
||||||
* USER1 -- Connected to P4[26]
|
* USER1 -- Connected to P4[26]
|
||||||
* USER2 -- Connected to P2[22]
|
* USER2 -- Connected to P2[22]
|
||||||
@ -271,12 +273,13 @@
|
|||||||
* JOY_B -- Connected to P2[26]
|
* JOY_B -- Connected to P2[26]
|
||||||
* JOY_C -- Connected to P2[23]
|
* JOY_C -- Connected to P2[23]
|
||||||
* JOY_D -- Connected to P2[19]
|
* JOY_D -- Connected to P2[19]
|
||||||
* JOY_CTR -- Connected to P0[14]
|
* JOY_CTR -- Connected to P0[14] (shared with SSP1 SSEL)
|
||||||
*
|
*
|
||||||
* The switches are all connected to ground and should be pulled up and sensed
|
* For the interrupting buttons, interrupts are generated on both edges (press and
|
||||||
* with a value of '0' when closed.
|
* release).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#define BOARD_BUTTON_USER1 0
|
#define BOARD_BUTTON_USER1 0
|
||||||
#define BOARD_BUTTON_USER2 1
|
#define BOARD_BUTTON_USER2 1
|
||||||
#define BOARD_BUTTON_USER3 2
|
#define BOARD_BUTTON_USER3 2
|
||||||
|
@ -101,7 +101,7 @@ static xcpt_t g_buttonisr[BOARD_NUM_BUTTONS];
|
|||||||
|
|
||||||
static uint8_t g_buttonirq[BOARD_NUM_BUTTONS] =
|
static uint8_t g_buttonirq[BOARD_NUM_BUTTONS] =
|
||||||
{
|
{
|
||||||
GPIO_USER1_IRQ, GPIO_USER2_IRQ, GPIO_USER3_IRQ, GPIO_JOY_A_IRQ,
|
0, GPIO_USER2_IRQ, GPIO_USER3_IRQ, GPIO_JOY_A_IRQ,
|
||||||
GPIO_JOY_B_IRQ, GPIO_JOY_C_IRQ, GPIO_JOY_D_IRQ, GPIO_JOY_CTR_IRQ
|
GPIO_JOY_B_IRQ, GPIO_JOY_C_IRQ, GPIO_JOY_D_IRQ, GPIO_JOY_CTR_IRQ
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
@ -209,36 +209,43 @@ xcpt_t up_irqbutton(int id, xcpt_t irqhandler)
|
|||||||
|
|
||||||
if ((unsigned)id < BOARD_NUM_BUTTONS)
|
if ((unsigned)id < BOARD_NUM_BUTTONS)
|
||||||
{
|
{
|
||||||
/* Return the current button handler and set the new interrupt handler */
|
/* Get the IRQ number for the button; A value of zero indicates that
|
||||||
|
* the button does not support the interrupt function.
|
||||||
oldhandler = g_buttonisr[id];
|
|
||||||
g_buttonisr[id] = irqhandler;
|
|
||||||
|
|
||||||
/* Disable interrupts until we are done */
|
|
||||||
|
|
||||||
flags = irqsave();
|
|
||||||
|
|
||||||
/* Configure the interrupt. Either attach and enable the new
|
|
||||||
* interrupt or disable and detach the old interrupt handler.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
irq = g_buttonirq[id];
|
irq = g_buttonirq[id];
|
||||||
if (irqhandler)
|
if (irq > 0)
|
||||||
{
|
{
|
||||||
/* Attach then enable the new interrupt handler */
|
/* Disable interrupts until we are done */
|
||||||
|
|
||||||
(void)irq_attach(irq, irqhandler);
|
flags = irqsave();
|
||||||
up_enable_irq(irq);
|
|
||||||
|
/* Return the current button handler and set the new interrupt handler */
|
||||||
|
|
||||||
|
oldhandler = g_buttonisr[id];
|
||||||
|
g_buttonisr[id] = irqhandler;
|
||||||
|
|
||||||
|
/* Configure the interrupt. Either attach and enable the new
|
||||||
|
* interrupt or disable and detach the old interrupt handler.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (irqhandler)
|
||||||
|
{
|
||||||
|
/* Attach then enable the new interrupt handler */
|
||||||
|
|
||||||
|
(void)irq_attach(irq, irqhandler);
|
||||||
|
up_enable_irq(irq);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Disable then then detach the the old interrupt handler */
|
||||||
|
|
||||||
|
up_disable_irq(irq);
|
||||||
|
(void)irq_detach(irq);
|
||||||
|
}
|
||||||
|
|
||||||
|
irqrestore(flags);
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Disable then then detach the the old interrupt handler */
|
|
||||||
|
|
||||||
up_disable_irq(irq);
|
|
||||||
(void)irq_detach(irq);
|
|
||||||
}
|
|
||||||
|
|
||||||
irqrestore(flags);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return oldhandler;
|
return oldhandler;
|
||||||
|
@ -53,7 +53,7 @@
|
|||||||
* reconfigure this pin as normal GPIO input if NAND is used.
|
* reconfigure this pin as normal GPIO input if NAND is used.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define GPIO_NAND_RB (GPIO_INPUT | GPIO_PULLUP | GPIO_PORT2 | GPIO_PIN21)
|
#define GPIO_NAND_RB (GPIO_INPUT | GPIO_PULLUP | GPIO_PORT2 | GPIO_PIN21)
|
||||||
|
|
||||||
/* If CONFIG_ARCH_LEDS is not defined, then the user can control the LEDs in
|
/* If CONFIG_ARCH_LEDS is not defined, then the user can control the LEDs in
|
||||||
* any way. The following definitions are used to access individual LEDs.
|
* any way. The following definitions are used to access individual LEDs.
|
||||||
@ -66,14 +66,16 @@
|
|||||||
* These LEDs are connecte to ground so a high output value will illuminate them.
|
* These LEDs are connecte to ground so a high output value will illuminate them.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define GPIO_LED1 (GPIO_OUTPUT | GPIO_VALUE_ONE | GPIO_PORT1 | GPIO_PIN14)
|
#define GPIO_LED1 (GPIO_OUTPUT | GPIO_VALUE_ONE | GPIO_PORT1 | GPIO_PIN14)
|
||||||
#define GPIO_LED2 (GPIO_OUTPUT | GPIO_VALUE_ONE | GPIO_PORT0 | GPIO_PIN16)
|
#define GPIO_LED2 (GPIO_OUTPUT | GPIO_VALUE_ONE | GPIO_PORT0 | GPIO_PIN16)
|
||||||
#define GPIO_LED3 (GPIO_OUTPUT | GPIO_VALUE_ONE | GPIO_PORT1 | GPIO_PIN13)
|
#define GPIO_LED3 (GPIO_OUTPUT | GPIO_VALUE_ONE | GPIO_PORT1 | GPIO_PIN13)
|
||||||
#define GPIO_LED4 (GPIO_OUTPUT | GPIO_VALUE_ONE | GPIO_PORT4 | GPIO_PIN27)
|
#define GPIO_LED4 (GPIO_OUTPUT | GPIO_VALUE_ONE | GPIO_PORT4 | GPIO_PIN27)
|
||||||
|
|
||||||
/* Button definitions ***************************************************************/
|
/* Button definitions ***************************************************************/
|
||||||
/* The Open1788 supports several buttons. All will read "1" when open and "0"
|
/* The Open1788 supports several buttons. All must be pulled up by the Open1788.
|
||||||
* when closed
|
* When closed, the pins will be pulled to ground. So the buttons will read "1"
|
||||||
|
* when open and "0" when closed. All except USER1 are capable of generating
|
||||||
|
* interrupts.
|
||||||
*
|
*
|
||||||
* USER1 -- Connected to P4[26]
|
* USER1 -- Connected to P4[26]
|
||||||
* USER2 -- Connected to P2[22]
|
* USER2 -- Connected to P2[22]
|
||||||
@ -85,21 +87,31 @@
|
|||||||
* JOY_B -- Connected to P2[26]
|
* JOY_B -- Connected to P2[26]
|
||||||
* JOY_C -- Connected to P2[23]
|
* JOY_C -- Connected to P2[23]
|
||||||
* JOY_D -- Connected to P2[19]
|
* JOY_D -- Connected to P2[19]
|
||||||
* JOY_CTR -- Connected to P0[14]
|
* JOY_CTR -- Connected to P0[14] (shared with SSP1 SSEL)
|
||||||
*
|
*
|
||||||
* The switches are all connected to ground and should be pulled up and sensed
|
* For the interrupting buttons, interrupts are generated on both edges (press and
|
||||||
* with a value of '0' when closed.
|
* release).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define GPIO_USER1 (GPIO_INTBOTH | GPIO_FLOAT | GPIO_PORT4 | GPIO_PIN26)
|
#define GPIO_USER1 (GPIO_INPUT | GPIO_PULLUP | GPIO_PORT4 | GPIO_PIN26)
|
||||||
#define GPIO_USER2 (GPIO_INTBOTH | GPIO_FLOAT | GPIO_PORT2 | GPIO_PIN22)
|
#define GPIO_USER2 (GPIO_INTBOTH | GPIO_PULLUP | GPIO_PORT2 | GPIO_PIN22)
|
||||||
#define GPIO_USER3 (GPIO_INTBOTH | GPIO_FLOAT | GPIO_PORT0 | GPIO_PIN10)
|
#define GPIO_USER3 (GPIO_INTBOTH | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN10)
|
||||||
|
|
||||||
#define GPIO_JOY_A (GPIO_INTBOTH | GPIO_FLOAT | GPIO_PORT2 | GPIO_PIN25)
|
#define GPIO_JOY_A (GPIO_INTBOTH | GPIO_PULLUP | GPIO_PORT2 | GPIO_PIN25)
|
||||||
#define GPIO_JOY_B (GPIO_INTBOTH | GPIO_FLOAT | GPIO_PORT2 | GPIO_PIN26)
|
#define GPIO_JOY_B (GPIO_INTBOTH | GPIO_PULLUP | GPIO_PORT2 | GPIO_PIN26)
|
||||||
#define GPIO_JOY_C (GPIO_INTBOTH | GPIO_FLOAT | GPIO_PORT2 | GPIO_PIN23)
|
#define GPIO_JOY_C (GPIO_INTBOTH | GPIO_PULLUP | GPIO_PORT2 | GPIO_PIN23)
|
||||||
#define GPIO_JOY_D (GPIO_INTBOTH | GPIO_FLOAT | GPIO_PORT2 | GPIO_PIN19)
|
#define GPIO_JOY_D (GPIO_INTBOTH | GPIO_PULLUP | GPIO_PORT2 | GPIO_PIN19)
|
||||||
#define GPIO_JOY_CTR (GPIO_INTBOTH | GPIO_FLOAT | GPIO_PORT0 | GPIO_PIN14)
|
#define GPIO_JOY_CTR (GPIO_INTBOTH | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN14)
|
||||||
|
|
||||||
|
/* IRQ numbers for the buttons that do support interrrupts */
|
||||||
|
|
||||||
|
#define GPIO_USER2_IRQ LPC17_IRQ_P2p22
|
||||||
|
#define GPIO_USER3_IRQ LPC17_IRQ_P0p10
|
||||||
|
#define GPIO_JOY_A_IRQ LPC17_IRQ_P2p25
|
||||||
|
#define GPIO_JOY_B_IRQ LPC17_IRQ_P2p26
|
||||||
|
#define GPIO_JOY_C_IRQ LPC17_IRQ_P2p23
|
||||||
|
#define GPIO_JOY_D_IRQ LPC17_IRQ_P2p19
|
||||||
|
#define GPIO_JOY_CTR_IRQ LPC17_IRQ_P0p14
|
||||||
|
|
||||||
/* SD Card **************************************************************************/
|
/* SD Card **************************************************************************/
|
||||||
/* The SD card detect (CD) signal is on P0[13]. This signal is shared. It is also
|
/* The SD card detect (CD) signal is on P0[13]. This signal is shared. It is also
|
||||||
@ -109,12 +121,12 @@
|
|||||||
* The CD pin is interrupting:
|
* The CD pin is interrupting:
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define GPIO_SD_CD (GPIO_INTBOTH | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN13)
|
#define GPIO_SD_CD (GPIO_INTBOTH | GPIO_PULLUP | GPIO_PORT0 | GPIO_PIN13)
|
||||||
|
|
||||||
/* LCD ******************************************************************************/
|
/* LCD ******************************************************************************/
|
||||||
/* Backlight enable, P2[1]. Initial state is OFF (zero) */
|
/* Backlight enable, P2[1]. Initial state is OFF (zero) */
|
||||||
|
|
||||||
#define GPIO_LCD_BL (GPIO_OUTPUT | GPIO_VALUE_ZERO | GPIO_PORT2 | GPIO_PIN1)
|
#define GPIO_LCD_BL (GPIO_OUTPUT | GPIO_VALUE_ZERO | GPIO_PORT2 | GPIO_PIN1)
|
||||||
|
|
||||||
/* XPT2046 Touchscreen **************************************************************/
|
/* XPT2046 Touchscreen **************************************************************/
|
||||||
/* -------------- -------------------- ------------ --------------
|
/* -------------- -------------------- ------------ --------------
|
||||||
|
Loading…
Reference in New Issue
Block a user