• Home
Name Date Size #Lines LOC

..--

BUILD.gnD12-May-2024866 2421

README.mdD12-May-20244.5 KiB159117

button_example.cD12-May-20242.1 KiB7335

README.md

1# BearPi-HM_Nano开发板基础外设开发——GPIO输入
2本示例将演示如何在BearPi-HM_Nano开发板上使用GPIO输入功能去读取按键状态。
3
4## GPIO API分析
5本案例主要使用了以下几个API完成GPIO输出功能。
6### IoTGpioInit()
7```c
8unsigned int IoTGpioInit(unsigned int id);
9```
10 **描述:**
11
12初始化GPIO外设。
13### IoTGpioSetFunc()
14```c
15unsigned int IoTGpioSetFunc(unsigned int id, unsigned char val);
16```
17**描述:**
18
19设置GPIO引脚复用功能。
20
21**参数:**
22
23|参数名|描述|
24|:--|:------|
25| id | 表示GPIO引脚号。  |
26| val | 表示GPIO复用功能。 |
27
28### IoTGpioSetDir()
29```c
30unsigned int IoTGpioSetDir(unsigned int id, IotGpioDir dir);
31```
32**描述:**
33
34设置GPIO输出方向。
35
36**参数:**
37
38|参数名|描述|
39|:--|:------|
40| id | 表示GPIO引脚号。  |
41| dir | 表示GPIO输出方向。  |
42
43
44### IoSetPull()
45```c
46unsigned int IoTGpioSetPull(unsigned int id, IotGpioPull val);
47```
48**描述:**
49
50设备GPIO的上下拉方式。
51
52**参数:**
53
54|参数名|描述|
55|:--|:------|
56| id | 表示GPIO引脚号。  |
57| val | 表示要设置的上拉或下拉。  |
58
59
60### IoTGpioRegisterIsrFunc()
61```c
62unsigned int IoTGpioRegisterIsrFunc(unsigned int id, IotGpioIntType intType, IotGpioIntPolarity intPolarity,
63                                    GpioIsrCallbackFunc func, char *arg);
64```
65**描述:**
66
67启用GPIO引脚的中断功能。这个函数可以用来为GPIO pin设置中断类型、中断极性和中断回调。
68
69**参数:**
70
71|参数名|描述|
72|:--|:------|
73| id | 表示GPIO引脚号。  |
74| intType| 表示中断类型。  |
75| intPolarity| 表示中断极性。 |
76| func| 表示中断回调函数.。  |
77| arg| 表示中断回调函数中使用的参数的指针。  |
78
79
80## 硬件设计
81本案例将使用板载的两个用户按键来验证GPIO的输入功能,在BearPi-HM_Nano开发板上用户按键的连接电路图如下图所示,按键F1的检测引脚与主控芯片的GPIO_11连接,按键F2的检测引脚与主控芯片的GPIO_12连接,所以需要编写软件去读取GPIO_11和GPIO_12的电平值,判断按键是否被按下。
82
83![按键电路](../../docs/figures/B2_basic_button/按键电路.png "按键电路")
84
85## 软件设计
86
87**主要代码分析**
88
89这部分代码主要分析按键触发中断的功能代码,这里以按键F1为例,按键F1的检测引脚与主控芯片的GPIO_11连接,首先通过调用IoTGpioSetFunc()和IoTGpioSetDir()将GPIO_11设置为普通GPIO的输入模式。从前面原理图可知,当按键按下时,GPIO_11会被下拉到地,所以这里要使用IoTGpioSetPull()将GPIO_11引脚设置为上拉,这样才能产生电平的跳变。最后通过IoTGpioRegisterIsrFunc()将中断类型设置为边沿触发,且为下降沿触发,当按键被按下时,GPIO_11会从高电平转为低电平,产生一个下降,这个时候就会触发中断并回调F1_Pressed函数。在F1_Pressed函数中实现点亮LED灯操作。
90```c
91/**
92* @brief Callback for F1 key
93*
94*/
95static void F1Pressed(char *arg)
96{
97    (void)arg;
98    IoTGpioSetOutputVal(LED_GPIO, 1);
99}
100
101/**
102* @brief Callback for F2 key
103*
104*/
105static void F2Pressed(char *arg)
106{
107    (void)arg;
108    IoTGpioSetOutputVal(LED_GPIO, 0);
109}
110
111/**
112 * @brief Main Entry of the Button Example
113 *
114 */
115static void ButtonExampleEntry(void)
116{
117    //init gpio of LED
118    IoTGpioInit(LED_GPIO);
119    IoTGpioSetDir(LED_GPIO, IOT_GPIO_DIR_OUT);
120
121    //init gpio of F1 key and set it as the falling edge to trigger interrupt
122    IoTGpioInit(BUTTON_F1_GPIO);
123    IoTGpioSetDir(BUTTON_F1_GPIO, IOT_GPIO_DIR_IN);
124    IoTGpioSetPull(BUTTON_F1_GPIO, IOT_GPIO_PULL_UP);
125    IoTGpioRegisterIsrFunc(BUTTON_F1_GPIO, IOT_INT_TYPE_EDGE, IOT_GPIO_EDGE_FALL_LEVEL_LOW, F1Pressed, NULL);
126
127    //init gpio of F2 key and set it as the falling edge to trigger interrupt
128    IoTGpioInit(BUTTON_F2_GPIO);
129    IoTGpioSetDir(BUTTON_F2_GPIO, IOT_GPIO_DIR_IN);
130    IoTGpioSetPull(BUTTON_F2_GPIO, IOT_GPIO_PULL_UP);
131    IoTGpioRegisterIsrFunc(BUTTON_F2_GPIO, IOT_INT_TYPE_EDGE, IOT_GPIO_EDGE_FALL_LEVEL_LOW, F2Pressed, NULL);
132}
133```
134
135## 编译调试
136
137### 修改 BUILD.gn 文件
138
139
140修改`device\bearpi\bearpi_hm_nano\app` 路径下 BUILD.gn 文件,指定 `button_example` 参与编译。
141
142```r
143#"B1_basic_led_blink:led_example",
144"B2_basic_button:button_example",
145#"B3_basic_pwm_led:pwm_example",
146#"B4_basic_adc:adc_example",
147#"B5_basic_i2c_nfc:i2c_example",
148#"B6_basic_uart:uart_example",
149```
150
151
152
153
154### 运行结果
155
156示例代码编译烧录代码后,按下开发板的RESET按键,开发板开始正常工作,按下F1按键LED会点亮,按下F2按键LED会熄灭。
157
158
159