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

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

3天内不再提示

基于MM32F013x上实现UART极性取反的方案设计

电子设计 来源:灵动微电子 作者:灵动微电子 2021-01-11 06:10 次阅读

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

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

o4YBAF_78GaACzKHAACp-yPmo54432.png

图1 UART隔离电路

01、UART极性取反简介

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

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

pIYBAF_78HSAaO19AACEpAn0FYQ055.png

图2 UART极性取反波形

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

pIYBAF_78M6Afht3AAGUxZVoiYQ896.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的值是一致的。

o4YBAF_78NuAfJ-qAABCwf9Jf8E582.png

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

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

pIYBAF_78OqAV2sNAABTx5hJ2hg925.png

图5 UART极性0x09取反波形
编辑:hfy

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

    关注

    31

    文章

    5357

    浏览量

    120656
  • 隔离电路
    +关注

    关注

    8

    文章

    66

    浏览量

    37129
  • uart
    +关注

    关注

    22

    文章

    1240

    浏览量

    101489
  • 逻辑分析仪
    +关注

    关注

    3

    文章

    214

    浏览量

    23202
收藏 人收藏

    评论

    相关推荐

    低电压冗余电源方案设计

    低电压冗余电源方案设计
    发表于 12-16 14:47 0次下载

    RZ/G2L高速虚拟串口方案 基于瑞萨RZ/G2L SMARC开发板的虚拟(Virtual UART)实现方案

    UART)实现方案,以实现高速Linux UART通信,供客户参考。 虚拟(Virtual UART
    发表于 11-20 14:41 420次阅读
    RZ/G2L高速虚拟串口<b class='flag-5'>方案</b> 基于瑞萨RZ/G2L SMARC开发板的虚拟(Virtual <b class='flag-5'>UART</b>)<b class='flag-5'>实现</b><b class='flag-5'>方案</b>

    使用USB转UART桥接芯片TUSB3410 TMS320F280x DSC USB连接

    电子发烧友网站提供《使用USB转UART桥接芯片TUSB3410 TMS320F280x DSC USB连接.pdf》资料免费下载
    发表于 10-16 10:51 0次下载
    使用USB转<b class='flag-5'>UART</b>桥接芯片TUSB3410 TMS320<b class='flag-5'>F280x</b> DSC USB连接

    将PWM输出用作TMS320F280x的数模转换器

    电子发烧友网站提供《将PWM输出用作TMS320F280x的数模转换器.pdf》资料免费下载
    发表于 10-16 10:33 0次下载
    将PWM输出用作TMS320<b class='flag-5'>F280x</b><b class='flag-5'>上</b>的数模转换器

    极性电容怎么变成无极性电容

    ,我们可以通过一些电路设计方法和替代策略来实现在某些情况下使用有极性电容达到无极性电容的效果。 一、理解有极性电容和无极性电容的差异 首先,
    的头像 发表于 09-27 10:53 618次阅读

    微型化晶振技术:实现1.2mm x 1.0mm尺寸的关键与优势

    随着现代电子设备的不断小型化和高性能化,晶振(晶体振荡器)也面临着向更小尺寸发展的需求。1.2mm x 1.0mm这种微型化晶振的实现代表了当前晶体振荡技术的前沿,它不仅在尺寸
    的头像 发表于 08-22 17:25 467次阅读
    微型化晶振技术:<b class='flag-5'>实现</b>1.2<b class='flag-5'>mm</b> <b class='flag-5'>x</b> 1.0<b class='flag-5'>mm</b>尺寸的关键与优势

    安森美OBC系统解决方案设计指南

    “OBC系统解决方案设计指南”又上新了,第一篇文章介绍了系统用途、系统实施方法、系统说明、市场趋势和标准等,本文将继续介绍解决方案概述及拓扑。
    的头像 发表于 08-20 16:34 915次阅读
    安森美OBC系统解决<b class='flag-5'>方案设计</b>指南

    MSP430F677x1A、MSP430F676x1A、MSP430F674x1A多相仪表计量片系统(SoC)数据表

    电子发烧友网站提供《MSP430F677x1A、MSP430F676x1A、MSP430F674x1A多相仪表计量片系统(SoC)数据表.pdf》资料免费下载
    发表于 08-09 10:40 0次下载
    MSP430<b class='flag-5'>F677x</b>1A、MSP430<b class='flag-5'>F676x</b>1A、MSP430<b class='flag-5'>F674x</b>1A多相仪表计量片<b class='flag-5'>上</b>系统(SoC)数据表

    B码对时方案,基于TI AM62x异构多核工业处理器实现

    AM62x异构多核处理器实现IRIG-B码对时方案,降低了终端用户的开发难度,缩减了研发时间,可快速进行产品方案评估与技术预研。 图3 常见IRIG-B码对时
    发表于 07-25 14:38

    B码对时方案,基于TI AM62x异构多核工业处理器实现

    IRIG-B码开发方案结构简单、开发成本较低、同步精度较高,可满足多种工业应用场景要求。AM62x IRIG-B码对时方案 本章节主要描述创龙科技基于TI AM62x的MCU(Cort
    发表于 07-17 11:07

    在imotion解决方案设计器中使用不同的参数集,为什么总是加载参数集0吗?

    我正在尝试在 imotion 解决方案设计器中使用不同的参数 集 。 我有 2 组参数 0 和 1,在构建阶段,我 设置 为在设备启动时加载参数 集 1。 但是当我对设备进行编程并重新启动它时,我
    发表于 06-03 08:13

    日本或对谷歌采取反垄断行动

    日本或对谷歌采取反垄断行动 据外媒报道日本计划就搜索广告的垄断行为对谷歌采取反垄断行动。据悉日本公平交易委员会此前就一直在调查谷歌向雅虎提供的关键词定向搜索广告技术;以推动谷歌改革其商业行为。
    的头像 发表于 04-17 16:35 369次阅读

    基于SDI5209PSS-X2雾化器方案设计

    电流 图6 SDI5209PSS-X2雾化器方案通过24bitADC来检测流过雾化片的电流,来检测雾化片是否工作正常,同时可以实现扫频追踪雾化片最佳频率。同时通过8位ADC通道检测电池电压来
    发表于 03-08 17:03

    请问有极性电容和无极性电容的区别在哪?

    您更好地理解它们。 一、定义 1. 极性电容:极性电容是一种具有正负电极极性的电容器。它们通常用于存储和释放电力的器件中。极性电容的正负极性
    的头像 发表于 02-21 11:30 4501次阅读

    PCBA电子元件极性识别方法

    【必看】PCBA电子元件极性识别方法
    的头像 发表于 01-11 10:18 1814次阅读
    PCBA<b class='flag-5'>上</b>电子元件<b class='flag-5'>极性</b>识别方法