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

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

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

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

再談 HPM6700/6400/6300 產(chǎn)品系列串口接收不定長數(shù)據(jù)的方式

先楫半導(dǎo)體HPMicro ? 2023-04-19 09:39 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

概 述

2023年3月底,先楫半導(dǎo)體官方發(fā)布了新的hpm_sdk版本,相比上一次發(fā)布的版本,串口外設(shè)多了一個(gè)uart_hardware_rx_idle的sample。目前,這個(gè)硬件的空閑中斷僅適用于HPM6200系列產(chǎn)品,而HPM6750/6400/6300系列的MCU只能使用 uart_software_rx_idle 通過軟件利用額外的定時(shí)器實(shí)現(xiàn)空閑中斷機(jī)制。

ed855090-da9b-11ed-ad0d-dac502259ad0.png

首先,我們簡單介紹一下以上4個(gè)串口相關(guān)的sample:

(1) uart_dma:此demo 的串口均使用DMA掌管進(jìn)行收發(fā),判斷收發(fā)完成只需要一次DMA傳輸完成中斷,但只能定長收發(fā),適用于固定長度的收發(fā)場(chǎng)景。此demo適用于先楫半導(dǎo)體所有MCU系列產(chǎn)品。

(2) uart_hardware_rx_idle:此demo 使用硬件空閑機(jī)制和DMA接收進(jìn)行接收不定長。適合接收不定長數(shù)據(jù)的場(chǎng)景,但此demo僅適用先楫半導(dǎo)體HPM6200系列MCU產(chǎn)品。

(3)uart_irq:此demo 的串口均使用中斷來進(jìn)行收發(fā),可適用于任何應(yīng)用場(chǎng)景。中斷進(jìn)行接收帶來的一個(gè)問題就是每接收一個(gè)字節(jié)就會(huì)進(jìn)入一次中斷,在數(shù)據(jù)量稍大的場(chǎng)景下會(huì)比較耗費(fèi)中斷次數(shù)。此demo適用于先楫半導(dǎo)體所有MCU系列產(chǎn)品。

(4)uart_software_rx_idle:此demo需要定時(shí)器的兩個(gè)通道,并且互聯(lián)到一個(gè)IO,這個(gè)IO需要接到串口的RX引腳。一個(gè)通道作為捕獲RX引腳下降沿以此判斷開始接收,另一個(gè)通道作為同步輸入SYNC(觸發(fā)會(huì)重置計(jì)數(shù)器)以此來判斷接收完成。利用定時(shí)器來實(shí)現(xiàn)空閑機(jī)制實(shí)現(xiàn)接收不定長數(shù)據(jù)。在資源利用不緊張的情況下可以選擇使用此demo,因?yàn)槊總€(gè)串口都需要定時(shí)器的兩個(gè)通道作為輔助外設(shè)。此demo適用于先楫半導(dǎo)體所有MCU系列產(chǎn)品。

對(duì)于某些應(yīng)用場(chǎng)合,比如接收不定長數(shù)據(jù),有硬件空閑中斷的支持,可以再配合DMA,用最小的中斷損耗(只需要一次中斷)以及最少的外設(shè)輔助(不需要定時(shí)器查詢)實(shí)現(xiàn)接收不定長數(shù)據(jù)。


本文將探討一種利用串口FIFO接收超時(shí)機(jī)制而不依賴額外定時(shí)器在HPM6700/6400/6300 產(chǎn)品系列上實(shí)現(xiàn)串口不定長數(shù)據(jù)接收。

實(shí)現(xiàn)方案

先楫半導(dǎo)體 HPM6700/6400/6300 產(chǎn)品系列串口特性如下:

ed989c22-da9b-11ed-ad0d-dac502259ad0.png


先楫半導(dǎo)體所有產(chǎn)品系列的串口 FIFO都支持閾值觸發(fā)中斷,也就是FIFO存儲(chǔ)到多少個(gè)字節(jié)認(rèn)為一次有效數(shù)據(jù)進(jìn)而觸發(fā)中斷。這樣可以大大減少觸發(fā)中斷的次數(shù),有了FIFO閾值中斷,就可以在進(jìn)入中斷后,一次性把FIFO的所有數(shù)據(jù)取出來。


開發(fā)者可以在SDK中找到詳細(xì)描述閾值范圍的內(nèi)容:

接收觸發(fā)閾值為 0 (uart_rx_fifo_trg_not_empty):代表RX FIFO不為空就一次觸發(fā)中斷。

接收觸發(fā)閾值為 1 (uart_rx_fifo_trg_gt_one_quarter):代表RX FIFO接收到超過FIFO的四分之一就觸發(fā)一次中斷。

