bossay_release_out/app/B6_basic_uart/README.md

131 lines
3.4 KiB
Markdown
Raw Permalink Normal View History

2025-09-24 11:16:14 +08:00
# BearPi-HM_Nano开发板基础外设开发——UART数据读写
本示例将演示如何在BearPi-HM_Nano开发板上使用UART进行数据的收发。
## UART API分析
本示例主要使用了以下API完成UART数据读写。
### IoTUartInit()
```c
unsigned int IoTUartInit(unsigned int id, const IotUartAttribute *param);
```
**描述:**
配置一个UART设备。
**参数:**
|参数名|描述|
|:--|:------|
| id | UART端口号。 |
| param |表示基本UART属性。|
### IoTUartWrite()
```c
int IoTUartWrite(unsigned int id, const unsigned char *data, unsigned int dataLen);
```
**描述:**
将数据写入UART设备。
**参数:**
|参数名|描述|
|:--|:------|
| id | UART端口号。 |
| data |表示指向要写入数据的起始地址的指针。|
| dataLen |表示读取数据的长度。|
### IoTUartRead()
```c
int IoTUartRead(unsigned int id, unsigned char *data, unsigned int dataLen);
```
**描述:**
从UART设备读取数据。
**参数:**
|参数名|描述|
|:--|:------|
| id | UART端口号。 |
| data |表示指向要读取数据的起始地址的指针。|
| dataLen |表示读取数据的长度。|
## 硬件设计
本案例将用 BearPi-HM_Nano 开发板 E53 接口的 UART 作为测试,如原理图所示第 18 和 19 脚分别为 TXD 和 RXD ,连接了主控芯片的 GPIO_6 和 GPIO_5 ,所以在编写软件的时候需要将 GPIO_6 和 GPIO_5 分别复用为 TXD 和 RXD 。
![](../../docs/figures/B6_basic_uart/E53接口电路.png "E53接口电路")
## 软件设计
**主要代码分析**
这部分代码为UART初始化的代码首先要在 `uart_attr` 结构体这配置波特率、数据位、停止位、奇偶检验位,然后通过 `IoTUartInit()` 函数对串口1进行配置。
```c
IotUartAttribute uart_attr = {
//baud_rate: 9600
.baudRate = 9600,
//data_bits: 8bits
.dataBits = 8,
.stopBits = 1,
.parity = 0,
};
//Initialize uart driver
ret = IoTUartInit(WIFI_IOT_UART_IDX_1, &uart_attr);
if (ret != IOT_SUCCESS) {
printf("Failed to init uart! Err code = %d\n", ret);
return;
}
```
这部分的代码主要实现通过 `IoTUartWrite()` 函数在串口1发送一串数据然后通过 `IoTUartRead()` 函数将数据都回来,并通过 `debug` 串口打印出来。
```c
//send data through uart1
IoTUartWrite(WIFI_IOT_UART_IDX_1, (unsigned char *)data, strlen(data));
//receive data through uart1
IoTUartRead(WIFI_IOT_UART_IDX_1, uart_buff_ptr, UART_BUFF_SIZE);
printf("Uart1 read data:%s\n", uart_buff_ptr);
```
## 编译调试
### 修改 BUILD.gn 文件
修改 `device\bearpi\bearpi_hm_nano\app` 路径下 BUILD.gn 文件,指定 `uart_example` 参与编译。
```r
#"B1_basic_led_blink:led_example",
#"B2_basic_button:button_example",
#"B3_basic_pwm_led:pwm_example",
#"B4_basic_adc:adc_example",
#"B5_basic_i2c_nfc:i2c_example",
"B6_basic_uart:uart_example",
```
### 运行结果
示例代码编译烧录代码后按下开发板的RESET按键 `将开发板上E53接口的UART_TX和UART_RX用杜邦线短接` 通过串口助手查看日志串口1实现自发自收。
```c
=======================================
*************UART_example**************
=======================================
Uart1 read data:Hello, BearPi!
=======================================
*************UART_example**************
=======================================
Uart1 read data:Hello, BearPi!
```