Nano102_112 Series BSP  V3.03.002
The Board Support Package for Nano102_112 Series
gpio.h
Go to the documentation of this file.
1 /**************************************************************************/
12 #ifndef __GPIO_H__
13 #define __GPIO_H__
14 
15 #ifdef __cplusplus
16 extern "C"
17 {
18 #endif
19 
20 
32 #define GPIO_PIN_MAX 16
34 /*---------------------------------------------------------------------------------------------------------*/
35 /* PMD Constant Definitions */
36 /*---------------------------------------------------------------------------------------------------------*/
37 #define GPIO_PMD_INPUT 0x0UL
38 #define GPIO_PMD_OUTPUT 0x1UL
39 #define GPIO_PMD_OPEN_DRAIN 0x2UL
41 /*---------------------------------------------------------------------------------------------------------*/
42 /* GPIO Interrupt Type Constant Definitions */
43 /*---------------------------------------------------------------------------------------------------------*/
44 #define GPIO_INT_RISING 0x00010000UL
45 #define GPIO_INT_FALLING 0x00000001UL
46 #define GPIO_INT_BOTH_EDGE 0x00010001UL
47 #define GPIO_INT_HIGH 0x01010000UL
48 #define GPIO_INT_LOW 0x01000001UL
50 /*---------------------------------------------------------------------------------------------------------*/
51 /* IMD Constant Definitions */
52 /*---------------------------------------------------------------------------------------------------------*/
53 #define GPIO_IMD_EDGE 0UL
54 #define GPIO_IMD_LEVEL 1UL
56 /*---------------------------------------------------------------------------------------------------------*/
57 /* DBNCECON Constant Definitions */
58 /*---------------------------------------------------------------------------------------------------------*/
59 #define GPIO_ICLK_ON 0x00000020UL
60 #define GPIO_ICLK_OFF 0x00000000UL
62 #define GPIO_DBCLKSRC_IRC10K 0x00000010UL
63 #define GPIO_DBCLKSRC_HCLK 0x00000000UL
65 #define GPIO_DBCLKSEL_1 0x00000000UL
66 #define GPIO_DBCLKSEL_2 0x00000001UL
67 #define GPIO_DBCLKSEL_4 0x00000002UL
68 #define GPIO_DBCLKSEL_8 0x00000003UL
69 #define GPIO_DBCLKSEL_16 0x00000004UL
70 #define GPIO_DBCLKSEL_32 0x00000005UL
71 #define GPIO_DBCLKSEL_64 0x00000006UL
72 #define GPIO_DBCLKSEL_128 0x00000007UL
73 #define GPIO_DBCLKSEL_256 0x00000008UL
74 #define GPIO_DBCLKSEL_512 0x00000009UL
75 #define GPIO_DBCLKSEL_1024 0x0000000AUL
76 #define GPIO_DBCLKSEL_2048 0x0000000BUL
77 #define GPIO_DBCLKSEL_4096 0x0000000CUL
78 #define GPIO_DBCLKSEL_8192 0x0000000DUL
79 #define GPIO_DBCLKSEL_16384 0x0000000EUL
80 #define GPIO_DBCLKSEL_32768 0x0000000FUL
96 #define GPIO_PIN_ADDR(port, pin) (*((volatile uint32_t *)((GPIO_PIN_DATA_BASE+(0x40*(port))) + ((pin)<<2))))
97 #define PA0 GPIO_PIN_ADDR(0, 0)
98 #define PA1 GPIO_PIN_ADDR(0, 1)
99 #define PA2 GPIO_PIN_ADDR(0, 2)
100 #define PA3 GPIO_PIN_ADDR(0, 3)
101 #define PA4 GPIO_PIN_ADDR(0, 4)
102 #define PA5 GPIO_PIN_ADDR(0, 5)
103 #define PA6 GPIO_PIN_ADDR(0, 6)
104 #define PA7 GPIO_PIN_ADDR(0, 7)
105 #define PA8 GPIO_PIN_ADDR(0, 8)
106 #define PA9 GPIO_PIN_ADDR(0, 9)
107 #define PA10 GPIO_PIN_ADDR(0, 10)
108 #define PA11 GPIO_PIN_ADDR(0, 11)
109 #define PA12 GPIO_PIN_ADDR(0, 12)
110 #define PA13 GPIO_PIN_ADDR(0, 13)
111 #define PA14 GPIO_PIN_ADDR(0, 14)
112 #define PA15 GPIO_PIN_ADDR(0, 15)
114 #define PB0 GPIO_PIN_ADDR(1, 0)
115 #define PB1 GPIO_PIN_ADDR(1, 1)
116 #define PB2 GPIO_PIN_ADDR(1, 2)
117 #define PB3 GPIO_PIN_ADDR(1, 3)
118 #define PB4 GPIO_PIN_ADDR(1, 4)
119 #define PB5 GPIO_PIN_ADDR(1, 5)
120 #define PB6 GPIO_PIN_ADDR(1, 6)
121 #define PB7 GPIO_PIN_ADDR(1, 7)
122 #define PB8 GPIO_PIN_ADDR(1, 8)
123 #define PB9 GPIO_PIN_ADDR(1, 9)
124 #define PB10 GPIO_PIN_ADDR(1, 10)
125 #define PB11 GPIO_PIN_ADDR(1, 11)
126 #define PB12 GPIO_PIN_ADDR(1, 12)
127 #define PB13 GPIO_PIN_ADDR(1, 13)
128 #define PB14 GPIO_PIN_ADDR(1, 14)
129 #define PB15 GPIO_PIN_ADDR(1, 15)
131 #define PC0 GPIO_PIN_ADDR(2, 0)
132 #define PC1 GPIO_PIN_ADDR(2, 1)
133 #define PC2 GPIO_PIN_ADDR(2, 2)
134 #define PC3 GPIO_PIN_ADDR(2, 3)
135 #define PC4 GPIO_PIN_ADDR(2, 4)
136 #define PC5 GPIO_PIN_ADDR(2, 5)
137 #define PC6 GPIO_PIN_ADDR(2, 6)
138 #define PC7 GPIO_PIN_ADDR(2, 7)
139 #define PC8 GPIO_PIN_ADDR(2, 8)
140 #define PC9 GPIO_PIN_ADDR(2, 9)
141 #define PC10 GPIO_PIN_ADDR(2, 10)
142 #define PC11 GPIO_PIN_ADDR(2, 11)
143 #define PC12 GPIO_PIN_ADDR(2, 12)
144 #define PC13 GPIO_PIN_ADDR(2, 13)
145 #define PC14 GPIO_PIN_ADDR(2, 14)
146 #define PC15 GPIO_PIN_ADDR(2, 15)
148 #define PD0 GPIO_PIN_ADDR(3, 0)
149 #define PD1 GPIO_PIN_ADDR(3, 1)
150 #define PD2 GPIO_PIN_ADDR(3, 2)
151 #define PD3 GPIO_PIN_ADDR(3, 3)
152 #define PD4 GPIO_PIN_ADDR(3, 4)
153 #define PD5 GPIO_PIN_ADDR(3, 5)
154 #define PD6 GPIO_PIN_ADDR(3, 6)
155 #define PD7 GPIO_PIN_ADDR(3, 7)
156 #define PD8 GPIO_PIN_ADDR(3, 8)
157 #define PD9 GPIO_PIN_ADDR(3, 9)
158 #define PD10 GPIO_PIN_ADDR(3, 10)
159 #define PD11 GPIO_PIN_ADDR(3, 11)
160 #define PD12 GPIO_PIN_ADDR(3, 12)
161 #define PD13 GPIO_PIN_ADDR(3, 13)
162 #define PD14 GPIO_PIN_ADDR(3, 14)
163 #define PD15 GPIO_PIN_ADDR(3, 15)
165 #define PE0 GPIO_PIN_ADDR(4, 0)
166 #define PE1 GPIO_PIN_ADDR(4, 1)
167 #define PE2 GPIO_PIN_ADDR(4, 2)
168 #define PE3 GPIO_PIN_ADDR(4, 3)
169 #define PE4 GPIO_PIN_ADDR(4, 4)
170 #define PE5 GPIO_PIN_ADDR(4, 5)
171 #define PE6 GPIO_PIN_ADDR(4, 6)
172 #define PE7 GPIO_PIN_ADDR(4, 7)
173 #define PE8 GPIO_PIN_ADDR(4, 8)
174 #define PE9 GPIO_PIN_ADDR(4, 9)
176 #define PF0 GPIO_PIN_ADDR(5, 0)
177 #define PF1 GPIO_PIN_ADDR(5, 1)
178 #define PF2 GPIO_PIN_ADDR(5, 2)
179 #define PF3 GPIO_PIN_ADDR(5, 3)
180 #define PF4 GPIO_PIN_ADDR(5, 4)
181 #define PF5 GPIO_PIN_ADDR(5, 5)
183  /* end of group NANO1X2_GPIO_EXPORTED_CONSTANTS */
184 
199 #define GPIO_CLR_INT_FLAG(gpio, u32PinMask) ((gpio)->ISRC = u32PinMask)
200 
211 #define GPIO_DISABLE_DEBOUNCE(gpio, u32PinMask) ((gpio)->DBEN &= ~u32PinMask)
212 
223 #define GPIO_ENABLE_DEBOUNCE(gpio, u32PinMask) ((gpio)->DBEN |= u32PinMask)
224 
235 #define GPIO_DISABLE_DIGITAL_PATH(gpio, u32PinMask) ((gpio)->OFFD |= (u32PinMask << 16))
236 
247 #define GPIO_ENABLE_DIGITAL_PATH(gpio, u32PinMask) ((gpio)->OFFD &= ~(u32PinMask << 16))
248 
259 #define GPIO_DISABLE_DOUT_MASK(gpio, u32PinMask) ((gpio)->DMASK &= ~u32PinMask)
260 
271 #define GPIO_ENABLE_DOUT_MASK(gpio, u32PinMask) ((gpio)->DMASK |= u32PinMask)
272 
284 #define GPIO_GET_INT_FLAG(gpio, u32PinMask) ((gpio)->ISRC & u32PinMask)
285 
304 #define GPIO_SET_DEBOUNCE_TIME(u32ClkSrc, u32ClkSel) (GPIO->DBNCECON = (GP_DBNCECON_DBCLK_ON_Msk | u32ClkSrc | u32ClkSel))
305 
315 #define GPIO_GET_IN_DATA(gpio) ((gpio)->PIN)
316 
327 #define GPIO_SET_OUT_DATA(gpio, u32Data) ((gpio)->DOUT = (u32Data))
328 
339 #define GPIO_DISABLE_PULL_UP(gpio, u32PinMask) ((gpio)->PUEN &= ~u32PinMask)
340 
351 #define GPIO_ENABLE_PULL_UP(gpio, u32PinMask) ((gpio)->PUEN |= u32PinMask)
352 
362 #define GPIO_TOGGLE(u32Pin) ((u32Pin) ^= 1)
363 
376 #define GPIO_EnableEINT0 GPIO_EnableInt
377 
378 
389 #define GPIO_DisableEINT0 GPIO_DisableInt
390 
391 
404 #define GPIO_EnableEINT1 GPIO_EnableInt
405 
406 
417 #define GPIO_DisableEINT1 GPIO_DisableInt
418 
419 
420 void GPIO_SetMode(GPIO_T *gpio, uint32_t u32PinMask, uint32_t u32Mode);
421 void GPIO_EnableInt(GPIO_T *gpio, uint32_t u32Pin, uint32_t u32IntAttribs);
422 void GPIO_DisableInt(GPIO_T *gpio, uint32_t u32Pin);
423 
424 
425  /* end of group NANO1X2_GPIO_EXPORTED_FUNCTIONS */
427  /* end of group NANO1X2_GPIO_Driver */
429  /* end of group NANO1X2_Device_Driver */
431 
432 #ifdef __cplusplus
433 }
434 #endif
435 
436 #endif //__GPIO_H__
437 
438 /*** (C) COPYRIGHT 2014 Nuvoton Technology Corp. ***/
void GPIO_SetMode(GPIO_T *gpio, uint32_t u32PinMask, uint32_t u32Mode)
Set GPIO operation mode.
Definition: gpio.c:40
void GPIO_DisableInt(GPIO_T *gpio, uint32_t u32Pin)
Disable GPIO interrupt.
Definition: gpio.c:82
void GPIO_EnableInt(GPIO_T *gpio, uint32_t u32Pin, uint32_t u32IntAttribs)
Enable GPIO interrupt.
Definition: gpio.c:65