/* * Copyright (C) 2014 Freie Universität Berlin * * 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. */ /** * @ingroup driver_periph * @brief Low-level GPIO peripheral driver * @{ * * @file periph/gpio.h * @brief Low-level GPIO peripheral driver interface definitions * * @author Hauke Petersen */ #ifndef __GPIO_H #define __GPIO_H #include "periph_conf.h" /* guard file in case no GPIO devices are defined */ #if GPIO_NUMOF /** * @brief Definition of available GPIO devices. Each device is managing exactly one pin. */ typedef enum { #ifdef GPIO_0_EN GPIO_0 = 0, /**< GPIO device 0 */ #endif #ifdef GPIO_1_EN GPIO_1, /**< GPIO device 1 */ #endif #ifdef GPIO_2_EN GPIO_2, /**< GPIO device 2 */ #endif #ifdef GPIO_3_EN GPIO_3, /**< GPIO device 3 */ #endif #ifdef GPIO_4_EN GPIO_4, /**< GPIO device 4 */ #endif #ifdef GPIO_5_EN GPIO_5, /**< GPIO device 5 */ #endif #ifdef GPIO_6_EN GPIO_6, /**< GPIO device 6 */ #endif #ifdef GPIO_7_EN GPIO_7, /**< GPIO device 7 */ #endif #ifdef GPIO_8_EN GPIO_8, /**< GPIO device 8 */ #endif #ifdef GPIO_9_EN GPIO_9, /**< GPIO device 9 */ #endif #ifdef GPIO_10_EN GPIO_10, /**< GPIO device 10 */ #endif #ifdef GPIO_11_EN GPIO_11, /**< GPIO device 11 */ #endif #ifdef GPIO_12_EN GPIO_12, /**< GPIO device 12 */ #endif #ifdef GPIO_13_EN GPIO_13, /**< GPIO device 13 */ #endif #ifdef GPIO_14_EN GPIO_14, /**< GPIO device 14 */ #endif #ifdef GPIO_15_EN GPIO_15, /**< GPIO device 15 */ #endif } gpio_t; /** * @brief Definition of pull-up/pull-down modes */ typedef enum { 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 */ } gpio_pp_t; /** * @brief Definition of possible active flanks for external interrupt mode */ typedef enum { GPIO_FALLING = 0, /**< emit interrupt on falling flank */ GPIO_RISING = 1, /**< emit interrupt on rising flank */ GPIO_BOTH = 2 /**< emit interrupt on both flanks */ } gpio_flank_t; /** * @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); /** * @brief Initialize GPIO pin as output pin * * @param[in] dev the GPIO pin to set as output * @param[in] pullup define if pull resistors should be used * * @return 0 on success * @return -1 on pull-up mode unavailable */ int gpio_init_out(gpio_t dev, gpio_pp_t pullup); /** * @brief Initialize a GPIO pin in input mode * * @param[in] dev the GPIO pin to use as input * @param[in] pullup define if pull resistors should be used * * @return 0 on success * @return -1 on pull-up mode unavailable */ int gpio_init_in(gpio_t dev, gpio_pp_t pullup); /** * @brief Initialize a GPIO pin for external interrupt usage * * The registered callback function will be called in interrupt context every time the defined flank(s) * are detected. * * The interrupt is activated automatically after the initialization. * * @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 * @param[in] arg optional argument passed to the callback * * @return 0 on success * @return -1 on pull-up mode unavailable * @return -2 on active flank unavailable */ int gpio_init_int(gpio_t dev, gpio_pp_t pullup, gpio_flank_t flank, gpio_cb_t cb, void *arg); /** * @brief Enable the GPIO pin's interrupt if configured as external interrupt source. * * @param[in] dev the GPIO pin to enable the interrupt for */ void gpio_irq_enable(gpio_t dev); /** * @brief Disable the GPIO pin's interrupt if configured as external interrupt source. * * @param[in] dev the GPIO pin to disable the interrupt for */ void gpio_irq_disable(gpio_t dev); /** * @brief Get the current value of the given GPIO pin * * @param[in] dev the GPIO pin to read * @return the current value, 0 for LOW, != 0 for HIGH * * @return 0 when pin is LOW * @return greater 0 for HIGH */ int gpio_read(gpio_t dev); /** * @brief Set the given GPIO pin to HIGH * * @param[in] dev the GPIO pin to set */ void gpio_set(gpio_t dev); /** * @brief Set the given GPIO pin to LOW * * @param[in] dev the GPIO pin to clear */ void gpio_clear(gpio_t dev); /** * @brief Toggle the value of the given GPIO pin * * @param[in] dev the GPIO pin to toggle */ void gpio_toggle(gpio_t dev); /** * @brief Set the given GPIO pin to the given value * * @param[in] dev the GPIO pin to set * @param[in] value value to set the pin to, 0 for LOW, HIGH otherwise */ void gpio_write(gpio_t dev, int value); #endif /* GPIO_NUMOF */ #endif /* __GPIO_H */ /** @} */