/* * Copyright (C) 2018 Gunar Schorcht * * 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 cpu_esp32 * @{ * * @file * @brief Architecture specific GPIO functions for ESP32 * * @author Gunar Schorcht * @} */ #ifndef GPIO_ARCH_H #define GPIO_ARCH_H #include "gpio_arch_common.h" #include "periph/gpio.h" #include "soc/io_mux_reg.h" #include "soc/gpio_sig_map.h" #ifndef DOXYGEN #ifdef __cplusplus extern "C" { #endif /** * @brief Table of GPIO to IOMUX register mappings */ extern const uint32_t _gpio_to_iomux_reg[]; #define GPIO_PIN_MUX_REG _gpio_to_iomux_reg /** * @brief Disable the pullup of the pin */ void gpio_pullup_dis (gpio_t pin); /** * @brief Returns the RTCIO pin number or -1 if the pin is not an RTCIO pin */ int8_t gpio_is_rtcio (gpio_t pin); /** * @brief Set the direction of a pin (initializes the pin calling gpio_init) * @param pin GPIO pin * @param mode active in sleep mode if true * @return 0 on success * -1 on invalid argument */ int gpio_set_direction(gpio_t pin, gpio_mode_t mode); /** * @brief extern declaration of ROM functions to avoid compilation problems */ void gpio_matrix_in (uint32_t gpio, uint32_t signal_idx, bool inv); void gpio_matrix_out(uint32_t gpio, uint32_t signal_idx, bool out_inv, bool oen_inv); #ifdef __cplusplus } #endif #endif /* DOXYGEN */ #endif /* GPIO_ARCH_H */