STM32的USART1与USART2模块串行数据通讯功能

发布时间:2023-08-03  

STM32的USART1与USART2模块支持多种功能,包括IrDA红外、Smart Card(IC卡)等。本文就其串行数据通讯功能进行讲解。


USART功能图:

图片

图片

一般情况串口都采用异步方式通讯,因此本文只讲解异步通讯方式(UART)。异步模式下串口采用Tx、Rx两线,其数据模式如图:

图片

上图为数据长度为8位(包括1位校验)的情形。位数据的意义:


总线空闲 :空闲时线上为高电平。


起始位 :一位逻辑0信号帧,代表传输开始。


数据位 :可以为7位或8位数据。低位开始传输


校验位: 若启用,使得逻辑1的位数应为偶数(偶校验)或奇数(奇校验)。若不启用,该位由一位数据帧替代(多一位数据)。


停止位: 一位或两位逻辑1,标志一个数据字符传输完成。


※一般情况下个人推荐①数据长度为9位(有效数据8位+一位校验)或②数据8位(无校验);并尽量采用ascii或16进制编码方式。


UART配置结构体LL_USART_InitTypeDef


typedef struct

{

  uint32_t BaudRate;/*

  配置波特率;通过LL_USART_SetBaudRate()函数实现

  @param BaudRate=115200,9600.etc

  */

  uint32_t DataWidth;/*

  配置数据帧数;通过LL_USART_SetDataWidth()函数实现

  @param DataWidth = LL_USART_DATAWIDTH_8B 

                     LL_USART_DATAWIDTH_9B

  */

  uint32_t StopBits;/*

  设置停止位数;通过LL_USART_SetStopBitsLength()实现

  @param StopBits = LL_USART_STOPBITS_0_5  0.5stop bit 

                    LL_USART_STOPBITS_1     1 stop bit 

                    LL_USART_STOPBITS_1_5  1.5stop bits 

                    LL_USART_STOPBITS_2     2stop bits

  */

  uint32_t Parity;/*

  设置校验位;通过LL_USART_SetParity()实现

  @param Parity = LL_USART_PARITY_NONE 

                  LL_USART_PARITY_EVEN  偶校验

                  LL_USART_PARITY_ODD  奇校验

  */

  uint32_t TransferDirection;/*

  设置数据收发模式;通过LL_USART_SetTransferDirection()实现

  @param TransferDirection = LL_USART_DIRECTION_NONE 双向禁用

                             LL_USART_DIRECTION_RX 单接收

                             LL_USART_DIRECTION_TX 单发送

                             LL_USART_DIRECTION_TX_RX 发送&接收

  */ 

  uint32_t HardwareFlowControl; /*

  用于RS232的其他硬件引脚配置(CTS、RTS);通过LL_USART_SetHWFlowCtrl()实现

  @param HardwareFlowControl = LL_USART_HWCONTROL_NONE 无

                               LL_USART_HWCONTROL_RTS RTS

                               LL_USART_HWCONTROL_CTS CTS

                               LL_USART_HWCONTROL_RTS_CTS CTS&RTS

  */

  uint32_t OverSampling;/*

  设置过采样。通过LL_USART_SetOverSampling()实现。※不要更改

  @param OverSampling = LL_USART_OVERSAMPLING_16 

                        LL_USART_OVERSAMPLING_8                

  */

} LL_USART_InitTypeDef;

__STATIC_INLINE void LL_USART_Enable(USART_TypeDef *USARTx);/*

启用USART模块;生成的初始化代码中已调用。

@param USARTx= USART1 

               USART2 .etc

*/

__STATIC_INLINE void LL_USART_Disable(USART_TypeDef *USARTx);/*

关闭USART模块

*/

__STATIC_INLINE uint32_t LL_USART_IsEnabled(USART_TypeDef *USARTx);/*

检测USART模块是否已开启。

@retval = 0  !0

*/

ErrorStatus LL_USART_Init(USART_TypeDef *USARTx, LL_USART_InitTypeDef *USART_InitStruct);/*

USART初始化函数; @retval = SUCCESS  ERROR

*/

