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

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

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

我猜你還不會UART!不信你點(diǎn)進(jìn)來看看

FPGA之家 ? 來源:小麥大叔 ? 作者:小麥大叔 ? 2021-06-01 11:09 ? 次閱讀

1 UART發(fā)展歷史1.1 早期的串行通訊設(shè)備早期的電報(bào)機(jī)器使用長度可變的脈沖信號進(jìn)行數(shù)據(jù)傳輸,比如摩斯電碼;

970a7114-c238-11eb-9e57-12bb97331649.png

摩斯電碼

后來電傳打印機(jī)(teleprinters )普遍使用5、6、7或8個數(shù)據(jù)位來表示各種字符編碼,最終成為計(jì)算機(jī)外圍設(shè)備。電傳打字機(jī)( teletypewriter 簡稱 tty)成為小型計(jì)算機(jī)十分出色的通用I/O設(shè)備。

Teletypewritter

由于歷史的發(fā)展原因,早期在Unix終端是一個名字為ASR33的電傳打字機(jī),而電傳打字機(jī)的英文單詞為Teletype(或Teletypewritter),縮寫為tty。因此,終端設(shè)備也被稱為tty設(shè)備。這就是TTY這個名稱的來源。

1.2 早期的芯片級UARTDEC(Digital Equipment Corporation)公司的Gordon Bell 為該公司的PDP系列計(jì)算機(jī)設(shè)計(jì)了第一個UART,不過體積龐大,UART的線路占據(jù)了整個電路板;

后來DEC將串行線路單元的設(shè)計(jì)濃縮為早期的UART單芯片,以方便自己使用。

DEC是美國一家計(jì)算機(jī)公司;

西部數(shù)據(jù)(Western Digital)公司在1971年左右將其開發(fā)為第一個廣泛可用的UART單芯片 WD1402A。這是中型集成電路的早期產(chǎn)品。

Western Digital是美國計(jì)算機(jī)硬盤驅(qū)動器制造商和數(shù)據(jù)存儲公司。

1.3 現(xiàn)代UART的發(fā)展2000年代開始,大多數(shù)IBM或者相關(guān)的計(jì)算機(jī)都刪除了其外部RS232的COM端口,將其替換為帶寬性能更加出色的USB端口;

對于仍然需要RS-232串行COM端口的用戶,現(xiàn)在通常使用外部USB轉(zhuǎn)UART轉(zhuǎn)換器,常見的有CH340,Silicon Labs 210x的驅(qū)動程序,現(xiàn)在很多處理器和芯片都內(nèi)置了UART。

2 預(yù)備知識通用異步收發(fā)傳輸器(Universal Asynchronous Receiver/Transmitter,通常稱為UART),在UART通信中,兩個UART直接通信。

發(fā)送端的UART將來自控制設(shè)備(如CPU)的并行數(shù)據(jù)轉(zhuǎn)換為串行數(shù)據(jù),以串行方式將其發(fā)送到接收端的UART,然后由接收端的UART將串行數(shù)據(jù)轉(zhuǎn)換為并行數(shù)據(jù)以用于接收設(shè)備的正常處理。

這里只需要兩條線RX/TX即可在兩個UART之間傳輸數(shù)據(jù)。具體如下圖所示;

97372e48-c238-11eb-9e57-12bb97331649.png

3 協(xié)議層UART傳輸?shù)臄?shù)據(jù)被封裝成數(shù)據(jù)包。每個數(shù)據(jù)包包含1個起始位,5~9個數(shù)據(jù)位(取決于UART的具體設(shè)置),一個可選的奇偶校驗(yàn)位以及1個或2個停止位,具體如下圖所示;

97433314-c238-11eb-9e57-12bb97331649.png

協(xié)議格式

起始位UART數(shù)據(jù)傳輸線通常在不傳輸數(shù)據(jù)時保持在高電平。

為了開始數(shù)據(jù)傳輸,發(fā)送端UART在一個時鐘周期內(nèi)將傳輸線從高電平拉低到低電平。

當(dāng)接收端UART檢測到高電壓到低電壓轉(zhuǎn)換時,它開始以波特率的頻率讀取數(shù)據(jù)位中的每一位數(shù)據(jù)。

數(shù)據(jù)數(shù)據(jù)位包含正在傳輸?shù)膶?shí)際數(shù)據(jù)。如果使用奇偶校驗(yàn)位,則可以是5位,最多8位。如果不使用奇偶校驗(yàn)位,則數(shù)據(jù)幀的長度可以為9位。

在大多數(shù)情況下,數(shù)據(jù)首先以低有效位發(fā)送。

校驗(yàn)位在串口通信中一種簡單的檢錯方式。

