mirror of https://github.com/ARMmbed/mbed-os.git
commit
6b9fca177a
|
@ -39,11 +39,11 @@
|
||||||
#define EDGE_FALL (2)
|
#define EDGE_FALL (2)
|
||||||
#define EDGE_BOTH (3)
|
#define EDGE_BOTH (3)
|
||||||
|
|
||||||
#define CHANNEL_NUM (4)
|
#define CHANNEL_NUM (7)
|
||||||
|
|
||||||
static uint32_t channel_ids[CHANNEL_NUM] = {0, 0, 0, 0};
|
static uint32_t channel_ids[CHANNEL_NUM] = {0, 0, 0, 0, 0, 0, 0};
|
||||||
static uint32_t channel_gpio[CHANNEL_NUM] = {0, 0, 0, 0};
|
static uint32_t channel_gpio[CHANNEL_NUM] = {0, 0, 0, 0, 0, 0, 0};
|
||||||
static uint32_t channel_pin[CHANNEL_NUM] = {0, 0, 0, 0};
|
static uint32_t channel_pin[CHANNEL_NUM] = {0, 0, 0, 0, 0, 0, 0};
|
||||||
|
|
||||||
static gpio_irq_handler irq_handler;
|
static gpio_irq_handler irq_handler;
|
||||||
|
|
||||||
|
@ -70,10 +70,13 @@ static void handle_interrupt_in(uint32_t irq_index) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// The irq_index is passed to the function
|
// The irq_index is passed to the function
|
||||||
static void gpio_irq0(void) {handle_interrupt_in(0);}
|
static void gpio_irq0(void) {handle_interrupt_in(0);} // EXTI line 0
|
||||||
static void gpio_irq1(void) {handle_interrupt_in(1);}
|
static void gpio_irq1(void) {handle_interrupt_in(1);} // EXTI line 1
|
||||||
static void gpio_irq2(void) {handle_interrupt_in(2);}
|
static void gpio_irq2(void) {handle_interrupt_in(2);} // EXTI line 2
|
||||||
static void gpio_irq3(void) {handle_interrupt_in(3);}
|
static void gpio_irq3(void) {handle_interrupt_in(3);} // EXTI line 3
|
||||||
|
static void gpio_irq4(void) {handle_interrupt_in(4);} // EXTI line 4
|
||||||
|
static void gpio_irq5(void) {handle_interrupt_in(5);} // EXTI lines 5 to 9
|
||||||
|
static void gpio_irq6(void) {handle_interrupt_in(6);} // EXTI lines 10 to 15
|
||||||
|
|
||||||
extern uint32_t Set_GPIO_Clock(uint32_t port_idx);
|
extern uint32_t Set_GPIO_Clock(uint32_t port_idx);
|
||||||
|
|
||||||
|
@ -88,29 +91,53 @@ int gpio_irq_init(gpio_irq_t *obj, PinName pin, gpio_irq_handler handler, uint32
|
||||||
uint32_t pin_index = STM_PIN(pin);
|
uint32_t pin_index = STM_PIN(pin);
|
||||||
|
|
||||||
// Select irq number and interrupt routine
|
// Select irq number and interrupt routine
|
||||||
switch (pin) {
|
switch (pin_index) {
|
||||||
case PC_13: // User button
|
case 0:
|
||||||
irq_n = EXTI15_10_IRQn;
|
irq_n = EXTI0_IRQn;
|
||||||
vector = (uint32_t)&gpio_irq0;
|
vector = (uint32_t)&gpio_irq0;
|
||||||
irq_index = 0;
|
irq_index = 0;
|
||||||
break;
|
break;
|
||||||
case PB_3:
|
case 1:
|
||||||
irq_n = EXTI3_IRQn;
|
irq_n = EXTI1_IRQn;
|
||||||
vector = (uint32_t)&gpio_irq1;
|
vector = (uint32_t)&gpio_irq1;
|
||||||
irq_index = 1;
|
irq_index = 1;
|
||||||
break;
|
break;
|
||||||
case PB_4:
|
case 2:
|
||||||
irq_n = EXTI4_IRQn;
|
irq_n = EXTI2_IRQn;
|
||||||
vector = (uint32_t)&gpio_irq2;
|
vector = (uint32_t)&gpio_irq2;
|
||||||
irq_index = 2;
|
irq_index = 2;
|
||||||
break;
|
break;
|
||||||
case PB_5:
|
case 3:
|
||||||
irq_n = EXTI9_5_IRQn;
|
irq_n = EXTI3_IRQn;
|
||||||
vector = (uint32_t)&gpio_irq3;
|
vector = (uint32_t)&gpio_irq3;
|
||||||
irq_index = 3;
|
irq_index = 3;
|
||||||
break;
|
break;
|
||||||
|
case 4:
|
||||||
|
irq_n = EXTI4_IRQn;
|
||||||
|
vector = (uint32_t)&gpio_irq4;
|
||||||
|
irq_index = 4;
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
case 6:
|
||||||
|
case 7:
|
||||||
|
case 8:
|
||||||
|
case 9:
|
||||||
|
irq_n = EXTI9_5_IRQn;
|
||||||
|
vector = (uint32_t)&gpio_irq5;
|
||||||
|
irq_index = 5;
|
||||||
|
break;
|
||||||
|
case 10:
|
||||||
|
case 11:
|
||||||
|
case 12:
|
||||||
|
case 13:
|
||||||
|
case 14:
|
||||||
|
case 15:
|
||||||
|
irq_n = EXTI15_10_IRQn;
|
||||||
|
vector = (uint32_t)&gpio_irq6;
|
||||||
|
irq_index = 6;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
error("This pin is not supported with InterruptIn.");
|
error("InterruptIn error: pin not supported.\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue