91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

了解在MCU中實現(xiàn)串口的不定長數(shù)據(jù)包接收的過程

5RJg_mcuworld ? 來源:未知 ? 作者:工程師郭婷 ? 2018-08-03 16:37 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

MCU的應(yīng)用中,經(jīng)常需要通過串口進(jìn)行不定長數(shù)據(jù)包的傳輸。發(fā)送方很簡單,不需特別的考慮,而接收方則需要能夠偵測到數(shù)據(jù)包的結(jié)束。接收方的簡單做法是結(jié)合串口的IDLE中斷,或使用DMA并利用DMA的超時傳輸機制。

但有些MCU在設(shè)計時出于成本上的考慮,簡化了串口接收的IDLE模式以及DMA超時傳輸機制。沒有串口IDLE中斷或者DMA超時傳輸?shù)臋C制,我們就不知道什么時候通信結(jié)束了。這種情況下,為了實現(xiàn)通過串口傳輸不定長數(shù)據(jù)包的要求,需要使用軟件和其它片內(nèi)外設(shè)的配合,協(xié)同完成指定的功能。

LPC54101系列的UART模塊,支持FIFO的接收超時,能夠方便地實現(xiàn)上述功能。除此之外,本文介紹一種基于LPC54101和SDK,通過使用引腳中斷和定時器配合,實現(xiàn)串口DMA接收超時,實現(xiàn)串口DMA接收超時的機制。

先分析下UART傳輸?shù)臅r序,圖1是一個典型的8位數(shù)據(jù)位1位停止位的串口通信數(shù)據(jù)流。串口每次發(fā)送數(shù)據(jù)時會首先發(fā)送一個起始位,在TTL電平邏輯下,Start位首先是一個下降沿信號。

了解在MCU中實現(xiàn)串口的不定長數(shù)據(jù)包接收的過程

圖1. 串口接收數(shù)據(jù)時序圖

在串口DMA接收超時系統(tǒng)中,我們需要利用MCU的引腳中斷功能偵測這個下降沿信號,引腳中斷觸發(fā)后告訴系統(tǒng)開始計時。要特別注意的是,當(dāng)系統(tǒng)偵測到Start位的下降沿后最好關(guān)閉引腳中斷,不然后續(xù)數(shù)據(jù)流等信號的下降沿也會觸發(fā)引腳中斷使得整套方案失去了意義(還不如直接用串口接收完成中斷)。

LPC54101的引腳中斷可以在任意IO引腳上使能,所以可以直接把LPC54101的串口接收的引腳的中斷功能打開,并設(shè)置成下降沿觸發(fā)。

超時計數(shù)器最好是系統(tǒng)里的低功耗定時器,這個例程中我們用的是LPC54101的RIT定時器。超時的時間設(shè)置要考慮到當(dāng)前串口設(shè)置的波特率以及一次串口傳輸?shù)淖畲蟀L。

超時定時器計數(shù)溢出產(chǎn)生中斷后,軟件首先要從DMA的狀態(tài)寄存器中獲取到當(dāng)前接收到數(shù)據(jù)的長度(對于LPC54101來說,串口DMA接收數(shù)據(jù)的長度在XFERCFGn寄存器中的XFERCOUNT位,如圖2所示),然后從串口DMA預(yù)設(shè)置的數(shù)據(jù)緩沖區(qū)獲取對應(yīng)的數(shù)據(jù)即可。

了解在MCU中實現(xiàn)串口的不定長數(shù)據(jù)包接收的過程

圖2. LPC54101 DMA傳輸數(shù)據(jù)長度計數(shù)位

在初始化設(shè)置串口對應(yīng)的DMA通道時,最好設(shè)置傳輸長度為可能的最大長度,在接收超時后也別忘記重新復(fù)位一下串口對應(yīng)DMA通道的狀態(tài),不然本次接收的數(shù)據(jù)和數(shù)據(jù)長度還會帶入下次傳輸?shù)倪^程中。

圖3是例程的流程圖,分主程序,串口RX引腳中斷服務(wù)程序,超時定時器服務(wù)程序三個部分。

了解在MCU中實現(xiàn)串口的不定長數(shù)據(jù)包接收的過程

了解在MCU中實現(xiàn)串口的不定長數(shù)據(jù)包接收的過程

了解在MCU中實現(xiàn)串口的不定長數(shù)據(jù)包接收的過程

圖3. 程序流程圖

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

    關(guān)注

    147

    文章

    18934

    瀏覽量

    398511
  • 串口
    +關(guān)注

    關(guān)注

    15

    文章

    1619

    瀏覽量

    82864

原文標(biāo)題:在MCU中,如何實現(xiàn)串口的不定長數(shù)據(jù)包接收?

