色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

UART:了解通用異步接收器/發射器的硬件通信協議

星星科技指導員 ? 來源:ADI ? 作者:Eric Peňa and Mary G ? 2022-12-16 15:42 ? 次閱讀

作者:Eric Peňa and Mary Grace Legaspi

UART或通用異步接收器-發射器是最常用的設備到設備通信協議之一。本文介紹如何按照標準過程將 UART 用作硬件通信協議。

正確配置后,UART可以使用許多不同類型的串行協議,這些協議涉及發送和接收串行數據。在串行通信中,數據使用單線或電線逐位傳輸。在雙向通信中,我們使用兩條線進行成功的串行數據傳輸。根據應用和系統要求,串行通信需要較少的電路和電線,從而降低了實施成本。

在本文中,我們將討論使用 UART 時的基本原則,重點是數據包傳輸、標準幀協議和自定義幀協議,這些協議在實現時(尤其是在代碼開發期間)是安全合規性的增值功能。在產品開發過程中,本文檔還旨在分享在檢查數據手冊的實際使用情況時的一些基本步驟。

在文章的最后,目標是更好地理解和遵守UART標準,以最大限度地提高功能和應用,特別是在開發新產品時。

“溝通中最大的一個問題是它已經發生的錯覺。
——蕭伯納

通信協議在組織設備之間的通信方面起著重要作用。它根據系統要求以不同的方式設計,并且這些協議具有設備之間商定的特定規則以實現成功的通信。

嵌入式系統微控制器和計算機大多使用UART作為設備到設備硬件通信協議的一種形式。在可用的通信協議中,UART僅使用兩根電線作為其發送端和接收端。

盡管它是一種廣泛使用的硬件通信協議方法,但它并沒有一直完全優化。在微控制器內部使用UART模塊時,通常會忽略幀協議的正確實現。

根據定義,UART是一種硬件通信協議,它使用具有可配置速度的異步串行通信。異步意味著沒有時鐘信號來同步從發送設備到接收端的輸出位。

接口

335962-fig-01.svg?h=270&hash=B065CFBC64504A18E932D2B8A4FA62EF&imgver=1

圖1.兩個UART直接相互通信。

每個UART設備的兩個信號被命名為:

發射器(發射)

接收器(接收)

每個設備的發射器和接收器線的主要目的是發送和接收用于串行通信的串行數據。

335962-fig-02.svg?h=270&hash=822F6D4489C5A7B5EA8209D4139D5955&imgver=1

圖2.帶數據總線的UART。

發送UART連接到以并行形式發送數據的控制數據總線。由此,數據現在將在傳輸線(線)上串行地一點一點地傳輸到接收UART。反過來,這將把串行數據轉換為接收設備的并行數據。

UART線路用作向另一個數據發送和接收數據的通信介質。請注意,UART設備具有專用于發送或接收的發送和接收引腳。

對于UART和大多數串行通信,需要在發送和接收設備上設置相同的波特率。波特率是信息傳輸到通信通道的速率。在串行端口上下文中,設置的波特率將用作每秒要傳輸的最大位數。

表1總結了我們必須了解的有關UART的知識。

電線 2
速度 9600, 19200, 38400, 57600, 115200, 230400, 460800, 921600, 1000000, 1500000
傳輸方法 異步
最大母版數量 1
最大從屬數量 1

UART接口不使用時鐘信號來同步發射器和接收器設備;它異步傳輸數據。發射器不是時鐘信號,而是基于其時鐘信號生成比特流,而接收器則使用其內部時鐘信號對傳入數據進行采樣。通過在兩個設備上具有相同的波特率來管理同步點。否則可能會影響發送和接收數據的時間,從而導致數據處理過程中出現差異。波特率的允許差異高達10%,在位的時序偏離太遠之前。

數據傳輸

在UART中,傳輸模式是數據包的形式。連接發射器和接收器的部分包括創建串行數據包并控制這些物理硬件線路。數據包由起始位、數據幀、奇偶校驗位和停止位組成。

335962-fig-03.svg?h=270&hash=1CB514C169E8D354B2D74F94776ADF96&imgver=2

圖3.UART 數據包。

起始位

UART數據傳輸線在不傳輸數據時通常保持在高電壓電平。為了開始數據傳輸,發射UART將傳輸線從高到低拉一(1)個時鐘周期。當接收UART檢測到高低壓轉換時,它開始以波特率的頻率讀取數據幀中的位。

pYYBAGOcIW-AOJXmAAAuynpVHXA321.jpg?h=270&hash=B99B0DFBC02B1141BEE6EACF6C88380D&imgver=1

圖4.起始位。

數據框

數據框包含正在傳輸的實際數據。如果使用奇偶校驗位,它可以是五 (5) 位,最多八 (8) 位長。如果未使用奇偶校驗位,則數據幀的長度可以是九 (9) 位。在大多數情況下,數據首先以最低有效位發送。

pYYBAGOcIXCASytAAAAw1bAxxJE290.jpg?h=270&hash=EADAED6D03BE96EB6080B8E052563847&imgver=1

圖5.數據框。

平價

奇偶校驗描述了一個數字的偶數或奇數。奇偶校驗位是接收UART判斷傳輸過程中是否有任何數據更改的一種方式。位可以通過電磁輻射、不匹配的波特率或長距離數據傳輸來改變。

接收UART讀取數據幀后,計算值為1的位數,并檢查總數是偶數還是奇數。如果奇偶校驗位為 0(偶數奇偶校驗),則數據幀中的 1 或邏輯高位的總和應為偶數。如果奇偶校驗位為 1(奇偶校驗),則數據框中的 1 位或邏輯高電平之和應為奇數。

當奇偶校驗位與數據匹配時,UART知道傳輸沒有錯誤。但是,如果奇偶校驗位為 0,并且總數為奇數,或者奇偶校驗位為 1,并且總數為偶數,則 UART 知道數據框中的位已更改。

pYYBAGOcIXGAM4SMAAAyqJWwPNE525.jpg?h=270&hash=F48BD4EF4118E5700C1B0D3685E641DF&imgver=1

圖6.奇偶校驗位。

停止位

為了發出數據包結束的信號,發送UART將數據傳輸線從低壓驅動到高壓,持續時間為一(1)到兩(2)位。

poYBAGOcIXKABTIjAAAxHbQJSjc467.jpg?h=270&hash=EC67F1307838CD967CEEE21BC59DCF77&imgver=1

圖7.停止位。

UART傳輸的步驟

第一:發送UART從數據總線并行接收數據。

335962-fig-08.svg?h=270&hash=AE1B03A0ECF42204722E9B12E71E3B5F&imgver=1

圖8.數據總線到發送UART。

第二:發送UART將起始位、奇偶校驗位和停止位添加到數據幀中。

335962-fig-09.svg?h=270&hash=8A06FEFF66A90D6C7A06B46CCF25CD93&imgver=1

圖9.Tx 側的 UART 數據幀。

第三:整個數據包從起始位到停止位從發送UART串行發送到接收UART。接收UART以預配置的波特率對數據線進行采樣。

335962-fig-10.svg?h=270&hash=04C8F78353D058A8B950BF323132CC0B&imgver=1

圖 10.UART傳輸。

第四:接收UART丟棄數據框中的起始位、奇偶校驗位和停止位。

335962-fig-11.svg?h=270&hash=B4EDA2D982611DD36FF1F969D4E527C1&imgver=1

圖 11.接收端的 UART 數據框。

第五:接收UART將串行數據轉換回并行數據,并將其傳輸到接收端的數據總線。

335962-fig-12.svg?h=270&hash=BB9680F74E40C33B4E7FBD0D1F4EC1E9&imgver=1

圖 12.接收UART到數據總線。

幀協議

