0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于MM32F013x上實(shí)現(xiàn)UART極性取反的方案設(shè)計(jì)

電子設(shè)計(jì) ? 來源:靈動微電子 ? 作者:靈動微電子 ? 2021-01-11 06:10 ? 次閱讀

本文是針對在MM32F013x上實(shí)現(xiàn)UART極性取反的功能應(yīng)用。

嵌入式領(lǐng)域,通常默認(rèn)串口的電平是高電平為邏輯1,低電平為邏輯0,而在MM32的UART特性中是可以將高電平設(shè)置為邏輯0,低電平設(shè)置為邏輯1的,UART極性取反雖然不常用,但還是在特殊情況下是需要這個(gè)功能,比如硬件設(shè)計(jì)已經(jīng)導(dǎo)致必須使用極性取反,否則電路就要改板或者增加反相電路。例如下圖的UART隔離電路就需要UART發(fā)送極性取反功能。

o4YBAF_78GaACzKHAACp-yPmo54432.png

圖1 UART隔離電路

01、UART極性取反簡介

UART極性取反下的電平與正常模式下的電平是相反的,正常情況下,UART空閑時(shí)電平是高,起始位是空閑狀態(tài)下變成低電平,bit為1時(shí)電平也高。在UART極性取反狀態(tài)下,空閑電平是低電平,起始位是高,bit為1時(shí)電平是低。

在數(shù)據(jù)接收發(fā)送寄存器中,數(shù)據(jù)也是可以反轉(zhuǎn)的,原來的0變?yōu)?,原來的1變?yōu)?,這和電平極性反轉(zhuǎn)是類似。需要特別注意的是,在極性反轉(zhuǎn)的時(shí)候,起始位和結(jié)束位也都反轉(zhuǎn)了,所有的信號電平都反轉(zhuǎn);而在數(shù)據(jù)寄存器中只反轉(zhuǎn)了數(shù)據(jù)位,其中也包含了校驗(yàn)位,沒有反轉(zhuǎn)信號的起始位和結(jié)束位的極性。

pIYBAF_78HSAaO19AACEpAn0FYQ055.png

圖2 UART極性取反波形

上圖是用邏輯分析儀抓取的UART極性取反的邏輯波形。紅色字體:“IDLE”部分是空閑狀態(tài),“START”是起始位,后面“0~7”是數(shù)據(jù)的bit0~bit7,“STOP” 是停止位,“IDLE”是空閑(注意,邏輯分析儀設(shè)置反向,不然只能抓到波形,無法解析出數(shù)據(jù))。

pIYBAF_78M6Afht3AAGUxZVoiYQ896.png

圖3 UART極性取反控制位

UART->GCR寄存器描述

設(shè)置寄存器 TX_TOG位來使能UART發(fā)送極性取反功能。

如果UART接收極性也需要取反,則設(shè)置RX_TOG位來使能UART接收極性取反功能。

除了設(shè)置上述2個(gè)位外,其他部分的設(shè)置跟普通模式一模一樣。

02、初始化UART1

從官網(wǎng)上下載MM32F013x例程,里面有UART普通模式的配置,主要是增加了UART->GCR的TX_TOG和RX_TOG位設(shè)置,如下:

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; //發(fā)送取反位
    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極性取反測試可以自發(fā)自收,需要將PA9和PA10短接,需要注意的是收發(fā)都需要配置成極性取反功能。在main函數(shù)所在.c文件里面,定義一個(gè)u8型全局變量UART_SendValue,UART_SendValue每隔500ms自加1,然后通過UART發(fā)送出去,依次循環(huán)。

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

在UART的中斷服務(wù)函數(shù)里面,將接收到的數(shù)據(jù)存放在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窗口數(shù)據(jù)對比

下圖邏輯分析儀抓取的邏輯波形,可以看到電平和分析到的數(shù)據(jù)都是一致的。

pIYBAF_78OqAV2sNAABTx5hJ2hg925.png

圖5 UART極性0x09取反波形
編輯:hfy

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5253

    瀏覽量

    119212
  • 隔離電路
    +關(guān)注

    關(guān)注

    8

    文章

    66

    瀏覽量

    37030
  • uart
    +關(guān)注

    關(guān)注

    22

    文章

    1199

    瀏覽量

    100833
  • 邏輯分析儀
    +關(guān)注

    關(guān)注

    3

    文章

    212

    瀏覽量

    23050
