查看: 1506|回复: 0
收起左侧

第六十二章:CH32V103应用教程——USART-硬件流控制

[复制链接]

  离线 

  • TA的每日心情
    慵懒
    2021-7-23 17:16
  • 签到天数: 17 天

    [LV.4]

    发表于 2021-4-30 18:22:12 | 显示全部楼层 |阅读模式

    有人预言,RISC-V或将是继Intel和Arm之后的第三大主流处理器体系。欢迎访问全球首家只专注于RISC-V单片机行业应用的中文网站

    您需要 登录 才可以下载或查看,没有帐号?立即注册

    x
    本帖最后由 草帽王子 于 2021-9-10 17:51 编辑

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


    1、USART简介及相关函数介绍

    在硬件流控制模式中,还需用到以下两个引脚:

    ● CTS: 清除发送,若是高电平,在当前数据传输结束时阻断下一次的数据发送。
    ● RTS: 发送请求,若是低电平,表明USART准备好接收数据。

    通过利用CTS输入和RTS输出可以控制2个设备间的串行数据流。下图表明在这个模式里如何连接2个设备。

    CH32V CH573单片机芯片-第六十二章:CH32V103应用教程——USART-硬件流控制risc-v单片机中文社区(1)
    通过将UASRTx_CTLR3中的RTSE和CTSE置位,可以分别独立地使能RTS和CTS流控制。

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

    CH32V CH573单片机芯片-第六十二章:CH32V103应用教程——USART-硬件流控制risc-v单片机中文社区(2)

    2、CTS流控制
    如果CTS流控制被使能(CTSE=1),发送器在发送下一帧前检查nCTS输入。如果nCTS有效(被拉成低电平),则下一个数据被发送(假设那个数据是准备发送的,也就是TXE=0),否则下一帧数据不被发出去。若nCTS在传输期间被变成无效,当前的传输完成后停止发送。

    当CTSE=1时,只要nCTS输入一变换状态,硬件就自动设置CTSIF状态位。它表明接收器是否准备好进行通信。如果设置了USART_CT3寄存器的CTSIE位,则产生中断。下图是一个启用CTS流控制通信的例子。
    CH32V CH573单片机芯片-第六十二章:CH32V103应用教程——USART-硬件流控制risc-v单片机中文社区(3)

    关于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、下载验证

    将编译好的程序分别下载到两个开发版并复位,串口打印如下:
    CH32V CH573单片机芯片-第六十二章:CH32V103应用教程——USART-硬件流控制risc-v单片机中文社区(4)

    61、USART-硬件流控制.rar
    CH32V CH573单片机芯片-第六十二章:CH32V103应用教程——USART-硬件流控制risc-v单片机中文社区(5) 61、USART-硬件流控制.rar (454.28 KB, 下载次数: 9)
    链接:https://pan.baidu.com/s/1uM7tIJiBV42gH9fBQxGvJg
    提取码:gjib
    复制这段内容后打开百度网盘手机App,操作更方便哦







    上一篇:第六十一章:CH32V103应用教程——USART-单线半双工
    下一篇:第六十三章:CH32V103应用教程——USART-同步模式
    RISCV作者优文
    全球首家只专注于RISC-V单片机行业应用的中文网站
    回复

    使用道具 举报

    高级模式
    B Color Image Link Quote Code Smilies

    本版积分规则

    关闭

    RISC-V单片机中文网上一条 /2 下一条



    版权及免责声明|RISC-V单片机中文网 |网站地图

    GMT+8, 2024-9-15 17:24 , Processed in 0.320732 second(s), 48 queries .

    快速回复 返回顶部 返回列表