/* * Copyright (C) 2015-2020 Alibaba Group Holding Limited */ #ifndef __HAL_GPIO_H__ #define __HAL_GPIO_H__ #ifdef __cplusplus extern "C" { #endif #include "plat_types.h" #include "hal_iomux.h" enum HAL_GPIO_DIR_T { HAL_GPIO_DIR_IN = 0, HAL_GPIO_DIR_OUT = 1, }; enum HAL_GPIO_IRQ_TYPE_T { HAL_GPIO_IRQ_TYPE_LEVEL_SENSITIVE = 0, HAL_GPIO_IRQ_TYPE_EDGE_SENSITIVE, }; enum HAL_GPIO_IRQ_POLARITY_T { HAL_GPIO_IRQ_POLARITY_LOW_FALLING = 0, HAL_GPIO_IRQ_POLARITY_HIGH_RISING, }; typedef void (* HAL_GPIO_PIN_IRQ_HANDLER)(enum HAL_GPIO_PIN_T pin); struct HAL_GPIO_IRQ_CFG_T { uint8_t irq_enable:1; uint8_t irq_debounce:1; enum HAL_GPIO_IRQ_TYPE_T irq_type; enum HAL_GPIO_IRQ_POLARITY_T irq_polarity; HAL_GPIO_PIN_IRQ_HANDLER irq_handler; }; enum HAL_GPIO_DIR_T hal_gpio_pin_get_dir(enum HAL_GPIO_PIN_T pin); void hal_gpio_pin_set_dir(enum HAL_GPIO_PIN_T pin, enum HAL_GPIO_DIR_T dir, uint8_t val_for_out); void hal_gpio_pin_set(enum HAL_GPIO_PIN_T pin); void hal_gpio_pin_clr(enum HAL_GPIO_PIN_T pin); uint8_t hal_gpio_pin_get_val(enum HAL_GPIO_PIN_T pin); uint8_t hal_gpio_setup_irq(enum HAL_GPIO_PIN_T pin, const struct HAL_GPIO_IRQ_CFG_T *cfg); #ifdef __cplusplus } #endif #endif