UART中可用但尚未完全使用的一個關鍵功能是幀協議的實現。這樣做的主要用途和重要性是為每個設備的安全性和保護增加值。

例如,當兩個設備使用相同的UART幀協議時,有一種趨勢是,當連接到同一UART而不檢查配置時,設備將連接到可能導致系統故障的不同引腳。

另一方面,實現這一點可確保安全性,因為需要根據設計框架協議解析收到的信息。每個幀協議都經過專門設計,具有唯一性和安全性。

在設計幀協議時,設計人員可以為不同的設備設置所需的標頭和尾部,包括CRC。在圖 13 中,將兩 (2) 個字節設置為標頭的一部分。

第二:在內存映射下,檢查UART地址。

pYYBAGOcIXSAdEl1AAA9QIKxEpc137.jpg?h=270&hash=46B34F9D8C7489357286DDB747D812F7&imgver=1

圖 13.示例 UART 幀協議。

根據示例,可以設置設備唯一的標頭、尾部和 CRC。

標頭 1(H1 為 0xAB)和標頭 2(H2 為 0xCD)

標頭是確定您是否與正確的設備通信的唯一標識符。

命令 (CMD) 選擇

命令將取決于旨在創建兩個設備之間通信的命令列表。

每個命令的數據長度 (DL)

數據長度將基于所選的命令。您可以根據所選命令最大化數據長度,因此數據長度會因選擇而異。在這種情況下,可以調整數據長度。

數據 n(可變數據)

數據是要從設備傳輸的有效負載。

拖車 1(T1 為 0xE1)和拖車 2(T2 為 0xE2)

拖車是在傳輸結束后添加的數據。就像標頭一樣,它們可以被唯一標識。

循環冗余校驗(CRC公式)

循環冗余檢查公式是一種附加的錯誤檢測模式,用于檢測對原始數據的意外更改。發射設備的CRC值必須始終等于接收端的CRC計算。

建議通過為每個UART設備實現幀協議來增加安全性。幀協議在發送和接收設備上需要相同的配置。

UART操作

使用任何硬件通信協議時,查看數據手冊和硬件參考手冊是先決條件。

以下是要遵循的步驟:

首先:檢查器件的數據手冊接口。

poYBAGOcIXeAWSamAAFGUDzQ_I4350.jpg?h=270&hash=51B6ED0F48C19EF1F96CEF6632FBBD71&imgver=1

圖 15.微控制器內存圖。

第三:檢查UART端口的具體細節,如操作模式、數據位長度、奇偶校驗位和停止位。數據表中的示例UART端口詳細信息:UART端口

示例MCU提供全雙工UART端口,該端口與PC標準UART完全兼容。UART 端口為其他外設或主機提供簡化的 UART 接口,支持串行數據的全雙工、DMA 和異步傳輸。UART 端口包括對 5 到 8 個數據位的支持,以及無奇偶校驗、偶數奇偶校驗或奇偶校驗。幀終止一個半或兩個停止位。

第四:檢查UART操作細節,包括波特率計算。波特率使用以下示例公式進行配置。此公式因微控制器而異。

UART 操作的示例詳細信息:

5 至 8 個數據位

1、2 或 1 和 1/2 停止位

無,偶數或奇偶校驗

編程過采樣率 4、8、16、32