有四種檢錯方式:偶校驗(yàn)、奇校驗(yàn)、高校驗(yàn)和低校驗(yàn)。當(dāng)然沒有校驗(yàn)位也是可以的。

對于偶和奇校驗(yàn)的情況,串口會設(shè)置校驗(yàn)位(數(shù)據(jù)位后面的一位),用一個值確保傳輸?shù)臄?shù)據(jù)有偶個或者奇?zhèn)€邏輯高位。

舉個例子,如果數(shù)據(jù)是011,則滿足;

偶校驗(yàn),校驗(yàn)位為0,保證邏輯高的位數(shù)是偶數(shù)個。

奇校驗(yàn),校驗(yàn)位為1,這樣就有3個邏輯高位。

具體如下圖所示;

976882c2-c238-11eb-9e57-12bb97331649.png

奇校驗(yàn)和偶校驗(yàn)

高位和低位不是真正的檢查數(shù)據(jù),而是強(qiáng)行將校驗(yàn)位設(shè)置為邏輯高或者邏輯低。這樣使得接收設(shè)備能夠知道一個位的狀態(tài),有機(jī)會判斷是否有噪聲干擾了通信或者是否傳輸和接收數(shù)據(jù)是否不同步。

停止位發(fā)送端UART將數(shù)據(jù)傳輸線從低電壓驅(qū)動到高電壓至少持續(xù)兩位數(shù)據(jù)的時間寬度來表示整個數(shù)據(jù)包的傳輸已經(jīng)結(jié)束。

由于數(shù)據(jù)是在傳輸線上定時的,并且每一個設(shè)備有其自己的時鐘,很可能在通信中兩臺設(shè)備間出現(xiàn)了小小的不同步。因此停止位不僅僅是表示傳輸?shù)慕Y(jié)束,并且提供計(jì)算機(jī)校正時鐘同步的機(jī)會。適用于停止位的位數(shù)越多,不同時鐘同步的容錯性越好,但是數(shù)據(jù)傳輸率同時也越慢。

波特率波特率是串口數(shù)據(jù)的傳輸速度,即Bit/s,常見的波特率有:9600,19200,38400,57600,115200,當(dāng)然還有很多波特率,不再一一給出;

假設(shè)目前UART的配置為,1個起始位,8個數(shù)據(jù)位,0個校驗(yàn)位,1個停止位,那么9600的波特率,可以計(jì)算出每一位數(shù)據(jù)的時間寬度為:

那么傳輸一個字節(jié)(也就是10 bit 數(shù)據(jù))需要的時間為 1.04 毫秒。

下面用串口抓取了UART的TX上的信號,其中一位數(shù)據(jù)的時間寬度為26微秒,具體如下圖所示;

983f9460-c238-11eb-9e57-12bb97331649.jpg

則可以簡單計(jì)算得到;

因此波特率大概為 38400;

下表是各個波特率下數(shù)據(jù)位時間寬度;

o4YBAGC1pSmAQyeXAAAnV8xR1vQ153.png

4 傳輸過程發(fā)送端UART從數(shù)據(jù)總線轉(zhuǎn)換并行數(shù)據(jù):

984a9e5a-c238-11eb-9e57-12bb97331649.png

發(fā)送端UART將起始位,奇偶校驗(yàn)位和停止位添加到數(shù)據(jù)包中:

98758890-c238-11eb-9e57-12bb97331649.png

整個數(shù)據(jù)包從發(fā)送端UART串行發(fā)送到接收端UART;接收端UART按照預(yù)先配置好的波特率對數(shù)據(jù)線進(jìn)行采樣:

987f037a-c238-11eb-9e57-12bb97331649.png

接收端UART解析接收的數(shù)據(jù),丟棄數(shù)據(jù)包中的起始位,奇偶校驗(yàn)位和停止位:

988aeb72-c238-11eb-9e57-12bb97331649.png

接收UART將串行數(shù)據(jù)轉(zhuǎn)換回并行數(shù)據(jù),并將其傳輸?shù)浇邮斩说臄?shù)據(jù)總線:

9895a7c4-c238-11eb-9e57-12bb97331649.png

5 物理層UART、RS232、RS485在串口通信中,主要區(qū)別是電平的不同,其中UART通常使用TTL電平,下面介紹這幾個存在的差異;

TTL

