VSF Documented
gpio.h
Go to the documentation of this file.
1/*****************************************************************************
2 * Copyright(C)2009-2022 by VSF Team *
3 * *
4 * Licensed under the Apache License, Version 2.0 (the "License"); *
5 * you may not use this file except in compliance with the License. *
6 * You may obtain a copy of the License at *
7 * *
8 * http://www.apache.org/licenses/LICENSE-2.0 *
9 * *
10 * Unless required by applicable law or agreed to in writing, software *
11 * distributed under the License is distributed on an "AS IS" BASIS, *
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
13 * See the License for the specific language governing permissions and *
14 * limitations under the License. *
15 * *
16 ****************************************************************************/
17
18#ifndef __HAL_DRIVER_ARTERY_AT32F402_405_GPIO_H__
19#define __HAL_DRIVER_ARTERY_AT32F402_405_GPIO_H__
20
21/*============================ INCLUDES ======================================*/
22
23#include "hal/vsf_hal_cfg.h"
24
25#if VSF_HAL_USE_GPIO == ENABLED
26
27// HW/IPCore
32// HW/IPCore end
33
34/*\note Refer to template/README.md for usage cases.
35 * For peripheral drivers, blackbox mode is recommended but not required, reimplementation part MUST be open.
36 * For IPCore drivers, class structure, MULTI_CLASS configuration, reimplementation and class APIs should be open to user.
37 * For emulated drivers, **** No reimplementation ****.
38 *
39 * Usually, there is no IPCore driver for GPIO.
40 */
41
42/*\note Includes CAN ONLY be put here. */
43
44#ifdef __cplusplus
45extern "C" {
46#endif
47
48/*============================ MACROS ========================================*/
49
50// HW
51/*\note hw GPIO driver can reimplement following types:
52 * To enable reimplementation, please enable macro below:
53 * VSF_GPIO_CFG_REIMPLEMENT_TYPE_MODE for vsf_gpio_mode_t
54 * VSF_GPIO_CFG_REIMPLEMENT_TYPE_CFG for vsf_gpio_cfg_t
55 * VSF_GPIO_CFG_REIMPLEMENT_TYPE_CAPABILITY for vsf_gpio_capability_t
56 * Reimplementation is used for optimization hw/IPCore drivers, reimplement the bit mask according to hw registers.
57 * *** DO NOT reimplement these in emulated drivers. ***
58 */
59
60#define VSF_GPIO_CFG_REIMPLEMENT_TYPE_MODE ENABLED
61// HW end
62
63// AF_MODE, internal usage only
64#define __VSF_HW_AF_MODE_OUTPUT_PP 1
65#define __VSF_HW_AF_MODE_OUTPUT_PP_PU 2
66#define __VSF_HW_AF_MODE_OUTPUT_PP_PD 3
67#define __VSF_HW_AF_MODE_OUTPUT_OD 4
68#define __VSF_HW_AF_MODE_OUTPUT_OD_PU 5
69#define __VSF_HW_AF_MODE_OUTPUT_OD_PD 6
70#define __VSF_HW_AF_MODE_INPUT 7
71#define __VSF_HW_AF_MODE_INPUT_PU 8
72#define __VSF_HW_AF_MODE_INPUT_PD 9
73
74/*============================ MACROFIED FUNCTIONS ===========================*/
75/*============================ TYPES =========================================*/
76
77// HW/IPCore, not for emulated drivers
78#if VSF_GPIO_CFG_REIMPLEMENT_TYPE_MODE == ENABLED
79typedef enum vsf_gpio_mode_t {
80 // GPIO_CFGR.IOMC: bit0..bit1
81 // GPIO_OMODE.OM: bit2
82 VSF_GPIO_INPUT = (0 << 0),
83 VSF_GPIO_ANALOG = (3 << 0),
84 __VSF_GPIO_AF = (2 << 0),
85 VSF_GPIO_OUTPUT_PUSH_PULL = (1 << 0) | (0 << 2),
86 VSF_GPIO_OUTPUT_OPEN_DRAIN = (1 << 0) | (1 << 2),
87 __VSF_GPIO_EXTI = (1 << 8),
89
92 VSF_GPIO_AF_INPUT = __VSF_GPIO_AF /*| (x[0|1] << 2)*/,
93#define VSF_GPIO_AF_OUTPUT_PUSH_PULL VSF_GPIO_AF_OUTPUT_PUSH_PULL
94#define VSF_GPIO_AF_OUTPUT_OPEN_DRAIN VSF_GPIO_AF_OUTPUT_OPEN_DRAIN
95#define VSF_GPIO_AF_INPUT VSF_GPIO_AF_INPUT
96
97 // GPIO_PULL.PULL: bit3..bit4
99 VSF_GPIO_PULL_UP = (1 << 3),
101
102 // GPIO_ODRVR.ODRV: bit5..bit6
103 // GPIO_HDRV.HDRV: bit7
104 VSF_GPIO_DRIVE_STRENGTH_LOW = (0 << 5) | (0 << 7),
105 VSF_GPIO_DRIVE_STRENGTH_MEDIUM = (0 << 5) | (1 << 7),
106 VSF_GPIO_DRIVE_STRENGTH_HIGH = (1 << 5) | (1 << 7),
107 VSF_GPIO_DRIVE_STRENGTH_MASK = (3 << 5) | (1 << 7),
112
113 // todo: exti support
121#endif
122
123/*============================ INCLUDES ======================================*/
124/*============================ PROTOTYPES ====================================*/
125
126#ifdef __cplusplus
127}
128#endif
129
130#endif // VSF_HAL_USE_GPIO
131#endif // __HAL_DRIVER_ARTERY_AT32F402_405_GPIO_H__
132/* EOF */
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_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_DRIVE_STRENGTH_MEDIUM
Definition gpio.h:109
#define VSF_GPIO_AF_INPUT
Definition gpio.h:95
#define VSF_GPIO_DRIVE_STRENGTH_HIGH
Definition gpio.h:110
#define VSF_GPIO_DRIVE_STRENGTH_MASK
Definition gpio.h:111
#define VSF_GPIO_AF_OUTPUT_PUSH_PULL
Definition gpio.h:93
#define VSF_GPIO_AF_OUTPUT_OPEN_DRAIN
Definition gpio.h:94
#define VSF_GPIO_DRIVE_STRENGTH_LOW
Definition gpio.h:108
@ __VSF_GPIO_EXTI
Definition gpio.h:87
@ __VSF_GPIO_AF
Definition gpio.h:84
Generated from commit: vsfteam/vsf@733f33a