文章出處:【微信號:mcuworld,微信公眾號:嵌入式資訊精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    CW32R030可以兼容BLE及XN297L數(shù)據(jù)包,請問這個XN297L數(shù)據(jù)包是什么?

    CW32R030可以兼容BLE及XN297L數(shù)據(jù)包,請問這個XN297L數(shù)據(jù)包是什么?
    發(fā)表于 01-20 06:37

    請問CW32L的UART是不是沒有空閑中斷?

    CW32L083的UART是不是沒有空閑中斷?大家一般怎么實現(xiàn)不定長數(shù)據(jù)接收?是串口中斷+定時器嗎?
    發(fā)表于 12-15 07:28

    CW32L052串口數(shù)據(jù)傳輸怎么解決?

    CW32L052串口數(shù)據(jù)傳輸
    發(fā)表于 11-24 07:35

    串口空閑中斷與串口超時中斷介紹

    。 特點 依賴總線物理狀態(tài),而非時間。 常用于檢測不定長數(shù)據(jù)幀的結(jié)束,無需依賴特定結(jié)束符。 應(yīng)用場景 Modbus通信:不定長數(shù)據(jù)包接收
    發(fā)表于 11-21 08:31

    使用nrf54L15的NORDIC藍(lán)牙芯片,通過串口發(fā)送一幀數(shù)據(jù)包時,會出現(xiàn)分包發(fā)送分析

    使用nrf54L15的NORDIC藍(lán)牙芯片,通過串口發(fā)送一幀數(shù)據(jù)包時,會出現(xiàn)分包發(fā)送分析,是什么原因呢
    發(fā)表于 11-17 15:52

    【道生物聯(lián)TKB-623評估板試用】TKB-623評估板雙機通訊測試_程序開發(fā)

    操作即可: 發(fā)送程序設(shè)置完成后,就會自動開始數(shù)據(jù)發(fā)送: 發(fā)送的過程中,接收程序會及時統(tǒng)計收到的數(shù)據(jù)包的情況: 為了模仿丟情況下,
    發(fā)表于 10-18 23:54

    串口DMA接收數(shù)據(jù)包丟失怎么解決?

    RTT串口DMA接收數(shù)據(jù),超過緩沖區(qū)后為什么會吞掉一個數(shù)據(jù)包呢,不能每次處理完后清除緩沖區(qū)數(shù)據(jù)嗎,感覺
    發(fā)表于 09-29 07:50

    求助,關(guān)于串口設(shè)備驅(qū)動fifo問題

    目前在做高頻數(shù)據(jù)采集分析,使用串口設(shè)備驅(qū)動(使用rs485),開啟DMA+空閑中斷,接收不定長數(shù)據(jù),接收
    發(fā)表于 09-12 08:18

    【RA4M2-SENSOR】—— 12.串口接收不定長度數(shù)據(jù)

    U1_Rxlen 計算總共收到了多少個字符; 假如一幀的數(shù)據(jù)接收完成了,那么 U1_Rxlen 變量的值應(yīng)該維持不變。 第一個步驟比較好實現(xiàn),還是
    發(fā)表于 09-01 11:22

    請問DCTCP與DCUDP 的登錄數(shù)據(jù)包和心跳數(shù)據(jù)包與服務(wù)器端是如何交互的?

    DCTCP與DCUDP 的登錄數(shù)據(jù)包和心跳數(shù)據(jù)包與服務(wù)器端是如何交互的?
    發(fā)表于 08-06 06:29

    EZ串行的BLE“無響應(yīng)寫入”, CAN一次通信中接收的最大數(shù)據(jù)包大小是多少?

    :所有數(shù)據(jù)都顯示與 ez-Serial 和 PUART 連接的 TeraTerm 上 [問題] (1) EZ 串行的 BLE“無響應(yīng)寫入”, CAN 一次通信中
    發(fā)表于 07-07 07:33

    藍(lán)牙數(shù)據(jù)通道空口數(shù)據(jù)包

    可以用下面的流程圖來描述上述過程。 ? 編輯 MD(1bit) ,more data,用來指示對方我還有數(shù)據(jù)包要傳,請繼續(xù)打開射頻窗口準(zhǔn)備接收。比如Nordic nRF51822一個connection
    發(fā)表于 06-03 10:51

    【RA-Eco-RA4M2開發(fā)板評測】定時器輔助串口不定長數(shù)據(jù)接收

    assert(status==FSP_SUCCESS); } ??2.定時器輔助串口接收,實現(xiàn)不定長數(shù)據(jù)
    發(fā)表于 04-30 14:44

    當(dāng)從接收DMA一次接收一個字節(jié)時,如何檢查是否已接收到任意長度的所有數(shù)據(jù)包呢?

    當(dāng)從接收 DMA 一次接收一個字節(jié)時,如何檢查是否已接收到任意長度的所有數(shù)據(jù)包?
    發(fā)表于 04-21 08:22

    為UART、MCXA142實現(xiàn)ISP通信的主機端,發(fā)送Ping數(shù)據(jù)包并收到預(yù)期的響應(yīng),發(fā)送和接收數(shù)據(jù)包的典型順序是什么?

    我想為 UART、MCXA142 實現(xiàn) ISP 通信的主機端。我發(fā)送 Ping 數(shù)據(jù)包并收到預(yù)期的響應(yīng)。發(fā)送和接收數(shù)據(jù)包的典型順序是什么? 此刻,我的照片是這樣的: 1. 發(fā)送 Pi
    發(fā)表于 04-03 08:05