波特率 = PCLK/((M + N/2048) × 2OSR + 2×

哪里

OSR(過采樣率)

UART_LCR2。OSR = 0 到 3

DIV(波特率分頻器)

UART_DIV = 1 到 65535

M (DIVM 分數波特率 M)

UART_FBR。DIVM = 1 到 3

N(DIVM 分數波特率 M)

UART_FBR。DIVN = 0 到 2047

第五:對于波特率,請務必檢查要使用的外設時鐘(PCLK)。在本例中,有一個 26 MHz PCLK 和 16 MHz PCLK 可用。請注意,OSR、DIV、DIVM 和 DIVN 因設備而異。

波特率 OSR DIV 迪姆 迪文
9600 3 24 3 1078
115200 3 4 1 1563
波特率 OSR DIV 迪姆 迪文
9600 3 17 3 1078
115200 3 2 2 348

第六:下一部分是檢查UART配置的詳細寄存器。查看計算波特率的參數,例如UART_LCR2、UART_DIV和UART_FBR。表4將引出一個特定的寄存器來覆蓋。

名字 描述
UART_DIV 波特率分頻器
UART_FIBR 分數波特率
UART_LCR2 二線控制

第七:在每個寄存器下,檢查詳細信息并替換值以計算波特率,然后開始實施UART。

為什么它很重要?

在開發穩健、質量驅動的產品時,熟悉UART通信協議是有利的。了解如何僅使用兩條線發送數據,以及如何傳輸整個數據包或有效載荷,將有助于確保數據傳輸和接收無誤。由于UART是最常用的硬件通信協議,因此這些知識可以在未來的設計中實現設計靈活性。

使用案例

您可以將UART用于許多應用程序,例如:

調試:在開發過程中及早檢測系統錯誤非常重要。在這種情況下,添加 UART 可以通過從系統捕獲消息來幫助。

制造功能級跟蹤:日志在制造中非常重要。它們通過提醒操作員生產線上發生的情況來確定功能。

客戶或客戶端更新:軟件更新非常重要。擁有完整的動態硬件和支持更新的軟件對于擁有完整的系統非常重要。

測試/驗證:在產品離開制造過程之前對其進行驗證有助于向客戶提供最優質的產品。

審核編輯:郭婷

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

    關注

    14

    文章

    2473

    瀏覽量

    71988
  • 發射器
    +關注

    關注

    6

    文章

    849

    瀏覽量

    53510
  • uart
    +關注

    關注

    22

    文章

    1240

    瀏覽量

    101488
收藏 人收藏

    評論

    相關推薦

    UART了解通用異步接收器/發送硬件通信協議

    通信協議在組織設備之間的通信時扮演著重要角色。它基于系統要求而以不同方式進行設計。此類協議具有特定的規則,為實現成功通信,不同設備都遵循該規則。
    發表于 05-14 14:32 ?3189次閱讀
    <b class='flag-5'>UART</b>:<b class='flag-5'>了解</b><b class='flag-5'>通用</b><b class='flag-5'>異步</b><b class='flag-5'>接收器</b>/發送<b class='flag-5'>器</b>的<b class='flag-5'>硬件</b><b class='flag-5'>通信協議</b>

    發射器接收器及其特性介紹

    了解發射器接收器及其特性
    發表于 06-19 10:53

    通用異步接收器/發送UART

    在世界范圍內,幾乎沒有電氣工程師和電子愛好者中很少有人沒有與通用異步接收器/發送UART)接口進行交互。在當今技術迅速淘汰的世界中,我們
    發表于 09-18 09:00

    通用異步接收器/發送UART

    在世界范圍內,幾乎沒有電氣工程師和電子愛好者中很少有人沒有與通用異步接收器/發送UART)接口進行交互。在當今技術迅速淘汰的世界中,我們
    發表于 09-25 17:43

    通用異步收發傳輸UART串口通信協議有哪些特性呢

    什么是通用異步收發傳輸UART呢?通用異步收發傳輸
    發表于 11-01 07:03

    單片機常用的通信協議有哪些

    要求的不同,也產生了許多類型的適用于不同情況的通信協議,并被廣泛的接受和使用。其實使用率最高的主要有以下幾種:一、UART和USART分別名為通用異步收發
    發表于 11-18 06:57

    單片機常用的通信協議有哪幾種呢

    要求的不同,也產生了許多類型的適用于不同情況的通信協議,并被廣泛的接受和使用。其實使用率最高的主要有以下幾種:  一、UART和USART  分別名為通用異步收發
    發表于 12-02 06:52

    基于射頻/無線系統的發射器接收器的基本測試

    射頻/無線系統會同時包含一個發射器接收器分別用于發送和接收信號。我們先介紹發射器的基本測試,接下來再介紹接收器的基本測試。
    發表于 11-24 16:12 ?7875次閱讀

    通用異步收發UART的工作原理及協議格式

    通用異步收發(Universal Asynchronous Receiver/Transmitter),通常稱作UART,是一種串行、異步
    發表于 06-18 10:22 ?2137次閱讀

    討論使用UART通信協議的基本原則

    UART,即通用異步接收器/發送,是最常用的設備間通信協議之一,正確配置后,
    的頭像 發表于 02-01 17:54 ?1070次閱讀

    UART通信協議的工作原理

    通用異步接收器/發射器,通常稱為UART,是一種串行,異步,全雙工
    的頭像 發表于 03-23 14:24 ?2736次閱讀
    <b class='flag-5'>UART</b><b class='flag-5'>通信協議</b>的工作原理

    【世說知識】一文搞懂UART通信協議

    UART,即通用異步接收器/發送,是最常用的設備間通信協議之一,正確配置后,
    的頭像 發表于 02-02 10:46 ?2228次閱讀
    【世說知識】一文搞懂<b class='flag-5'>UART</b><b class='flag-5'>通信協議</b>

    微控制通信協議UART技術

    ART代表通用異步接收器和發送。同步協議具有獨立的時鐘和數據線路,時鐘線路用于觸發數據線的讀取(或寫入)。
    發表于 11-27 16:05 ?1443次閱讀
    微控制<b class='flag-5'>器</b><b class='flag-5'>通信協議</b>之<b class='flag-5'>UART</b>技術

    TL28L92 3.3V/5V雙通道通用異步接收器/發射器數據表

    電子發燒友網站提供《TL28L92 3.3V/5V雙通道通用異步接收器/發射器數據表.pdf》資料免費下載
    發表于 07-09 09:34 ?0次下載
    TL28L92 3.3V/5V雙通道<b class='flag-5'>通用</b><b class='flag-5'>異步</b><b class='flag-5'>接收器</b>/<b class='flag-5'>發射器</b>數據表

    簡單認識UART通信協議

    UART(Universal Asynchronous Receiver/Transmitter,通用異步收發傳輸通信協議是一種常見的串
    的頭像 發表于 07-25 18:07 ?1489次閱讀
    主站蜘蛛池模板: 久久久久毛片免费观看| 亚洲午夜精品A片久久软件| 亚洲精品久久久久久偷窥| 91区国产福利在线观看午夜| 国产极品白嫩超清在线观看| 绿巨人www在线观看| 色视频色露露永久免费观看| 最近的2019中文字幕国语HD| 国产精品私人玩物在线观看 | 考试考90就可以晚上和老师C| 日韩欧美精品有码在线播放免费| 印度12 13free| 国产精品免费小视频| 女性BBWBBWBBWBBW| 伊人亚洲AV久久无码精品| 国产高潮久久精品AV无码| 欧美精品熟妇乱| 渔夫床满艳史bd高清在线直播| 国产精品VIDEOSSEX久久发布| 蜜臀AV精品久久无码99| 小夫妻天天恶战| 超碰免费视频公开观看| 美女gif趴跪式动态图| 亚洲日本欧美国产在线视| 国产av久久免费观看| 欧美一区二区三区男同| 中国成人在线视频| 黄色网址在线免费观看| 天天综合网网欲色| 成人免费一级毛片在线播放视频| 美女xx00| 瑜伽牲交AV| 精品无码久久久久久久动漫| 午夜精品久久久久久久99蜜桃| 成在线人免费视频| 欧美日韩视频一区二区三区| 2022精品福利在线小视频| 久久精品成人免费网站| 亚洲色噜噜狠狠站欲八| 国产人妻精品无码AV在线五十路| 少妇两个奶头喷出奶水了怎么办|