以下函数与状态寄存器有关(相关函数只用于指示状态,可以不使用):


请在reset时先将使用到的位清零


※但若使能中断,则中断处理完全必须清零状态位方能产生下一次interrupt


__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_PE(USART_TypeDef *USARTx);/*

接收使能时,判断是否发生奇偶性校验错误(检测PE位,当错误时置位,通过软件清零)

※当CubeMx设置了奇偶校验时有效

@retval = 1 发生过错误

*/

__STATIC_INLINE void LL_USART_ClearFlag_PE(USART_TypeDef *USARTx);/*

清零PE位。

*/


__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_FE(USART_TypeDef *USARTx);/*

判断是否发生帧错误(噪声、断开符)。(检测FE位,当错误时置位,通过软件清零)

@retval = 1 发生过错误

*/

__STATIC_INLINE void LL_USART_ClearFlag_FE(USART_TypeDef *USARTx);/*

清零FE位

*/


__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_NE(USART_TypeDef *USARTx);/*

检测噪声错误。(检测NE位,当错误时置位,通过软件清零)

*/

__STATIC_INLINE void LL_USART_ClearFlag_NE(USART_TypeDef *USARTx);/*

清零NE位

*/


__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_ORE(USART_TypeDef *USARTx);/*

检测过载错误。(读取寄存器中数据尚未被读取时收到新数据)(ORE位)

*/

__STATIC_INLINE void LL_USART_ClearFlag_ORE(USART_TypeDef *USARTx);/*

清零ORE位

*/


__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_IDLE(USART_TypeDef *USARTx);/*

检测总线空闲;(IDLE位)

*/

__STATIC_INLINE void LL_USART_ClearFlag_IDLE(USART_TypeDef *USARTx);/*

清零IDLE位

*/

以下为使用频繁的状态寄存器相关函数:


__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_RXNE(USART_TypeDef *USARTx);/*

读数据非空   ;检测读取数据寄存器RDR状态。

※读取数据寄存器RDR 完全 完成一次数据接收时,该位被置位。@retval =1

※对读取数据寄存器RDR的读取操作可以硬件清零 该位。

不推荐软件清零

*/

__STATIC_INLINE void LL_USART_ClearFlag_RXNE(USART_TypeDef *USARTx);/*慎用*/



__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_TC(USART_TypeDef *USARTx);/*

发送完成   ;读TC

当发送完一帧,且发送数据寄存器空时@retval = 1

需要通过软件清零

*/

__STATIC_INLINE void LL_USART_ClearFlag_TC(USART_TypeDef *USARTx);


__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_TXE(USART_TypeDef *USARTx);/*

发送数据寄存器空     ; 检测发送数据寄存器TDR状态

※当发送数据寄存器TDR数据被送出时,该位被置位。 @retval = 1 

※对发送数据寄存器TDR的写入操作可以硬件清零该位。

不推荐软件清零

*/

__STATIC_INLINE void LL_USART_ClearFlag_TXE(USART_TypeDef *USARTx);/*慎用*/

相关寄存器:

图片

图片

串口中断的使用

关于中断源:


IDLE中断:总线空闲中断


RXNE中断:接收缓冲区非空中断※常用


TC中断:发送完成中断


TXE中断:发送缓冲区空中断


PE中断:校验失败中断※常用

※以上中断发生将同时调用同一中断函数void USARTx_IRQHandler(void)。可在函数内判断具体的中断源。


配置中断使能:

__STATIC_INLINE void LL_USART_EnableIT_IDLE(USART_TypeDef USARTx);/

使能总线空闲中断

*/

__STATIC_INLINE void LL_USART_EnableIT_RXNE(USART_TypeDef USARTx);/

使能RXNE中断

*/

__STATIC_INLINE void LL_USART_EnableIT_TC(USART_TypeDef USARTx);/

使能TC中断

*/

__STATIC_INLINE void LL_USART_EnableIT_TXE(USART_TypeDef USARTx);/

使能TXE中断

*/

__STATIC_INLINE void LL_USART_EnableIT_PE(USART_TypeDef USARTx);/

