[RISC-V MCU 应用开发] 第六十二章、CH32V103应用教程——USART-硬件流控制

[复制链接]
 楼主| RISCVLAR 发表于 2021-1-26 15:17 | 显示全部楼层 |阅读模式
本帖最后由 RISCVLAR 于 2021-1-28 11:39 编辑

CH32V103应用教程——USART-硬件流控制

本章教程主要通过UART1演示硬件流控制数据收发。将程序分别下载到两个开发板,同时上电进行数据传输。

1、USART简介及相关函数介绍
在硬件流控制模式中,还需用到以下两个引脚:
● CTS: 清除发送,若是高电平,在当前数据传输结束时阻断下一次的数据发送。
● RTS: 发送请求,若是低电平,表明USART准备好接收数据。
通过利用CTS输入和RTS输出可以控制2个设备间的串行数据流。下图表明在这个模式里如何连接2个设备。
图片1.png
通过将UASRTx_CTLR3中的RTSE和CTSE置位,可以分别独立地使能RTS和CTS流控制。

1、RTS流控制
如果RTS流控制被使能(RTSE=1),只要USART接收器准备好接收新的数据, nRTS就变成有效(接低电平)。当接收寄存器内有数据到达时,nRTS被释放,由此表明希望在当前帧结束时停止数据传输。下图是一个启用RTS流控制的通信的例子。
图片2.png

2、CTS流控制
如果CTS流控制被使能(CTSE=1),发送器在发送下一帧前检查nCTS输入。如果nCTS有效(被拉成低电平),则下一个数据被发送(假设那个数据是准备发送的,也就是TXE=0),否则下一帧数据不被发出去。若nCTS在传输期间被变成无效,当前的传输完成后停止发送。
当CTSE=1时,只要nCTS输入一变换状态,硬件就自动设置CTSIF状态位。它表明接收器是否准备好进行通信。如果设置了USART_CT3寄存器的CTSIE位,则产生中断。下图是一个启用CTS流控制通信的例子。
图片3.png

关于CH32V103 USART具体信息,可参考CH32V103应用手册。USART标准库函数在第三章节已介绍,在此不再赘述。

2、硬件设计
本章教程主要通过使用两块开发板UART1演示硬件流控制数据收发,USART1_Tx(PA9)、USART1_Rx(PA10)、USART1_CTS(PA11)、USART1_RTS(PA12),将两块开发板对应引脚连接即可,连接方式如下:
硬件连线:PA9 —— PA10
      PA10 —— PA9
      PA11 —— PA12
      PA12 —— PA11
但此处为保证两块开发板之间正常通讯,数据正常发送,将CTS拉低,即PA11接GND。

3软件设计
本章教程主要通过使用两块开发板UART1演示硬件流控制数据收发,具体程序如下:
usart.h文件
  1. #ifndef __USART_H
  2. #define __USART_H

  3. #include "ch32v10x_conf.h"

  4. void USART1_ReCFG(void);

  5. #endif
usart.h文件主要进行相关定义和函数声明;
usart.c文件
  1. #include "usart.h"

  2. /*******************************************************************************
  3. * Function Name  : USART1_ReCFG
  4. * Description    : Reinitialize the USART1.
  5. * Input          : None
  6. * Return         : None
  7. *******************************************************************************/
  8. void USART1_ReCFG(void)
  9. {
  10.     GPIO_InitTypeDef  GPIO_InitStructure;
  11.     USART_InitTypeDef USART_InitStructure;

  12.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA |RCC_APB2Periph_USART1 , ENABLE);

  13.     /* USART1 TX-->A.9  */
  14.     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9 ;
  15.     GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  16.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  17.     GPIO_Init(GPIOA, &GPIO_InitStructure);

  18.     /* RTS-->A.12 */
  19.     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12;
  20.     GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  21.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  22.     GPIO_Init(GPIOA, &GPIO_InitStructure);

  23.     /* USART1 RX-->A.10 */
  24.     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10 ;
  25.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
  26.     GPIO_Init(GPIOA, &GPIO_InitStructure);

  27.     /* CTS-->A.11 */
  28.     GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_11;
  29.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
  30.     GPIO_Init(GPIOA, &GPIO_InitStructure);

  31.     USART_InitStructure.USART_BaudRate = 115200;                 //设置串口波特率为115200
  32.     USART_InitStructure.USART_WordLength = USART_WordLength_8b;  //字长为8位数据格式
  33.     USART_InitStructure.USART_StopBits = USART_StopBits_1;       //1个停止位
  34.     USART_InitStructure.USART_Parity = USART_Parity_No;          //无奇偶校验位
  35.     USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_RTS_CTS; //硬件流控制
  36.     USART_InitStructure.USART_Mode = USART_Mode_Tx | USART_Mode_Rx; //发送和接收模式
  37.     USART_Init(USART1, &USART_InitStructure);

  38.     USART_Cmd(USART1, ENABLE);

  39. }
usart.c文件主要进行串口2初始化配置;
main.c文件
  1. int main(void)
  2. {
  3.     NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
  4.     Delay_Init();
  5.     USART1_ReCFG();

  6.     printf("USART1 Hardware Flow Control TEST\r\n");

  7.     while(TxCnt<TxSize)
  8.     {
  9.       USART_SendData(USART1, TxBuffer[TxCnt++]);
  10.       while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
  11.     }

  12.     do
  13.     {
  14.       if((USART_GetFlagStatus(USART1, USART_FLAG_RXNE) != RESET)&&(RxCnt < TxSize))
  15.       {
  16.        RxBuffer[RxCnt] = USART_ReceiveData(USART1);
  17.        USART_SendData(USART1, RxBuffer[RxCnt++]);              /* send it when receive a byte */
  18.       }
  19.     }while((RxBuffer[RxCnt - 1] != '\r')&&(RxCnt != TxSize));

  20.     while(1)
  21.     {
  22.     }
  23. }
main.c文件主要进行数据发送和接收。

4下载验证
将编译好的程序分别下载到两个开发版并复位,串口打印如下:
图片4.png

61、USART-硬件流控制.rar

454.28 KB, 下载次数: 213

xinpian101 发表于 2021-2-22 10:17 | 显示全部楼层
串口助手是不是要开启这个功能。

评论

这边进行实验时两个开发板之间进行串口通信,串口助手正常使用,不用开启哦  发表于 2021-2-22 10:20
明天真的好 发表于 2021-2-23 16:12 | 显示全部楼层
硬件流测试我一直没有搞明白,串口调试助手应该怎么设置才可以?

评论

这个例程中不用对串口调试助手进行设置,是两个开发板之间的通信  发表于 2021-2-23 16:25
嵌入小菜菜 发表于 2021-2-23 16:25 | 显示全部楼层
硬件流在使用串口调试助手测试的时候,好像一般串口调试助手都不具备这样的功能。
dongnanxibei 发表于 2021-3-13 15:41 | 显示全部楼层
这个是不是要多用2根线
您需要登录后才可以回帖 登录 | 注册

本版积分规则

133

主题

296

帖子

45

粉丝
快速回复 在线客服 返回列表 返回顶部