0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

在MM32F013x上实现UART极性取反的功能应用

电子设计 来源:电子设计 作者:电子设计 2022-02-21 10:38 次阅读

本文是针对在MM32F013x上实现UART极性取反的功能应用。

嵌入式领域,通常默认串口的电平是高电平为逻辑1,低电平为逻辑0,而在MM32的UART特性中是可以将高电平设置为逻辑0,低电平设置为逻辑1的,UART极性取反虽然不常用,但还是在特殊情况下是需要这个功能,比如硬件设计已经导致必须使用极性取反,否则电路就要改板或者增加反相电路。例如下图的UART隔离电路就需要UART发送极性取反功能。

o4YBAGAHyd6APdokAACKVuTz680882.png

图1 UART隔离电路

01、UART极性取反简介

UART极性取反下的电平与正常模式下的电平是相反的,正常情况下,UART空闲时电平是高,起始位是空闲状态下变成低电平,bit为1时电平也高。在UART极性取反状态下,空闲电平是低电平,起始位是高,bit为1时电平是低。

在数据接收发送寄存器中,数据也是可以反转的,原来的0变为1,原来的1变为0,这和电平极性反转是类似。需要特别注意的是,在极性反转的时候,起始位和结束位也都反转了,所有的信号电平都反转;而在数据寄存器中只反转了数据位,其中也包含了校验位,没有反转信号的起始位和结束位的极性。

o4YBAGAHyhyAHNKyAABp-MZY9GY778.png

图2 UART极性取反波形

上图是用逻辑分析仪抓取的UART极性取反的逻辑波形。红色字体:“IDLE”部分是空闲状态,“START”是起始位,后面“0~7”是数据的bit0~bit7,“STOP” 是停止位,“IDLE”是空闲(注意,逻辑分析仪设置反向,不然只能抓到波形,无法解析出数据)。

o4YBAGAHylqAZsAyAAEB0eCLsQM322.png

图3 UART极性取反控制位

UART->GCR寄存器描述

设置寄存器 TX_TOG位来使能UART发送极性取反功能。

如果UART接收极性也需要取反,则设置RX_TOG位来使能UART接收极性取反功能。

除了设置上述2个位外,其他部分的设置跟普通模式一模一样。

02、初始化UART1

从官网上下载MM32F013x例程,里面有UART普通模式的配置,主要是增加了UART->GCR的TX_TOG和RX_TOG位设置,如下:

void uart_nvic_init(u32 bound) { GPIO_InitTypeDef GPIO_InitStructure; UART_InitTypeDef UART_InitStructure; NVIC_InitTypeDef NVIC_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_UART1, ENABLE); RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOA, ENABLE); GPIO_PinAFConfig(GPIOA, GPIO_PinSource9, GPIO_AF_1); GPIO_PinAFConfig(GPIOA, GPIO_PinSource10, GPIO_AF_1); //UART1 NVIC NVIC_InitStructure.NVIC_IRQChannel = UART1_IRQn; NVIC_InitStructure.NVIC_IRQChannelPriority = 3; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); //Baud rate UART_StructInit(&UART_InitStructure); UART_InitStructure.BaudRate = bound; //The word length is in 8-bit data format. UART_InitStructure.WordLength = UART_WordLength_8b; UART_InitStructure.StopBits = UART_StopBits_1; //No even check bit. UART_InitStructure.Parity = UART_Parity_No; //No hardware data flow control. UART_InitStructure.HWFlowControl = UART_HWFlowControl_None; UART_InitStructure.Mode = UART_Mode_Rx | UART_Mode_Tx; UART_Init(UART1, &UART_InitStructure); UART_ITConfig(UART1,UART_IT_RXIEN,ENABLE); UART1->GCR |= UART_GCR_TXTOG; //发送取反位 UART1->GCR |= UART_GCR_RXTOG; //接收取反位 UART_Cmd(UART1, ENABLE); //UART1_TX GPIOA.9 GPIO_StructInit(&GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; GPIO_Init(GPIOA, &GPIO_InitStructure); //UART1_RX GPIOA.10 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_FLOATING; GPIO_Init(GPIOA, &GPIO_InitStructure); }

03、功能测试

UART极性取反测试可以自发自收,需要将PA9和PA10短接,需要注意的是收发都需要配置成极性取反功能。在main函数所在.c文件里面,定义一个u8型全局变量UART_SendValue,UART_SendValue每隔500ms自加1,然后通过UART发送出去,依次循环。

u8 UART_SendValue = 0; s32 main(void) { DELAY_Init(); LED_Init(); uart_nvic_init(9600); while(1) { UartSendByte(++UART_SendValue); DELAY_Ms(500); } }

在UART的中断服务函数里面,将接收到的数据存放在printBuf,这样可以在仿真界面下的watch窗口观看printBuf的值是否每隔500ms增加一次并且和UART_SendValue的值一致。

void UART1_IRQHandler(void) { if (UART_GetITStatus(UART1, UART_ISR_RX) != RESET) { UART_ClearITPendingBit(UART1, UART_ISR_RX); printBuf = UART_ReceiveData(UART1); } }