TTL全名是晶體管-晶體管邏輯集成電路(Transistor-Transistor Logic

輸入高電平最小2V,輸出高電平最小2.4V,典型值3.4V;

輸入低電平最大0.8V,輸出低電平最大0.4V,典型值0.2V。

RS232

RS232 邏輯1電平(MARK)=-3V~-15V,邏輯0電平(SPACE)=+3~+15V;

同樣的,對于傳輸數(shù)據(jù)0x55,即二進(jìn)制的01010101,RS232和TTL的區(qū)別如下;

989e2980-c238-11eb-9e57-12bb97331649.png

RS485

RS485是差分信號進(jìn)行串行傳輸;

邏輯1以兩線間的電壓差為+(2~6)V表示;

邏輯“0”以兩線間的電壓差為-(2~6)V表示;

工業(yè)通信中,使用RS485比較多,因?yàn)镽S485是差分信號,可以抑制共模干擾,因此在惡劣的環(huán)境中擁有很好的抗干擾性,比較穩(wěn)定;

6 優(yōu)缺點(diǎn)沒有任何通信協(xié)議是完美的,以下是UART的一些利弊,可幫助您確定它們是否適合您的項(xiàng)目需求:

優(yōu)點(diǎn)

通信只需要兩條數(shù)據(jù)線;

無需時鐘信號;

有奇偶校驗(yàn)位,方便通信的差錯檢查;

只需要接收端和發(fā)送端設(shè)置好數(shù)據(jù)包結(jié)構(gòu),即可穩(wěn)定通信;

缺點(diǎn)

數(shù)據(jù)幀最大支持9位數(shù)據(jù);

不支持多主機(jī)或多從機(jī)的主從系統(tǒng);

編輯:jq

聲明:本文內(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)注

    5378

    文章

    11319

    瀏覽量

    360428
  • 電平
    +關(guān)注

    關(guān)注

    5

    文章

    357

    瀏覽量

    39813
  • 晶體管
    +關(guān)注

    關(guān)注

    77

    文章

    9610

    瀏覽量

    137666
  • uart
    +關(guān)注

    關(guān)注

    22

    文章

    1219

    瀏覽量

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

    關(guān)注

    0

    文章

    248

    瀏覽量

    24345

原文標(biāo)題:我打賭!你還不會UART!不信,你看看~

