18#ifndef __HAL_DRIVER_NATIONS_N32H76X_N32H78X_GPIO_H__
19#define __HAL_DRIVER_NATIONS_N32H76X_N32H78X_GPIO_H__
25#if VSF_HAL_USE_GPIO == ENABLED
34#include "../../__device.h"
62#define VSF_GPIO_CFG_REIMPLEMENT_TYPE_MODE ENABLED
63#define VSF_GPIO_CFG_REIMPLEMENT_TYPE_CFG DISABLED
64#define VSF_GPIO_CFG_REIMPLEMENT_TYPE_CAPABILITY DISABLED
71#if (VSF_GPIO_CFG_REIMPLEMENT_TYPE_CFG == ENABLED) || (VSF_GPIO_CFG_REIMPLEMENT_TYPE_CAPABILITY == ENABLED)
73#define vsf_gpio_pin_mask_t vsf_gpio_pin_mask_t
81#if VSF_GPIO_CFG_REIMPLEMENT_TYPE_MODE == ENABLED
104#define VSF_GPIO_SPEED_LOW VSF_GPIO_SPEED_LOW
105#define VSF_GPIO_SPEED_HIGH VSF_GPIO_SPEED_HIGH
106#define VSF_GPIO_SPEED_MASK VSF_GPIO_SPEED_MASK
132#if VSF_GPIO_CFG_REIMPLEMENT_TYPE_CFG == ENABLED
146#if VSF_GPIO_CFG_REIMPLEMENT_TYPE_CAPABILITY == ENABLED
148#if VSF_GPIO_CFG_INHERIT_HAL_CAPABILITY == ENABLED
vsf_gpio_mode_t
Definition gpio.h:31
@ VSF_GPIO_NO_PULL_UP_DOWN
Definition gpio.h:39
@ VSF_GPIO_EXTI_MODE_HIGH_LEVEL
Definition gpio.h:50
@ VSF_GPIO_OUTPUT_PUSH_PULL
Definition gpio.h:43
@ VSF_GPIO_EXTI
Definition gpio.h:45
@ VSF_GPIO_EXTI_MODE_LOW_LEVEL
Definition gpio.h:49
@ VSF_GPIO_EXTI_MODE_NONE
Definition gpio.h:48
@ VSF_GPIO_EXTI_MODE_RISING
Definition gpio.h:51
@ VSF_GPIO_EXTI_MODE_RISING_FALLING
Definition gpio.h:53
@ VSF_GPIO_PULL_UP
Definition gpio.h:37
@ VSF_GPIO_AF
Definition gpio.h:46
@ VSF_GPIO_INPUT
Definition gpio.h:41
@ VSF_GPIO_ANALOG
Definition gpio.h:44
@ VSF_GPIO_EXTI_MODE_FALLING
Definition gpio.h:52
@ VSF_GPIO_OUTPUT_OPEN_DRAIN
Definition gpio.h:42
@ VSF_GPIO_PULL_DOWN
Definition gpio.h:38
#define VSF_GPIO_SPEED_HIGH
Definition gpio.h:84
#define VSF_GPIO_SPEED_MASK
Definition gpio.h:86
@ __VSF_HW_GPIO_MODE_ALL_BITS
Definition gpio.h:98
@ VSF_GPIO_AF_PUSH_PULL
enable output push-pull mode
Definition gpio.h:67
@ VSF_GPIO_AF_OPEN_DRAIN
enable output open-drain mode
Definition gpio.h:68
#define VSF_GPIO_SPEED_LOW
Definition gpio.h:82
#define VSF_GPIO_DRIVE_STRENGTH_MEDIUM
Definition gpio.h:115
void vsf_gpio_exti_isr_handler_t(void *target_ptr, vsf_gpio_t *gpio_ptr, vsf_gpio_pin_mask_t pin_mask)
Definition gpio.h:134
#define VSF_GPIO_HIGH_DRIVE_STRENGTH_MASK
Definition gpio.h:118
#define VSF_GPIO_DRIVE_STRENGTH_HIGH
Definition gpio.h:116
#define VSF_GPIO_DRIVE_STRENGTH_VERY_HIGH
Definition gpio.h:117
struct vsf_gpio_capability_t vsf_gpio_capability_t
struct vsf_gpio_exti_irq_cfg_t vsf_gpio_exti_irq_cfg_t
#define vsf_gpio_pin_mask_t
Definition gpio.h:73
struct vsf_gpio_cfg_t vsf_gpio_cfg_t
#define VSF_GPIO_DRIVE_STRENGTH_LOW
Definition gpio.h:114
@ VSF_GPIO_HIGH_DRIVE_STRENGTH_LOW
Definition gpio.h:109
@ VSF_GPIO_HIGH_DRIVE_STRENGTH_HIGH
Definition gpio.h:111
@ VSF_GPIO_HIGH_DRIVE_STRENGTH_MEDIUM
Definition gpio.h:110
@ VSF_GPIO_HIGH_DRIVE_STRENGTH_VERY_HIGH
Definition gpio.h:112
vsf_arch_prio_t
Definition cortex_a_generic.h:88
unsigned short uint16_t
Definition stdint.h:7
unsigned uint32_t
Definition stdint.h:9
unsigned char uint8_t
Definition stdint.h:5
Definition vsf_template_gpio.h:628
uint8_t support_output_and_clear
Support for atomic output and clear operations. Prevents signal glitches when switching from input to...
Definition vsf_template_gpio.h:663
uint8_t pin_count
Total number of pins in hardware. Includes all pins, even those that cannot be configured as GPIO....
Definition vsf_template_gpio.h:685
uint8_t support_interrupt
Support for external interrupt functionality. When set, the GPIO pins can be configured to generate i...
Definition vsf_template_gpio.h:673
vsf_gpio_pin_mask_t pin_mask
Available pin mask indicating which pins can be used as GPIO. Common bit patterns include:
Definition vsf_template_gpio.h:703
inherit(vsf_peripheral_capability_t) uint8_t is_async uint8_t support_output_and_set
Flag indicating if GPIO operations are asynchronous. When set, operations are only guaranteed to be s...
Definition vsf_template_gpio.h:630
gpio channel configuration
Definition vsf_template_gpio.h:600
uint16_t alternate_function
alternate function is only valid in GPIO_AF mode
Definition vsf_template_gpio.h:603
vsf_gpio_mode_t mode
Definition vsf_template_gpio.h:601
Definition vsf_template_gpio.h:593
vsf_gpio_exti_isr_handler_t * handler_fn
Definition vsf_template_gpio.h:594
vsf_arch_prio_t prio
Definition vsf_template_gpio.h:596
void * target_ptr
Definition vsf_template_gpio.h:595
Definition vsf_template_gpio.h:725
Definition vsf_template_hal_driver.h:203
void vsf_gpio_exti_isr_handler_t(void *target_ptr, vsf_gpio_t *gpio_ptr, vsf_gpio_pin_mask_t pin_mask)
Definition gpio.h:105
uint32_t vsf_gpio_pin_mask_t
Definition vsf_template_gpio.h:304