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

    文章

    1319

    浏览量

    106973
  • 灵动微电子
    +关注

    关注

    7

    文章

    137

    浏览量

    20542
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    TMS320F281x与TMS320C281x DSPs:功能特性与应用指南

    TMS320F281x与TMS320C281x DSPs:功能特性与应用指南 电子设计领域,数字信号处理器(DSP)扮演着至关重要的角色。今天我们要深入探讨的是德州仪器(TI)推出
    的头像 发表于 04-23 14:20 83次阅读

    探索F28M35x Concerto™微控制器:功能、应用与设计要点

    探索F28M35x Concerto™微控制器:功能、应用与设计要点 引言 电子工程师的日常工作中,选择合适的微控制器是项目成功的关键。F28M35x Concerto™微控制器以其
    的头像 发表于 04-19 10:30 218次阅读

    ST75MM电力线通信片系统使用指南

    ST75MM电力线通信片系统使用指南 电力线通信领域,ST75MM电力线通信片系统是一款备受关注的产品。本文将依据其用户手册,为电子工
    的头像 发表于 04-16 15:40 120次阅读

    深入解析 NTMFC013NP10M5L 双沟道 MOSFET:特性与应用

    NTMFC013NP10M5L 是一款双沟道 MOSFET,集成了 N 沟道和 P 沟道,采用 SO8FL 封装,具有小尺寸(5 x 6 mm)的特点,非常适合紧凑型设计。它的主
    的头像 发表于 04-13 17:25 344次阅读

    深入解析 onsemi NVMYS013N08LH 单通道 N 沟道功率 MOSFET

    NVMYS013N08LH 是 onsemi 公司的一款高性能 MOSFET,具有 80V 的耐压、13.1mΩ 的低导通电阻和 42A 的连续漏极电流。该器件采用 LFPAK4 封装,尺寸仅为 5x6mm,非常适合紧凑型设
    的头像 发表于 04-02 17:10 413次阅读

    极海APM32F427 MCURT-Thread系统使用LwIP网络功能

    下面是基于RT-Thread的ENV命令行开发环境,APM32F427使用LwIP网络协议栈实现网络通信功能的。
    的头像 发表于 04-02 15:19 8582次阅读
    极海APM32<b class='flag-5'>F</b>427 MCU<b class='flag-5'>在</b>RT-Thread系统<b class='flag-5'>上</b>使用LwIP网络<b class='flag-5'>功能</b>

    STM32F042x4/STM32F042x6微控制器深度解析:特性、应用与设计要点

    STM32F042x4/STM32F042x6微控制器深度解析:特性、应用与设计要点 嵌入式系统开发领域,微控制器的选择至关重要,它直接影响着产品的性能、功能和成本。今天,我们就来深
    的头像 发表于 03-19 17:15 616次阅读

    探索PIC16(L)F1885X/7X微控制器功能与应用介绍

    探索PIC16(L)F1885X/7X微控制器:功能与应用的深度剖析 电子设计领域,微控制器扮演着至关重要的角色。今天,我们将深入探讨Microchip公司的PIC16(L)
    的头像 发表于 03-17 17:30 510次阅读

    探索PIC16(L)F1885X/7X微控制器:功能与应用的深度剖析

    探索PIC16(L)F1885X/7X微控制器:功能与应用的深度剖析 在当今电子设备飞速发展的时代,微控制器作为核心组件,其性能和功能直接影响着产品的质量和应用范围。Microchip
    的头像 发表于 03-17 16:55 327次阅读

    SM320F281x/C281x DSP系列:高性能与多功能的完美融合

    SM320F281x/C281x DSP系列:高性能与多功能的完美融合 在当今的电子设计领域,数字信号处理器(DSP)扮演着至关重要的角色。德州仪器(TI)的SM320F281x
    的头像 发表于 03-09 10:35 694次阅读

    如何在CW32F030实现IAP功能实现远程升级?

    程序用于电时判断程序是进入 IAP 升级流程还是进入 APP 应用程序执行过程。其一般放置 FLASH 的开始部分 CW32F030 的 Flash 起始地址为 0x00000
    发表于 12-11 06:15

    STEVAL-LLL013V1 LED矩阵面板技术解析与应用指南

    时的功能。LEB矩阵板显示标语,标语中每个像素可能有不同的亮度级别(32级)。水平方向左右滚动标语实现不同照明效果,其中屏幕刷新率高于100Hz。使用STSW-LLL013GUI P
    的头像 发表于 10-25 16:00 2859次阅读
    STEVAL-LLL<b class='flag-5'>013</b>V1 LED矩阵面板技术解析与应用指南

    哪个是有极性的电解电容?

    限体积内能实现远超其他类型电容的容值(通常从1μF至数万μF),但同时也带来了独特的极性特征。 极性电解电容的识别特征 有
    的头像 发表于 09-01 16:08 1282次阅读

    广州唯创电子WT588F(C013)语音芯片:赋能智能玩具的“声”动未来

    追求寓教于乐的智能玩具时代,丰富的语音交互能力已成为核心竞争力。广州唯创电子WT588F(C013)语音芯片凭借其卓越的性能与多功能性,正成为打造高互动性、高趣味性智能玩具的“声”力
    的头像 发表于 08-08 08:09 833次阅读
    广州唯创电子WT588<b class='flag-5'>F</b>(C<b class='flag-5'>013</b>)语音芯片:赋能智能玩具的“声”动未来

    uart接收功能不工作是怎么回事?

    我正在 TL989x 系列开发板上工作,示例代码 UART 发送和接收功能中起作用,发送功能可以工作但接收
    发表于 07-18 08:13