文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    明明說的是25G信號,卻讓看12.5G的損耗?

    。 那如果25Gbps信號的損耗真的是要看到25GHz頻點(diǎn)的話,30dB的衰減在眼圖中估計(jì)只能看到黑屏和雪花了。但是實(shí)際仿真卻不是這樣,依然能得到還不錯的眼圖結(jié)果,如下所示,眼高
    發(fā)表于 10-23 09:11

    關(guān)于陶瓷電路板不知道的事

    陶瓷電路板(Ceramic Circuit Board),又稱陶瓷基板,是一種以陶瓷材料為基體,通過精密的制造工藝在表面形成電路圖形的高技術(shù)產(chǎn)品,快來看看哪些是您還不知道的事?
    的頭像 發(fā)表于 10-21 11:55 ?123次閱讀
    關(guān)于陶瓷電路板<b class='flag-5'>你</b>不知道的事

    認(rèn)識貼片電阻嗎,對他了解多少?

    認(rèn)識貼片電阻嗎,對他了解多少?
    的頭像 發(fā)表于 08-27 15:49 ?334次閱讀
    <b class='flag-5'>你</b>認(rèn)識貼片電阻嗎,<b class='flag-5'>你</b>對他了解多少?

    雙向收發(fā)的信號應(yīng)該在哪進(jìn)行串聯(lián)端接?分享幾個實(shí)用設(shè)計(jì)方法!

    自從上次高速先生教會了串阻端接的技巧后,感覺一般的設(shè)計(jì)都難不倒了!直到遇到了雙向收發(fā)的信號這種“二般”的設(shè)計(jì)后,感覺自己又不會了。別慌,再進(jìn)來
    的頭像 發(fā)表于 07-12 18:03 ?1237次閱讀
    雙向收發(fā)的信號應(yīng)該在哪進(jìn)行串聯(lián)端接?分享幾個實(shí)用設(shè)計(jì)方法!

    為什么串阻阻值通常是22到33歐姆,看完后不信不懂!

    ,基本上很多1GHz以下的單端信號都有可能用到。從信號類型來看,像低速點(diǎn)的I2C信號、local bus信號到高一點(diǎn)的flash信號、以太網(wǎng)RGMII信號,甚至再高一點(diǎn)的DDR1到DD
    發(fā)表于 06-04 11:12

    還不會代碼托管嗎?一文教會使用Gitee~

    一、Gitee簡介gitee:基于Git的代碼托管和研發(fā)協(xié)作平臺二、Gitee創(chuàng)建賬號1、打開瀏覽器,輸入https://gitee.com進(jìn)入gitee官網(wǎng),注冊2、注冊好賬號,進(jìn)入gitee主頁面3、點(diǎn)擊"+"以及新建倉庫,創(chuàng)建自己的倉庫4、創(chuàng)建倉庫名稱(最好是言簡意賅的名字),點(diǎn)擊創(chuàng)建5、下面就是我們創(chuàng)建好的倉庫了三、Gitee使用技巧1Gitee提交
    的頭像 發(fā)表于 03-05 08:13 ?679次閱讀
    <b class='flag-5'>還不會</b>代碼托管嗎?一文教會<b class='flag-5'>你</b>使用Gitee~

    如何將USB-UART bridge固件復(fù)合進(jìn)來,實(shí)現(xiàn)synchronous slave FIFO和USB-UART bridge同時工作?

    ,USB-UART bridge ,可實(shí)現(xiàn)虛擬COM端口 請問如何將USB-UART bridge 固件復(fù)合進(jìn)來,實(shí)現(xiàn)synchronous slave FIFO和USB-UART b
    發(fā)表于 02-29 07:09

    沒有10年工作經(jīng)驗(yàn),不會用電磁場來分析高速問題吧?

    過孔stub到底有什么影響時,也非常的有用。例如以下這個有比較長stub的過孔結(jié)構(gòu)。 從S參數(shù)上,我們當(dāng)時知道會出現(xiàn)諧振點(diǎn),如下所示: 但是不看看電場,不會了解這個在諧振
    發(fā)表于 02-01 14:48

    賬號狀態(tài)異常,有論壇管理員來看看么?

    今天登錄進(jìn)來看,發(fā)現(xiàn)自己的帳號竟然積分是負(fù)數(shù),有點(diǎn)意思啊。 然后,再看,竟然發(fā)現(xiàn)微信帳號和手機(jī)帳號不是同一個帳號! 也就是說當(dāng)時微信登錄的時候沒驗(yàn)證手機(jī)帳號 注意看,有兩個帳號,一個2013創(chuàng)建
    發(fā)表于 12-19 09:18

    PEAK版本升級,看看有沒有關(guān)注的新功能?

    近期PEAK進(jìn)行了重要的版本升級,這次升級帶來了許多令人興奮的功能優(yōu)化,助力您的工作流程更加便捷高效。為了幫助用戶更好地了解PEAK新版本,我們提供了詳細(xì)的說明和指導(dǎo),快來看看有沒有關(guān)注的新功能
    的頭像 發(fā)表于 12-14 08:04 ?600次閱讀
    PEAK版本升級,<b class='flag-5'>看看</b>有沒有<b class='flag-5'>你</b>關(guān)注的新功能?

    pcb自動放板機(jī)有多自動?

    pcb自動放板機(jī)有多自動?進(jìn)來看看~
    的頭像 發(fā)表于 12-08 16:08 ?626次閱讀

    幾張圖告訴,為什么要一點(diǎn)接地!

    幾張圖告訴,為什么要一點(diǎn)接地!
    的頭像 發(fā)表于 12-07 15:58 ?495次閱讀
    幾張圖告訴<b class='flag-5'>你</b>,為什么要一<b class='flag-5'>點(diǎn)</b>接地!

    POL負(fù)載點(diǎn)電源設(shè)計(jì)中有何訣竅?有兩點(diǎn)很關(guān)鍵,必須知道

    POL負(fù)載點(diǎn)電源設(shè)計(jì)中有何訣竅?有兩點(diǎn)很關(guān)鍵,必須知道
    的頭像 發(fā)表于 12-06 16:06 ?1883次閱讀
    POL負(fù)載<b class='flag-5'>點(diǎn)</b>電源設(shè)計(jì)中有何訣竅?有兩<b class='flag-5'>點(diǎn)</b>很關(guān)鍵,<b class='flag-5'>你</b>必須知道

    的聲音被聽到:看看你的TWS耳塞是怎么設(shè)計(jì)的

    的聲音被聽到:看看你的TWS耳塞是怎么設(shè)計(jì)的
    的頭像 發(fā)表于 12-05 17:25 ?513次閱讀
    讓<b class='flag-5'>你</b>的聲音被聽到:<b class='flag-5'>看看</b>你的TWS耳塞是怎么設(shè)計(jì)的

    還沒使用SiC FET?快來看看本文,秒懂SiC FET性能和優(yōu)勢!

    還沒使用SiC FET?快來看看本文,秒懂SiC FET性能和優(yōu)勢!
    的頭像 發(fā)表于 11-29 16:49 ?643次閱讀
    還沒使用SiC FET?快<b class='flag-5'>來看看</b>本文,秒懂SiC FET性能和優(yōu)勢!