收藏 人收藏

    評論

    相關(guān)推薦

    微型化晶振技術(shù):實(shí)現(xiàn)1.2mm x 1.0mm尺寸的關(guān)鍵與優(yōu)勢

    隨著現(xiàn)代電子設(shè)備的不斷小型化和高性能化,晶振(晶體振蕩器)也面臨著向更小尺寸發(fā)展的需求。1.2mm x 1.0mm這種微型化晶振的實(shí)現(xiàn)代表了當(dāng)前晶體振蕩技術(shù)的前沿,它不僅在尺寸
    的頭像 發(fā)表于 08-22 17:25 ?178次閱讀
    微型化晶振技術(shù):<b class='flag-5'>實(shí)現(xiàn)</b>1.2<b class='flag-5'>mm</b> <b class='flag-5'>x</b> 1.0<b class='flag-5'>mm</b>尺寸的關(guān)鍵與優(yōu)勢

    在imotion解決方案設(shè)計(jì)器中使用不同的參數(shù)集,為什么總是加載參數(shù)集0嗎?

    我正在嘗試在 imotion 解決方案設(shè)計(jì)器中使用不同的參數(shù) 集 。 我有 2 組參數(shù) 0 和 1,在構(gòu)建階段,我 設(shè)置 為在設(shè)備啟動時(shí)加載參數(shù) 集 1。 但是當(dāng)我對設(shè)備進(jìn)行編程并重新啟動它時(shí),我
    發(fā)表于 06-03 08:13

    MM32F5270 UART實(shí)現(xiàn)LIN通信

    LIN(Local Interconnect Network)總線是基于UART/SCI(通用異步收發(fā)器/串行接口)的低成本串行通訊協(xié)議,其目標(biāo)定位于車身網(wǎng)絡(luò)模塊節(jié)點(diǎn)間的低端通信
    的頭像 發(fā)表于 01-04 17:35 ?3052次閱讀
    <b class='flag-5'>MM32F</b>5270 <b class='flag-5'>UART</b><b class='flag-5'>實(shí)現(xiàn)</b>LIN通信

    GD32F47x/F42x的設(shè)備限制及解決方案勘誤手冊

    電子發(fā)燒友網(wǎng)站提供《GD32F47x/F42x的設(shè)備限制及解決方案勘誤手冊.pdf》資料免費(fèi)下載
    發(fā)表于 12-14 09:50 ?0次下載
    GD32<b class='flag-5'>F47x</b>/<b class='flag-5'>F42x</b>的設(shè)備限制及解決<b class='flag-5'>方案</b>勘誤手冊

    GD32F45x/F40x的設(shè)備限制及解決方案介紹

    電子發(fā)燒友網(wǎng)站提供《GD32F45x/F40x的設(shè)備限制及解決方案介紹.pdf》資料免費(fèi)下載
    發(fā)表于 12-14 09:45 ?0次下載
    GD32<b class='flag-5'>F45x</b>/<b class='flag-5'>F40x</b>的設(shè)備限制及解決<b class='flag-5'>方案</b>介紹

    GD32F30x的設(shè)備限制及解決方案介紹

    電子發(fā)燒友網(wǎng)站提供《GD32F30x的設(shè)備限制及解決方案介紹.pdf》資料免費(fèi)下載
    發(fā)表于 12-14 09:44 ?1次下載
    GD32<b class='flag-5'>F30x</b>的設(shè)備限制及解決<b class='flag-5'>方案</b>介紹

    LED驅(qū)動電路方案設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《LED驅(qū)動電路方案設(shè)計(jì).rar》資料免費(fèi)下載
    發(fā)表于 11-20 11:36 ?1次下載
    LED驅(qū)動電路<b class='flag-5'>方案設(shè)計(jì)</b>

    壓控振蕩電路的方案設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《壓控振蕩電路的方案設(shè)計(jì).pdf》資料免費(fèi)下載
    發(fā)表于 11-20 09:59 ?2次下載
    壓控振蕩電路的<b class='flag-5'>方案設(shè)計(jì)</b>

    汽車應(yīng)用模擬解決方案設(shè)計(jì)指南

    電子發(fā)燒友網(wǎng)站提供《汽車應(yīng)用模擬解決方案設(shè)計(jì)指南.pdf》資料免費(fèi)下載
    發(fā)表于 11-17 10:39 ?0次下載
    汽車應(yīng)用模擬解決<b class='flag-5'>方案設(shè)計(jì)</b>指南

    壓電驅(qū)動電源系統(tǒng)的方案設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《壓電驅(qū)動電源系統(tǒng)的方案設(shè)計(jì).pdf》資料免費(fèi)下載
    發(fā)表于 11-14 09:39 ?6次下載
    壓電驅(qū)動電源系統(tǒng)的<b class='flag-5'>方案設(shè)計(jì)</b>

    Melexis針對汽車綠色節(jié)能的方案設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《Melexis針對汽車綠色節(jié)能的方案設(shè)計(jì).rar》資料免費(fèi)下載
    發(fā)表于 11-10 09:59 ?5次下載
    Melexis針對汽車綠色節(jié)能的<b class='flag-5'>方案設(shè)計(jì)</b>

    MM32F0010使用總結(jié)

    MM32F0010使用總結(jié)
    的頭像 發(fā)表于 11-01 17:07 ?759次閱讀
    <b class='flag-5'>MM32F</b>0010使用總結(jié)

    GLONASS接收機(jī)的方案設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《GLONASS接收機(jī)的方案設(shè)計(jì).pdf》資料免費(fèi)下載
    發(fā)表于 10-19 10:25 ?1次下載
    GLONASS接收機(jī)的<b class='flag-5'>方案設(shè)計(jì)</b>

    基于GPS和TTS的自動報(bào)站器方案設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《基于GPS和TTS的自動報(bào)站器方案設(shè)計(jì).pdf》資料免費(fèi)下載
    發(fā)表于 10-08 10:21 ?0次下載
    基于GPS和TTS的自動報(bào)站器<b class='flag-5'>方案設(shè)計(jì)</b>

    MM32F0140 UART學(xué)習(xí)筆記

    MM32F0140 UART學(xué)習(xí)筆記
    的頭像 發(fā)表于 09-26 16:45 ?658次閱讀
    <b class='flag-5'>MM32F</b>0140 <b class='flag-5'>UART</b>學(xué)習(xí)筆記