接收觸發(fā)閾值為 2 (uart_rx_fifo_trg_gt_half):代表RX FIFO接收到超過FIFO的一半就觸發(fā)一次中斷。

接收觸發(fā)閾值為 3 (uart_rx_fifo_trg_gt_three_quarters):代表RX FIFO接收到超過FIFO的四分之三就觸發(fā)一次中斷。

edaf6a42-da9b-11ed-ad0d-dac502259ad0.png

有了FIFO閾值設(shè)置,先楫半導(dǎo)體MCU產(chǎn)品的串口還具備了FIFO timeout 的中斷。

edca7bf2-da9b-11ed-ad0d-dac502259ad0.png

產(chǎn)生中斷需要同時(shí)具備以下條件

① 需要使能FIFO;

② RXFIFO里面需要存在至少一個(gè)字符;

③ RXFIFO在四個(gè)字符的時(shí)間再也沒有收到新的字符。

結(jié)合以上特點(diǎn)可知,當(dāng)接收閾值產(chǎn)生中斷的時(shí)候,系統(tǒng)能夠把接收到的數(shù)據(jù)從FIFO提取出來;當(dāng)FIFO timeout中斷觸發(fā)時(shí),系統(tǒng)能夠在最后把接收的數(shù)據(jù)從FIFO提取出來。通過這種方式來實(shí)現(xiàn)一幀不定長數(shù)據(jù)的接收。


此外,開發(fā)者可以結(jié)合以下特征以及自己的應(yīng)用開發(fā)需求來決定是否采用此方案:


相比單個(gè)字節(jié)接收,接收中斷次數(shù)能減少10倍以上。比如接收1000個(gè)字節(jié),單個(gè)字節(jié)接收需要進(jìn)入1000次中斷,而使用rx fifo閾值+fifo超時(shí)機(jī)制,只需要進(jìn)入77次,相比減少12倍以上中斷次數(shù)。

接收閾值中斷和超時(shí)中斷是一起使能觸發(fā)的。

使用這種方式的話,接收無法配合DMA,但是發(fā)送可以使用DMA。

超時(shí)條件是四個(gè)字符時(shí)間。也就是在四個(gè)字符時(shí)間沒收到新數(shù)據(jù),則判斷超時(shí)。

方案驗(yàn)證

結(jié)合以上的論述,我們開發(fā)一個(gè)sample進(jìn)行驗(yàn)證。接收使用RX FIFO 和 FIFO timeout方式,發(fā)送則使用DMA。使用100到1000字節(jié)隨機(jī)幾組進(jìn)行驗(yàn)證接收的中斷次數(shù)。

對(duì)于RX FIFO 和 FIFO timeout方式,代碼配置如下:

ede397f4-da9b-11ed-ad0d-dac502259ad0.png

中斷進(jìn)行提取FIFO的數(shù)據(jù):

ee029a46-da9b-11ed-ad0d-dac502259ad0.png

實(shí)驗(yàn)現(xiàn)象

通過本次實(shí)驗(yàn)結(jié)果可見相對(duì)于中斷方式接收,采用本文提到的方案可以顯著減少中斷次數(shù)。本法在進(jìn)行不定長大數(shù)據(jù)量傳輸?shù)膱?chǎng)景下尤為有利,假設(shè)接收1000個(gè)字節(jié),單個(gè)字節(jié)中斷需要產(chǎn)生1000次中斷,而本文提到的方案在不使用其他額外定時(shí)器的條件下,只需要77次中斷就可完成傳輸。

ee2b5936-da9b-11ed-ad0d-dac502259ad0.png

