chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

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

電子設計 ? 來源:靈動微電子 ? 作者:靈動微電子 ? 2021-01-11 06:10 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

o4YBAF_78GaACzKHAACp-yPmo54432.png

圖1 UART隔離電路

01、UART極性取反簡介

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

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

pIYBAF_78HSAaO19AACEpAn0FYQ055.png

圖2 UART極性取反波形

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

pIYBAF_78M6Afht3AAGUxZVoiYQ896.png

圖3 UART極性取反控制位

UART->GCR寄存器描述

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

如果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; //發(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文件里面,定義一個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的中斷服務函數(shù)里面,將接收到的數(shù)據存放在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ù)據對比

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

pIYBAF_78OqAV2sNAABTx5hJ2hg925.png

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

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

    關注

    31

    文章

    5601

    瀏覽量

    129574
  • 隔離電路
    +關注

    關注

    8

    文章

    67

    瀏覽量

    37784
  • uart
    +關注

    關注

    22

    文章

    1308

    瀏覽量

    106382
  • 邏輯分析儀
    +關注

    關注

    3

    文章

    219

    瀏覽量

    24347
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    基于靈動MM32F0010微控制器的空氣炸鍋應用方案

    英尚的智能空氣炸鍋應用方案以靈動MM32F0010作為主控芯片,構建了一套完整、高效的空氣炸鍋智能控制系統(tǒng)。該方案主控采用靈動MM32F0010系列微控制器,它搭載了高性能的Arm
    的頭像 發(fā)表于 12-18 15:54 ?226次閱讀
    基于靈動<b class='flag-5'>MM32F</b>0010微控制器的空氣炸鍋應用<b class='flag-5'>方案</b>

    ?onsemi AF013x Hyperlux? 1.2MP iToF傳感器技術解析與應用指南

    (BSI)CMOS全局快門深度和成像。安森美 (onsemi) AF013x iToF圖像傳感器提供片雙激光驅動器控制、調制頻率(最高至200MHz)和激光眼安全閾值。AF0130傳感器版本在其像素
    的頭像 發(fā)表于 11-22 15:00 ?1089次閱讀
    ?onsemi AF<b class='flag-5'>013x</b> Hyperlux? 1.2MP iToF傳感器技術解析與應用指南

    用于RISCV的F指令集實現(xiàn)的浮點計算單元(FPU)設計方案

    fclass.s e203_exu_fpu_fmvwx_fmvxw 實現(xiàn)指令fmv.w.x fmv.x.w 結構和控制信號設計 如上一節(jié),實際的模塊數(shù)量小于26,復用一些模塊
    發(fā)表于 10-24 07:43

    哪個是有極性的電解電容?

    限體積內能實現(xiàn)遠超其他類型電容的容值(通常從1μF至數(shù)萬μF),但同時也帶來了獨特的極性特征。 極性電解電容的識別特征 有
    的頭像 發(fā)表于 09-01 16:08 ?942次閱讀

    廣州唯創(chuàng)電子WT588F(C013)語音芯片:賦能智能玩具的“聲”動未來

    在追求寓教于樂的智能玩具時代,豐富的語音交互能力已成為核心競爭力。廣州唯創(chuàng)電子WT588F(C013)語音芯片憑借其卓越的性能與多功能性,正成為打造高互動性、高趣味性智能玩具的“聲”力軍,為孩子們
    的頭像 發(fā)表于 08-08 08:09 ?603次閱讀
    廣州唯創(chuàng)電子WT588<b class='flag-5'>F</b>(C<b class='flag-5'>013</b>)語音芯片:賦能智能玩具的“聲”動未來

    基于RV1126開發(fā)板實現(xiàn)人臉檢測方案

    在RV1126開發(fā)板實現(xiàn)人臉檢測:在圖像中找出人臉,以及每張人臉的landmarks位置。 方案設計邏輯流程圖,方案代碼分為分為兩個業(yè)務流程,主體代碼負責抓取、合成圖像,
    的頭像 發(fā)表于 04-21 17:59 ?934次閱讀
    基于RV1126開發(fā)板<b class='flag-5'>實現(xiàn)</b>人臉檢測<b class='flag-5'>方案</b>

    基于RV1126開發(fā)板實現(xiàn)人臉檢測方案

    在RV1126開發(fā)板實現(xiàn)人臉檢測:在圖像中找出人臉,以及每張人臉的landmarks位置。 方案設計邏輯流程圖,方案代碼分為分為兩個業(yè)務流程,主體代碼負責抓取、合成圖像,
    的頭像 發(fā)表于 04-21 14:00 ?13次閱讀
    基于RV1126開發(fā)板<b class='flag-5'>實現(xiàn)</b>人臉檢測<b class='flag-5'>方案</b>

    基于RV1126開發(fā)板實現(xiàn)人員檢測方案

    在RV1126實現(xiàn)人員檢測:在圖像中找出人。 方案設計邏輯流程圖,方案代碼分為分為兩個業(yè)務流程,主體代碼負責抓取、合成圖像,算法代碼負責人員檢測功能。
    的頭像 發(fā)表于 04-21 10:42 ?830次閱讀
    基于RV1126開發(fā)板<b class='flag-5'>實現(xiàn)</b>人員檢測<b class='flag-5'>方案</b>

    基于RV1126開發(fā)板實現(xiàn)人臉檢測方案

    在RV1126開發(fā)板實現(xiàn)人臉檢測:在圖像中找出人臉,以及每張人臉的landmarks位置。 方案設計邏輯流程圖,方案代碼分為分為兩個業(yè)務流程,主體代碼負責抓取、合成圖像,
    的頭像 發(fā)表于 04-21 10:21 ?99次閱讀
    基于RV1126開發(fā)板<b class='flag-5'>實現(xiàn)</b>人臉檢測<b class='flag-5'>方案</b>

    基于RV1126開發(fā)板實現(xiàn)人臉檢測方案

    在RV1126實現(xiàn)人臉檢測:在圖像中找出人臉,以及每張人臉的landmarks位置。方案設計邏輯流程圖,方案代碼分為分為兩個業(yè)務流程,主體代碼負責抓取、合成圖像, 算法代碼負責人臉檢
    的頭像 發(fā)表于 04-18 16:47 ?277次閱讀
    基于RV1126開發(fā)板<b class='flag-5'>實現(xiàn)</b>人臉檢測<b class='flag-5'>方案</b>

    靈動微電子推出全新超值型MM32F0050系列MCU

    靈動微電子推出全新超值型MM32F0050系列MCU。2018年,靈動首次上市了其主打性價比的超值型MM32F00系列,目前已陸續(xù)推出了F003、F0010、
    的頭像 發(fā)表于 04-01 09:36 ?1573次閱讀
    靈動微電子推出全新超值型<b class='flag-5'>MM32F</b>0050系列MCU

    無法在imx8mm-c2板啟動藍牙,為什么?

    我無法在 imx8mm-c2 板啟動藍牙、我正在使用 AMPAK 固件 BCM4362A2_001.003.006.1132.1255.hcd、這是我的 dts 文件更改 uart
    發(fā)表于 03-31 06:07

    使用STM32F103RET6方案設計一款錄音筆,如何設計才能達到輸出16bit的分辨率?

    使用STM32F103RET6方案設計一款錄音筆,為了減少紋波并提高分辨率,在硬件電路設計預采用R-2R梯形網絡,如何設計才能達到輸出16bit的分辨率?
    發(fā)表于 03-10 06:08

    300x32mm玻璃鋼天線:高性能通信解決方案

    深圳安騰納天線|300x32mm玻璃鋼天線:高性能通信解決方案
    的頭像 發(fā)表于 02-27 09:03 ?977次閱讀

    0.6mm超薄ePOP4x!江波龍智能穿戴存儲再突破

    )超薄ePOP4x實現(xiàn)了更精簡的穿戴物理布局。 超薄封裝、高集成度設計 穿戴設備更極致的空間利用 與標準存儲方案相比,ePOP4x采用了創(chuàng)新的封裝技術和高度集成設計。其最大厚度僅為0
    發(fā)表于 02-21 11:09 ?417次閱讀
    0.6<b class='flag-5'>mm</b>超薄ePOP4<b class='flag-5'>x</b>!江波龍智能穿戴存儲再突破