2014-02-03 19:31:04 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
|
|
|
*
|
2014-08-27 18:47:31 +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-02-03 19:31:04 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2014-10-25 15:37:04 +02:00
|
|
|
* @defgroup driver_periph_gpio GPIO
|
2014-02-03 19:31:04 +01:00
|
|
|
* @ingroup driver_periph
|
2014-02-04 18:46:02 +01:00
|
|
|
* @brief Low-level GPIO peripheral driver
|
2014-02-03 19:31:04 +01:00
|
|
|
*
|
2014-12-04 10:03:15 +01:00
|
|
|
* @{
|
2014-10-25 15:37:04 +02:00
|
|
|
* @file
|
2014-02-04 18:46:02 +01:00
|
|
|
* @brief Low-level GPIO peripheral driver interface definitions
|
2014-02-03 19:31:04 +01:00
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __GPIO_H
|
|
|
|
#define __GPIO_H
|
|
|
|
|
|
|
|
#include "periph_conf.h"
|
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-07-28 16:21:30 +02:00
|
|
|
/* guard file in case no GPIO devices are defined */
|
|
|
|
#if GPIO_NUMOF
|
2014-02-03 19:31:04 +01:00
|
|
|
|
|
|
|
/**
|
2014-02-04 18:46:02 +01:00
|
|
|
* @brief Definition of available GPIO devices. Each device is managing exactly one pin.
|
2014-02-03 19:31:04 +01:00
|
|
|
*/
|
|
|
|
typedef enum {
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_0_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_0 = 0, /**< GPIO device 0 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_1_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_1, /**< GPIO device 1 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_2_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_2, /**< GPIO device 2 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_3_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_3, /**< GPIO device 3 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_4_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_4, /**< GPIO device 4 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_5_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_5, /**< GPIO device 5 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_6_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_6, /**< GPIO device 6 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_7_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_7, /**< GPIO device 7 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_8_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_8, /**< GPIO device 8 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_9_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_9, /**< GPIO device 9 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_10_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_10, /**< GPIO device 10 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_11_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_11, /**< GPIO device 11 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_12_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_12, /**< GPIO device 12 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_13_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_13, /**< GPIO device 13 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_14_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_14, /**< GPIO device 14 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_15_EN
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_15, /**< GPIO device 15 */
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_16_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_16, /**< GPIO device 16 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_17_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_17, /**< GPIO device 17 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_18_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_18, /**< GPIO device 18 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_19_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_19, /**< GPIO device 19 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_20_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_20, /**< GPIO device 20 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_21_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_21, /**< GPIO device 21 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_22_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_22, /**< GPIO device 22 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_23_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_23, /**< GPIO device 23 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_24_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_24, /**< GPIO device 24 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_25_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_25, /**< GPIO device 25 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_26_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_26, /**< GPIO device 26 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_27_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_27, /**< GPIO device 27 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_28_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_28, /**< GPIO device 28 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_29_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_29, /**< GPIO device 29 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_30_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_30, /**< GPIO device 30 */
|
|
|
|
#endif
|
2014-10-17 19:09:25 +02:00
|
|
|
#if GPIO_31_EN
|
2014-10-01 18:42:34 +02:00
|
|
|
GPIO_31, /**< GPIO device 31 */
|
|
|
|
#endif
|
2014-02-03 19:31:04 +01:00
|
|
|
} gpio_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Definition of pull-up/pull-down modes
|
|
|
|
*/
|
|
|
|
typedef enum {
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_NOPULL = 0, /**< do not use internal pull resistors */
|
|
|
|
GPIO_PULLUP = 1, /**< enable internal pull-up resistor */
|
|
|
|
GPIO_PULLDOWN = 2 /**< enable internal pull-down resistor */
|
2014-02-03 19:31:04 +01:00
|
|
|
} gpio_pp_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Definition of possible active flanks for external interrupt mode
|
|
|
|
*/
|
|
|
|
typedef enum {
|
2014-04-03 17:44:49 +02:00
|
|
|
GPIO_FALLING = 0, /**< emit interrupt on falling flank */
|
|
|
|
GPIO_RISING = 1, /**< emit interrupt on rising flank */
|
|
|
|
GPIO_BOTH = 2 /**< emit interrupt on both flanks */
|
2014-02-03 19:31:04 +01:00
|
|
|
} gpio_flank_t;
|
|
|
|
|
2014-07-28 16:21:30 +02:00
|
|
|
/**
|
|
|
|
* @brief Signature for function called from interrupt context after an external event
|
|
|
|
*
|
|
|
|
* @param[in] arg optional context for the callback
|
|
|
|
*/
|
|
|
|
typedef void (*gpio_cb_t)(void *arg);
|
|
|
|
|
2014-02-03 19:31:04 +01:00
|
|
|
/**
|
|
|
|
* @brief Initialize GPIO pin as output pin
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @param[in] dev the GPIO pin to set as output
|
|
|
|
* @param[in] pullup define if pull resistors should be used
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @return 0 on success
|
2014-07-28 16:21:30 +02:00
|
|
|
* @return -1 on pull-up mode unavailable
|
2014-02-03 19:31:04 +01:00
|
|
|
*/
|
2014-04-03 17:44:49 +02:00
|
|
|
int gpio_init_out(gpio_t dev, gpio_pp_t pullup);
|
2014-02-03 19:31:04 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize a GPIO pin in input mode
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @param[in] dev the GPIO pin to use as input
|
|
|
|
* @param[in] pullup define if pull resistors should be used
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @return 0 on success
|
2014-07-28 16:21:30 +02:00
|
|
|
* @return -1 on pull-up mode unavailable
|
2014-02-03 19:31:04 +01:00
|
|
|
*/
|
2014-04-03 17:44:49 +02:00
|
|
|
int gpio_init_in(gpio_t dev, gpio_pp_t pullup);
|
2014-02-03 19:31:04 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize a GPIO pin for external interrupt usage
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-02-04 18:46:02 +01:00
|
|
|
* The registered callback function will be called in interrupt context every time the defined flank(s)
|
2014-02-03 19:31:04 +01:00
|
|
|
* are detected.
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-02-03 19:31:04 +01:00
|
|
|
* The interrupt is activated automatically after the initialization.
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @param[in] dev the GPIO pin to initialize
|
|
|
|
* @param[in] pullup define if pull resistors should be enabled
|
|
|
|
* @param[in] flank define the active flank(s)
|
|
|
|
* @param[in] cb register the callback that is called in interrupt context
|
2014-07-28 16:21:30 +02:00
|
|
|
* @param[in] arg optional argument passed to the callback
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @return 0 on success
|
2014-07-28 16:21:30 +02:00
|
|
|
* @return -1 on pull-up mode unavailable
|
|
|
|
* @return -2 on active flank unavailable
|
2014-02-03 19:31:04 +01:00
|
|
|
*/
|
2014-07-28 16:21:30 +02:00
|
|
|
int gpio_init_int(gpio_t dev, gpio_pp_t pullup, gpio_flank_t flank, gpio_cb_t cb, void *arg);
|
2014-02-03 19:31:04 +01:00
|
|
|
|
2014-07-03 21:51:37 +02:00
|
|
|
/**
|
2014-07-28 16:21:30 +02:00
|
|
|
* @brief Enable the GPIO pin's interrupt if configured as external interrupt source.
|
2014-07-03 21:51:37 +02:00
|
|
|
*
|
2014-07-28 16:21:30 +02:00
|
|
|
* @param[in] dev the GPIO pin to enable the interrupt for
|
2014-07-03 21:51:37 +02:00
|
|
|
*/
|
2014-07-28 16:21:30 +02:00
|
|
|
void gpio_irq_enable(gpio_t dev);
|
2014-07-03 21:51:37 +02:00
|
|
|
|
|
|
|
/**
|
2014-07-28 16:21:30 +02:00
|
|
|
* @brief Disable the GPIO pin's interrupt if configured as external interrupt source.
|
2014-07-03 21:51:37 +02:00
|
|
|
*
|
2014-07-28 16:21:30 +02:00
|
|
|
* @param[in] dev the GPIO pin to disable the interrupt for
|
2014-07-03 21:51:37 +02:00
|
|
|
*/
|
2014-07-28 16:21:30 +02:00
|
|
|
void gpio_irq_disable(gpio_t dev);
|
2014-07-03 21:51:37 +02:00
|
|
|
|
2014-02-03 19:31:04 +01:00
|
|
|
/**
|
|
|
|
* @brief Get the current value of the given GPIO pin
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @param[in] dev the GPIO pin to read
|
2014-07-28 16:21:30 +02:00
|
|
|
* @return the current value, 0 for LOW, != 0 for HIGH
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @return 0 when pin is LOW
|
|
|
|
* @return greater 0 for HIGH
|
2014-02-03 19:31:04 +01:00
|
|
|
*/
|
|
|
|
int gpio_read(gpio_t dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the given GPIO pin to HIGH
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @param[in] dev the GPIO pin to set
|
2014-02-03 19:31:04 +01:00
|
|
|
*/
|
2014-07-28 16:21:30 +02:00
|
|
|
void gpio_set(gpio_t dev);
|
2014-02-03 19:31:04 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the given GPIO pin to LOW
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @param[in] dev the GPIO pin to clear
|
2014-02-03 19:31:04 +01:00
|
|
|
*/
|
2014-07-28 16:21:30 +02:00
|
|
|
void gpio_clear(gpio_t dev);
|
2014-02-03 19:31:04 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Toggle the value of the given GPIO pin
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @param[in] dev the GPIO pin to toggle
|
2014-02-03 19:31:04 +01:00
|
|
|
*/
|
2014-07-28 16:21:30 +02:00
|
|
|
void gpio_toggle(gpio_t dev);
|
2014-02-03 19:31:04 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the given GPIO pin to the given value
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-04-03 17:44:49 +02:00
|
|
|
* @param[in] dev the GPIO pin to set
|
|
|
|
* @param[in] value value to set the pin to, 0 for LOW, HIGH otherwise
|
2014-02-03 19:31:04 +01:00
|
|
|
*/
|
2014-07-28 16:21:30 +02:00
|
|
|
void gpio_write(gpio_t dev, int value);
|
|
|
|
|
|
|
|
#endif /* GPIO_NUMOF */
|
2014-02-03 19:31:04 +01:00
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2014-02-03 19:31:04 +01:00
|
|
|
#endif /* __GPIO_H */
|
|
|
|
/** @} */
|