mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-07 16:38:30 -04:00
146 lines
4.4 KiB
C
146 lines
4.4 KiB
C
|
#ifndef _EXTI_H_
|
||
|
#define _EXTI_H_
|
||
|
|
||
|
#include <string.h>
|
||
|
#include "hal_types.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
|
||
|
/**
|
||
|
* External interrupt line numbers.
|
||
|
*/
|
||
|
typedef enum afio_exti_num {
|
||
|
AFIO_EXTI_0, /**< External interrupt line 0. */
|
||
|
AFIO_EXTI_1, /**< External interrupt line 1. */
|
||
|
AFIO_EXTI_2, /**< External interrupt line 2. */
|
||
|
AFIO_EXTI_3, /**< External interrupt line 3. */
|
||
|
AFIO_EXTI_4, /**< External interrupt line 4. */
|
||
|
AFIO_EXTI_5, /**< External interrupt line 5. */
|
||
|
AFIO_EXTI_6, /**< External interrupt line 6. */
|
||
|
AFIO_EXTI_7, /**< External interrupt line 7. */
|
||
|
AFIO_EXTI_8, /**< External interrupt line 8. */
|
||
|
AFIO_EXTI_9, /**< External interrupt line 9. */
|
||
|
AFIO_EXTI_10, /**< External interrupt line 10. */
|
||
|
AFIO_EXTI_11, /**< External interrupt line 11. */
|
||
|
AFIO_EXTI_12, /**< External interrupt line 12. */
|
||
|
AFIO_EXTI_13, /**< External interrupt line 13. */
|
||
|
AFIO_EXTI_14, /**< External interrupt line 14. */
|
||
|
AFIO_EXTI_15, /**< External interrupt line 15. */
|
||
|
} afio_exti_num;
|
||
|
|
||
|
/**
|
||
|
* @brief External interrupt line port selector.
|
||
|
*
|
||
|
* Used to determine which GPIO port to map an external interrupt line
|
||
|
* onto. */
|
||
|
/* (See AFIO sections, below) */
|
||
|
typedef enum afio_exti_port {
|
||
|
AFIO_EXTI_PA, /**< Use port A (PAx) pin. */
|
||
|
AFIO_EXTI_PB, /**< Use port B (PBx) pin. */
|
||
|
AFIO_EXTI_PC, /**< Use port C (PCx) pin. */
|
||
|
AFIO_EXTI_PD, /**< Use port D (PDx) pin. */
|
||
|
AFIO_EXTI_PE, /**< Use port E (PEx) pin. */
|
||
|
AFIO_EXTI_PF, /**< Use port E (PEx) pin. */
|
||
|
AFIO_EXTI_PG, /**< Use port E (PEx) pin. */
|
||
|
} afio_exti_port;
|
||
|
|
||
|
/** External interrupt trigger mode */
|
||
|
typedef enum exti_trigger_mode {
|
||
|
EXTI_RISING, /**< Trigger on the rising edge */
|
||
|
EXTI_FALLING, /**< Trigger on the falling edge */
|
||
|
EXTI_RISING_FALLING /**< Trigger on both the rising and falling edges */
|
||
|
} exti_trigger_mode;
|
||
|
|
||
|
|
||
|
|
||
|
void exti_init();
|
||
|
|
||
|
/**
|
||
|
* @brief Register a handler to run upon external interrupt.
|
||
|
*
|
||
|
* This function assumes that the interrupt request corresponding to
|
||
|
* the given external interrupt is masked.
|
||
|
*
|
||
|
* @param num External interrupt line number.
|
||
|
* @param port Port to use as source input for external interrupt.
|
||
|
* @param handler Function handler to execute when interrupt is triggered.
|
||
|
* @param mode Type of transition to trigger on, one of:
|
||
|
* EXTI_RISING, EXTI_FALLING, EXTI_RISING_FALLING.
|
||
|
* @see afio_exti_num
|
||
|
* @see afio_exti_port
|
||
|
* @see voidFuncPtr
|
||
|
* @see exti_trigger_mode
|
||
|
*/
|
||
|
void exti_attach_interrupt(afio_exti_num num,
|
||
|
afio_exti_port port,
|
||
|
Handler handler,
|
||
|
exti_trigger_mode mode);
|
||
|
|
||
|
|
||
|
void exti_attach_interrupt_pri(afio_exti_num num,
|
||
|
afio_exti_port port,
|
||
|
Handler handler,
|
||
|
exti_trigger_mode mode,
|
||
|
uint8_t priority);
|
||
|
/**
|
||
|
* @brief Unregister an external interrupt handler
|
||
|
* @param num Number of the external interrupt line to disable.
|
||
|
* @see afio_exti_num
|
||
|
*/
|
||
|
void exti_detach_interrupt(afio_exti_num num);
|
||
|
|
||
|
|
||
|
void exti_enable_interrupt(afio_exti_num num, bool e); // needed access to internal data
|
||
|
|
||
|
/**
|
||
|
* Re-enable interrupts.
|
||
|
*
|
||
|
* Call this after noInterrupts() to re-enable interrupt handling,
|
||
|
* after you have finished with a timing-critical section of code.
|
||
|
*
|
||
|
* @see noInterrupts()
|
||
|
*/
|
||
|
static INLINE void interrupts() {
|
||
|
__enable_irq();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Disable interrupts.
|
||
|
*
|
||
|
* After calling this function, all user-programmable interrupts will
|
||
|
* be disabled. You can call this function before a timing-critical
|
||
|
* section of code, then call interrupts() to re-enable interrupt
|
||
|
* handling.
|
||
|
*
|
||
|
* @see interrupts()
|
||
|
*/
|
||
|
static INLINE void noInterrupts() {
|
||
|
__disable_irq();
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
static inline void exti_clear_pending_bit(uint32_t EXTI_Line)
|
||
|
{
|
||
|
EXTI->PR = EXTI_Line;
|
||
|
}
|
||
|
|
||
|
|
||
|
void EXTI0_IRQHandler(void);
|
||
|
void EXTI1_IRQHandler(void);
|
||
|
void EXTI2_IRQHandler(void);
|
||
|
void EXTI3_IRQHandler(void);
|
||
|
void EXTI4_IRQHandler(void);
|
||
|
void EXTI9_5_IRQHandler(void);
|
||
|
void EXTI15_10_IRQHandler(void);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
|
||
|
#endif
|