2013-11-27 17:54:30 +01:00
|
|
|
/*
|
2013-08-16 10:20:23 +02:00
|
|
|
* Copyright 2009, Freie Universitaet Berlin (FUB). All rights reserved.
|
|
|
|
*
|
2014-08-23 15:43:13 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
2014-08-27 18:47:31 +02:00
|
|
|
*/
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/**
|
2013-11-27 17:54:30 +01:00
|
|
|
* @defgroup drivers_gpioint GPIO IRQ Multiplexer
|
|
|
|
* @ingroup drivers
|
|
|
|
* @brief Provides an API to implement interrupt handlers on IO pins.
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
|
|
|
* Multiplexer and interrupt handling must be implemented platform specific.
|
|
|
|
*
|
|
|
|
* @{
|
2013-11-27 17:54:30 +01:00
|
|
|
*
|
2010-09-22 15:10:42 +02:00
|
|
|
* @file
|
2013-11-27 17:54:30 +01:00
|
|
|
* @brief GPIO IRQ Multiplexer interface
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2013-11-27 17:54:30 +01:00
|
|
|
* @author Michael Baar <michael.baar@fu-berlin.de>
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
|
2017-01-18 13:00:05 +01:00
|
|
|
#ifndef GPIOINT_H
|
|
|
|
#define GPIOINT_H
|
2015-11-19 17:13:33 +01:00
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
/*
|
2015-11-19 17:13:33 +01:00
|
|
|
* @brief GPIO IRQ multiplexer flags
|
|
|
|
*
|
|
|
|
* @note We rely on the exact values for the edges.
|
|
|
|
* @note These flags are extended in hal/drivers/device-gpio.h
|
|
|
|
*
|
|
|
|
* @{
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
2015-11-19 17:13:33 +01:00
|
|
|
#define GPIOINT_DISABLE 0x00 /**< disable interrupt */
|
|
|
|
#define GPIOINT_RISING_EDGE 0x01 /**< interrupt is generated on rising edge */
|
|
|
|
#define GPIOINT_FALLING_EDGE 0x02 /**< interrupt is generated on falling edge */
|
|
|
|
#define GPIOINT_DEBOUNCE 0x04 /**< debounce this interrupt */
|
|
|
|
/** @} */
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/**
|
2013-11-27 17:54:30 +01:00
|
|
|
* @brief GPIO IRQ callback function type
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
typedef void(*fp_irqcb)(void);
|
|
|
|
|
|
|
|
/**
|
2013-11-27 17:54:30 +01:00
|
|
|
* @brief GPIO IRQ handler setup
|
|
|
|
* @param[in] port CPU specific port number (starting at 0)
|
|
|
|
* @param[in] bitmask One or more bits for which to set the handler
|
|
|
|
* @param[in] flags A combination of #GPIOINT_RISING_EDGE and #GPIOINT_FALLING_EDGE
|
|
|
|
* @param[in] callback A pointer to a handler function
|
|
|
|
* @retval true successful
|
|
|
|
* @retval false failed
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
|
|
|
* To enable interrupt handling for a pin flags and callback must be non-zero. To disable interrupt
|
|
|
|
* handling flags and callback shall be zero.
|
|
|
|
*/
|
|
|
|
bool gpioint_set(int port, uint32_t bitmask, int flags, fp_irqcb callback);
|
|
|
|
|
2015-11-19 17:13:33 +01:00
|
|
|
/**
|
|
|
|
* @brief Initialize the multiplexer
|
|
|
|
*/
|
2010-09-22 15:10:42 +02:00
|
|
|
void gpioint_init(void);
|
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
/** @} */
|
2017-01-18 13:00:05 +01:00
|
|
|
#endif /* GPIOINT_H */
|