使能PE中断

*/


**禁用中断 **


函数模板为LL_USART_DisableIT_xxx(USART_TypeDef *USARTx);


中断程序编写

使能串口中断后,中断调用函数为void USART▢_IRQHandler(void)


若启用了多个对应的中断源,则应该在中断函数中


判断中断源,再进行对应操作。


判断原理:

初始化时启用相应中断并软件清零用到的状态位。


当触发相应的事件时,中断源的状态位被置位,其余状态位仍处于初始化后0态。此时跳转执行中断函数void USART▢_IRQHandler(void)

在中断函数中进行用到的状态位的判断,若状态位为1则为中断源

执行完后,将相应状态位清零以使能下一次中断




示例程序:以接收中断为例


在 usart.c中:


void MX_USART1_UART_Init(void)

{

·

·

LL_USART_ClearFlag_RXNE(USART1);//强制清零状态位

LL_USART_EnableIT_RXNE(USART1); //使能RXNE中断

·

}

在it.c中


void USART1_IRQHandler(void)

{

 if (LL_USART_IsActiveFlag_RXNE(USART1))//判断中断源

 {

  LL_USART_TransmitData8(USART1, LL_USART_ReceiveData8(USART1));/*读接收寄存器(8bit)并发送,

  *读操作自动清零状态位*/

  //LL_USART_ClearFlag_RXNE(USART1);//强制清零状态位,不推荐使用

 }

}


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    公布日期为2024年6月4日。 专利摘要显示,本发明涉及光伏电池技术领域,尤其涉及基于远距离光伏电池数据采集传输系统,包括数据采集模块数据传输模块、电子终端机,其中数据采集模块......
    控制器可以有多个通道,每个通道独立管理一个数据传输任务。通道的数量取决于具体的STM32型号,每个通道可以独立配置,使得DMA可以同时执行多个数据传输任务。 数据传输方向寄存器: 该寄存器用于配置数据传输......
    量级时间间隔测量系统由CPU模块、时间间隔测量模块数据传输模块三部分组成,其逻辑框图如图1所示。 其中CPU模块主要功能是模拟纳秒量级脉冲信号、接收时间间隔测量模块的数据、FIFO缓存、发送数据到数据传输模块......
    实现任意分频的时钟输出[4]。其频率表达式如下: 用verilog语言描述时钟产生模块,用ISE综合后,其生成电路如图5所示。 3.2.2 串行接口模块SPI-shift设计[5] 数据传输模块......
    钟的产生、命令和数据的传送。● AHB总线接口:操作SDIO适配器模块中的寄存器(由STM32控制SDIO外设),并产生中断和DMA请求信号 复位后默认情况下SDIO_D0用于数据传输,初始化后主机可以改变数据......
    中,单片机通过带流控位的串口与网络传输模块进行数据传输。 4)网络传输模块将接收到串口数据通过TCP通信同步上传到百度语音识别API,传输结束后,等待TCP Server返回HTTP 响应报文,将报......
    汉字库。   LCM12864ZK引脚功能如表1。2.2操作时序2.2.1并行接口数据传输  当PSB脚接高电平时,模块将进入并行传输方式(由指令位DLFLAG选择8位或4位接口)。每当E引脚上出现一个脉冲,RS和......
    和可编程的外围接口。每条指令占四个时钟周期,在48M晶振下工作时,单指令周 期为83.3ns,执行速度远快于标准的8051单片机。本文的数据传输模块采用CY7C68013 高速芯片设计的USB接口可以实现外部的存储测试电路数据......
    机端:AT89C52单片机芯片,用于控制无线模块的发射和接受;PTR2000无线数据传输模块,使用了433MHz IGM频段,是真正的单片UHF无线收发一体芯片,可以和单片机的串口直接相连。 2、 PC端......
    单片机iic通信的工作原理简述;单片机IIC通信是指在单片机控制下,通过IIC总线进行的数据传输和通信。IIC通信是一种串行通信方式,通过SCL和SDA两个线路进行数据传输,SCL线路......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>