以上是針對(duì)先楫半導(dǎo)體HPM6700/6400/6300這三個(gè)系列的MCU產(chǎn)品操作串口外設(shè)的一種方式的介紹。在實(shí)際操作過程中,希望能帶給各位開發(fā)者一點(diǎn)啟發(fā)。

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

    關(guān)注

    339

    文章

    31238

    瀏覽量

    266563
  • 數(shù)據(jù)
    +關(guān)注

    關(guān)注

    8

    文章

    7349

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    Banana Pi開源社區(qū)開源產(chǎn)品系列規(guī)格(2026年產(chǎn)品畫冊(cè))

    Banana Pi開源社區(qū)開源產(chǎn)品系列規(guī)格(2026年產(chǎn)品畫冊(cè))
    的頭像 發(fā)表于 03-31 09:10 ?723次閱讀
    Banana Pi開源社區(qū)開源<b class='flag-5'>產(chǎn)品系列</b>規(guī)格(2026年<b class='flag-5'>產(chǎn)品</b>畫冊(cè))

    長晶科技達(dá)林頓陣列產(chǎn)品系列特性與應(yīng)用解析

    主要產(chǎn)品,對(duì)該系列器件做一個(gè)簡要介紹。產(chǎn)品系列長晶科技的達(dá)林頓陣列產(chǎn)品線較為豐富,主要包括以下幾個(gè)型號(hào):PartNumberVOUT(V)IOUT(mA)VI(on)(
    的頭像 發(fā)表于 03-20 17:04 ?213次閱讀
    長晶科技達(dá)林頓陣列<b class='flag-5'>產(chǎn)品系列</b>特性與應(yīng)用解析

    為什么串口接收數(shù)據(jù)就會(huì)觸發(fā)中斷呢?

    為什么串口接收數(shù)據(jù)就會(huì)觸發(fā)中斷呢? 串口接收喚醒機(jī)制有哪些注意事項(xiàng)?
    發(fā)表于 01-08 06:45

    LT6700/LT6700HV:低功耗雙比較器的卓越之選

    ,看看它在實(shí)際應(yīng)用中能為我們帶來哪些優(yōu)勢(shì)。 文件下載: LT6700.pdf 產(chǎn)品概述 LT6700/LT6700HV將兩個(gè)微功耗、低電壓比較器與一個(gè)400mV參考電壓集成在一個(gè)6引腳
    的頭像 發(fā)表于 01-07 15:25 ?335次閱讀

    請(qǐng)問CW32L的UART是不是沒有空閑中斷?

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

    串口空閑中斷與串口超時(shí)中斷介紹

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

    串口通信有哪些方式

    串口通信(Serial Communication)是一種通過串行方式逐位傳輸數(shù)據(jù)的通信方式,廣泛應(yīng)用于嵌入式系統(tǒng)、工業(yè)控制、儀器儀表等領(lǐng)域。其通信
    的頭像 發(fā)表于 09-28 18:02 ?1299次閱讀

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

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

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

    ;, U1_RxBuff);//打印收到的數(shù)據(jù) user_uart_clear();//清空接收緩沖區(qū) } HAL_Delay(10); } 編譯代碼,燒錄到板子 打開串口助手 發(fā)送
    發(fā)表于 09-01 11:22

    先楫半導(dǎo)體高性能MCU入駐立創(chuàng)商城,國產(chǎn)芯勢(shì)力再添新動(dòng)能

    HPM6E00、HPM5300、HPM6700系列明星產(chǎn)品線及其開發(fā)板,主頻最高達(dá)816GHz,集成EtherCAT工業(yè)總線、高精度PWM
    的頭像 發(fā)表于 07-31 08:32 ?1396次閱讀
    先楫半導(dǎo)體高性能MCU入駐立創(chuàng)商城,國產(chǎn)芯勢(shì)力再添新動(dòng)能

    STM32407使用串口閑時(shí)中斷+DMA方式接收最大接收字節(jié)是多少?

    使用串口閑時(shí)中斷+DMA方式接收數(shù)據(jù),波特率為460800,DMA接收長度為1024個(gè)字節(jié),并開啟串口
    發(fā)表于 07-22 08:16

    支持HPM6P00/HPM5E00系列!HPMicro Manufacturing Tool v0.6.0發(fā)布

    HPM6P00、HPM5E00系列SoC的燒寫及其它操作,新增HPM6E00、HPM5E00固件;新增verify-checksum及que
    的頭像 發(fā)表于 06-04 08:28 ?2699次閱讀
    支持<b class='flag-5'>HPM</b>6P00/<b class='flag-5'>HPM</b>5E00<b class='flag-5'>系列</b>!HPMicro Manufacturing Tool v0.6.0發(fā)布

    易飛揚(yáng)低延遲光模塊產(chǎn)品系列為客戶帶來納秒使用價(jià)值

    為滿足數(shù)據(jù)中心及高性能計(jì)算場(chǎng)景對(duì)超低延遲、高可靠性的迫切需求,易飛揚(yáng)正式推出全新低延遲光模塊產(chǎn)品系列。該系列產(chǎn)品通過優(yōu)化光學(xué)性能與信號(hào)處理技術(shù),實(shí)現(xiàn)在無需前向糾錯(cuò)(FEC)的條件下達(dá)到極低誤碼率,顯著降低鏈路傳輸延遲,為金融交易
    的頭像 發(fā)表于 05-21 15:05 ?950次閱讀
    易飛揚(yáng)低延遲光模塊<b class='flag-5'>產(chǎn)品系列</b>為客戶帶來納秒使用價(jià)值

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

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