下图仿真界面下可以看到printBuf和UART_SendValue的值是一致的。

pIYBAGAHypiAT5W0AAAc_dV2kEM793.png

图4 UART仿真watch窗口数据对比

下图逻辑分析仪抓取的逻辑波形,可以看到电平和分析到的数据都是一致的。

转自:灵动微电子
审核编辑:何安

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • uart
    +关注

    关注

    22

    文章

    1159

    浏览量

    99961
  • 灵动微电子
    +关注

    关注

    7

    文章

    108

    浏览量

    19555
收藏 人收藏

    评论

    相关推荐

    STM32F407UART ISP下载失败率高是什么原因导致的?

    大侠,现在用UART ISP(115200BPS)下载,用的同样的程序,STM32F103是100%成功,现更换STM32F407后发现
    发表于 04-15 08:07

    如何配置同时具备SlaveFifo和USB-UART桥接功能的FX3设备?

    功能希望同时实现,且彼此之间互不干扰 1. FX3与FPGA连接,即使用SlaveFifo功能(如 FX3 SDK slfifosync 示例) 2. 1的基础
    发表于 02-28 08:20

    请问可以更改UART的引脚GPIO54和GPIO55上来实现UART功能嘛?

    我想更改UART的引脚 GPIO54和GPIO55实现UART功能,在手册中没有找到相关的
    发表于 02-28 06:12

    能否RS485和ESP=M3使用相同的UART

    我们目前的产品TLE9243QK_BASE_BOARDPSoC™目前有RS485通过UART组件。现在我需要添加 ESP8285 ESP-M3 来添加 WIFI 功能。我的问题是,我能否 RS485 和 ESP=M3
    发表于 01-22 08:10

    uart与usart区别 usart可以当uart用吗

    USART实际上包含了UART功能,并增加了支持同步通信的能力。在大多数微控制器中,UART通常是USART功能的一部分,USART可以配置为UA
    发表于 01-17 15:46 4656次阅读
    <b class='flag-5'>uart</b>与usart区别 usart可以当<b class='flag-5'>uart</b>用吗

    MM32F5270 UART实现LIN通信

    LIN(Local Interconnect Network)总线是基于UART/SCI(通用异步收发器/串行接口)的低成本串行通讯协议,其目标定位于车身网络模块节点间的低端通信
    的头像 发表于 01-04 17:35 1787次阅读
    <b class='flag-5'>MM</b>32F5270 <b class='flag-5'>UART</b><b class='flag-5'>实现</b>LIN通信

    直流高压发生器实现快速极性转换的几种方式

    直流高压发生器实现快速极性转换的几种方式  直流高压发生器是一种能够输出高电压、高稳定性的设备,广泛应用于实验室研究、工业生产以及医疗领域等。在某些应用场景中,可能需要快速地实现极性
    的头像 发表于 12-20 15:23 395次阅读

    如何用HLS实现UART呢?

    UART 是一种旧的串行通信机制,但仍在很多平台中使用。它在 HDL 语言中的实现并不棘手,可以被视为本科生的作业。在这里,我将通过这个例子来展示在 HLS 中实现它是多么容易和有趣。
    的头像 发表于 11-20 09:50 354次阅读
    如何用HLS<b class='flag-5'>实现</b><b class='flag-5'>UART</b>呢?

    如何用HLS实现UART

    UART 是一种旧的串行通信机制,但仍在很多平台中使用。它在 HDL 语言中的实现并不棘手,可以被视为本科生的作业。在这里,我将通过这个例子来展示在 HLS 中实现它是多么容易和有趣。
    的头像 发表于 11-20 09:48 298次阅读
    如何用HLS<b class='flag-5'>实现</b><b class='flag-5'>UART</b>

    使用“~”运算符对单bit信号进行取反

    使用“~”运算符对单bit信号进行取反(也称为位翻转或反向)。
    的头像 发表于 11-08 09:28 606次阅读

    MM32F0140 UART学习笔记

    MM32F0140 UART学习笔记
    的头像 发表于 09-26 16:45 415次阅读
    <b class='flag-5'>MM</b>32F0140 <b class='flag-5'>UART</b>学习笔记

    如何在CW32F030实现IAP功能

    CW32F030实现IAP功能
    发表于 09-15 07:43

    BUCK电路从输出滤波电容后面取反馈和电容前取反馈的区别是什么?

    BUCK电路从输出滤波电容后面取反馈和电容前取反馈有什么不同吗?影响响应速度,可以详解一下吗?取的是电流反馈
    发表于 07-31 17:04

    imx6ulluart3和uart6是否支持rs485?

    目前,我正在研究 IMX8dxp 处理器,但我 fsl-lpuart.c 的 linux 驱动程序中遇到了一些问题。 我的硬件,我们想使用硬件 rs485 收发器连接我们的 uart
    发表于 05-24 07:14

    kernel5.10的imx8mm uart dma无法接收数据怎么解决?

    社区大家好, 我将kernel5.10移植到imx8mm,发现一个问题,当我打开串口的dma功能时,串口通讯不可用,无法收发数据。 我已经链接了 RTS/CTS,这是我的 dts 设置
    发表于 05-19 08:01