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

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

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

數(shù)據(jù)包的結構及傳輸過程

單片機匠人 ? 來源:單片機匠人 ? 作者:單片機匠人 ? 2022-03-11 09:19 ? 次閱讀

今天我們來詳細地說說數(shù)據(jù)包的結構以及它們的傳輸過程。USB是串行總線,所以數(shù)據(jù)是一位一位地在數(shù)據(jù)線上傳送的。既然是一位一位地傳送,就存在著一個數(shù)據(jù)位先后的問題。usb使用的是LSB在前的方式,即先出來的是最低位數(shù)據(jù),接下來是次低位,最后是最高位(MSB)。一個包,又被分成了很多個域(field),而LSB、MSB就是以域為單位來劃分的。

前面說過,USB數(shù)據(jù)在發(fā)送到總線上之前,要先經(jīng)過位填充,再經(jīng)過NRZ1編碼。在這里討論時,所用的數(shù)據(jù)都是原始的數(shù)據(jù),即沒有經(jīng)過位填充和NRZ編碼的原始數(shù)據(jù)。以后也是如此,凡是沒有明確說明是位填充或NRZI編碼過的數(shù)據(jù),默認為原始的數(shù)據(jù)。另外還有一個數(shù)據(jù)傳輸方向的問題,因為在USB系統(tǒng)中,主機處于主導地位,所以把從設備到主機的數(shù)據(jù)叫做輸入,從主機到設備的數(shù)據(jù)叫做輸出。

USB總線上傳輸數(shù)據(jù)是以包為基本單位的。一個包被分成不同的域。根據(jù)不同類型的包,所包含的域是不一樣的。但是不同的包有個共同的特點,就是都要以同步域開始,緊跟一個包標識符PD( Packet Identifier),最終以包結束符EOP(End Of Packet)來結束這個包。

同步域是用來告訴USB的串行接口引擎數(shù)據(jù)要開始傳輸了,請做好準備。除此之外,同步域還可以用來同步主機端和設備端的數(shù)據(jù)時鐘,因為同步域是以一串0開始的,而0在USB總線上就被編碼為電平翻轉(zhuǎn),結果就是每個數(shù)據(jù)位都發(fā)生電平變化,這讓串行接口引擎很容易就能恢復出采樣時鐘信號;對于全速設備和低速設備,同步域使用的是0000001(二進制數(shù),線上的發(fā)送順序);對于高速設備,同步域使用的是31個0,后面跟1個1(需要注意的是,這是對發(fā)送端的要求,接收端解碼時,0的個數(shù)可以少于這個數(shù))。

圖1是一個全速或者低速USB數(shù)據(jù)包的同步域經(jīng)過NRZ編碼后的波形。這個波形有7次電平翻轉(zhuǎn),即對應著7個0,最后一個電平不翻轉(zhuǎn),即對應著1個1當串行接口引擎檢測到一個位的數(shù)據(jù)未發(fā)生翻轉(zhuǎn)后(即收到數(shù)據(jù)1),就認為包標識符PID開始了,如圖1.9.1中的PID0PD1,就是包標識符的最低兩位。

cfaa03a4-894d-11ec-952b-dac502259ad0.jpg

cfc05302-894d-11ec-952b-dac502259ad0.png

圖1 全速設備和低速設備的同步域

包結束符EOP,對于高速設備和全速/低速設備也是不一樣的。全速/低速設備的EOP是一個大約為2個數(shù)據(jù)位寬度的單端0(SE0)信號。SE0的意思就是,D+和D同時都保持為低電平。由于USB使用的是差分數(shù)據(jù)線,通常都是一高一低的,而SE0不同,是一種都為低特殊的狀態(tài)。SE0用來表示一些特殊的意義,例如包結束、復位信號等。前面提到USB集線器對USB設備進行復位的操作,就是通過將總線設置為SE0狀態(tài)大約10ms來實現(xiàn)的。對于高速設備的EOP,使用故意的位填充錯誤來表示。那么如何判斷一個位填充錯誤是真的位填充錯誤還是包結束呢?這個由CRC校驗來判斷。如果CRC校驗正確,則說明這個位填充錯誤是EOP;否則,說明傳輸出錯。具體的定義請參看USB協(xié)議,這里只要知道有EOP這么一個東西就行了。

包標識符PID是用來標識一個包的類型的它總共有8位,其中USB協(xié)議使用的只有4位(PID~PID3),另外4位(PI4~PID7)是PID~PD3的取反,用來校驗PID。USB協(xié)議規(guī)定了4類包,分別是令牌包(token packet,PD1~0為01)、數(shù)據(jù)包( data packet,pid1~0為11)、握手包(handshake packet,piD~0為10)和特殊包( special packet,PiD1~0為00)。不同類的包又分成幾種具體的包。圖2 是USB2.0協(xié)議中規(guī)定的各種PID,其中有些是在USB1.1協(xié)議中沒有的,用號標出。

cfaa03a4-894d-11ec-952b-dac502259ad0.jpg

cff19b42-894d-11ec-952b-dac502259ad0.png

圖2 USB2.0中定義的各種PID

以上是數(shù)據(jù)包的結構以及它們傳輸?shù)倪^程,今天的分享就到這里。

往期回顧:

●USB的四種傳輸類型之控制傳輸

●指針和數(shù)組的恩恩怨怨

●USB的四種傳輸類型之中斷傳輸?shù)葧r傳輸

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

    關注

    60

    文章

    7846

    瀏覽量

    263288
  • 數(shù)據(jù)包

    關注

    0

    文章

    244

    瀏覽量

    24324

原文標題:USB的包結構以及包的類型

文章出處:【微信號:gh_e7f294a514ca,微信公眾號:單片機匠人】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關推薦

    華納云:服務器平均響應時間和數(shù)據(jù)包大小之間的影響

    服務器的平均響應時間與數(shù)據(jù)包大小有一定的關系,但這只是影響響應時間的眾多因素之一。具體來說,數(shù)據(jù)包大小對服務器響應時間的影響可以從以下幾個方面來理解: 1.數(shù)據(jù)傳輸時間 影響: 較大的數(shù)據(jù)包
    的頭像 發(fā)表于 10-10 14:01 ?96次閱讀

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

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

    esp8266怎么做才能每秒發(fā)送更多的數(shù)據(jù)包呢?

    數(shù)據(jù)包的速度,即每秒大約 50 個 UDP 數(shù)據(jù)包。高波特率唯一改變的是,在數(shù)據(jù)包較大的情況下,我可以以與輕量級數(shù)據(jù)包相同的速度發(fā)送數(shù)據(jù)包
    發(fā)表于 07-22 08:00

    能否在ESP結束之前通過串行端口停止傳入的UDP數(shù)據(jù)包傳輸以解析下一個UDP數(shù)據(jù)包?

    丟棄在ESP完成之前不需要的數(shù)據(jù)包,以便通過串行端口發(fā)送它以接收下一個數(shù)據(jù)包, 如果沒有,我必須按順序讀取所有傳入的數(shù)據(jù)包,需要的和不需要的, 而且波特率不足,主機處理器開銷大, 我能否在 ESP 結束之前通過串行端口停止傳入
    發(fā)表于 07-16 06:18

    NONOS如何檢查是否實際發(fā)送了UDP數(shù)據(jù)包?

    我發(fā)現(xiàn)進入深度睡眠通常無法傳輸發(fā)送的最后一個 UDP 數(shù)據(jù)包。我現(xiàn)在將睡眠延遲 30 毫秒,這是一個黑客。 我寧愿有一種方法來檢查是否可以休眠,或者以其他方式能夠注冊指示數(shù)據(jù)包已發(fā)送的回調(diào)(無線電發(fā)送緩沖區(qū)為空)。 說清楚:
    發(fā)表于 07-12 06:14

    can總線的數(shù)據(jù)傳輸過程是什么

    CAN總線(Controller Area Network)是一種用于汽車和工業(yè)控制系統(tǒng)的通信協(xié)議。它具有高可靠性、實時性和靈活性,因此在許多領域得到了廣泛應用。本文將詳細介紹CAN總線的數(shù)據(jù)傳輸過程
    的頭像 發(fā)表于 06-16 10:18 ?1774次閱讀

    在AN65974中短數(shù)據(jù)包和零長數(shù)據(jù)包是什么意思?

    在 AN65974 中,短數(shù)據(jù)包和零長數(shù)據(jù)包是什么意思? 非常感謝!
    發(fā)表于 05-30 07:41

    在Fx3控制器中,USB數(shù)據(jù)包中的數(shù)據(jù)有效載荷無法正常發(fā)送的原因?

    在 Fx3 控制器中,在流式傳輸過程中,從主機收到了意外的端點停止請求。 在調(diào)試過程中,我發(fā)現(xiàn) USB 數(shù)據(jù)包中的數(shù)據(jù)有效載荷無法正常發(fā)送,請問出現(xiàn)這種錯誤的原因是什么。 下面附有錯誤
    發(fā)表于 05-28 06:37

    如何在AIROC GUI上獲取良好數(shù)據(jù)包和總數(shù)據(jù)包?

    使用 IQxel-MW LifePoint 作為發(fā)生器并發(fā)送波形BT_1DH5_00001111_Fs80M.iqvsg,但無法在 AIROC 工具中接收數(shù)據(jù)包。 以下是從 IQxel 發(fā)送
    發(fā)表于 05-22 06:39

    如何確保DMA傳輸過程中的數(shù)據(jù)都是好的?

    有沒有哪位大佬清楚DMA原理的 想請教下,芯片廠是如何確保DMA傳輸過程中的數(shù)據(jù)都是OK的 比如傳輸前后SRAM里面的數(shù)據(jù)不變,傳輸出來的
    發(fā)表于 04-12 06:23

    請問高端網(wǎng)絡芯片如何處理數(shù)據(jù)包呢?

    隨著網(wǎng)絡芯片帶寬的持續(xù)提升,其內(nèi)部數(shù)據(jù)包處理單元的工作負載也隨之增加。然而,如果處理單元無法與網(wǎng)絡接口的傳入速率相匹配,將無法及時處理數(shù)據(jù)包,這不僅會導致數(shù)據(jù)包隨機丟失,更會降低網(wǎng)絡的吞吐量。
    的頭像 發(fā)表于 04-02 16:36 ?511次閱讀
    請問高端網(wǎng)絡芯片如何處理<b class='flag-5'>數(shù)據(jù)包</b>呢?

    DPDK在AI驅(qū)動的高效數(shù)據(jù)包處理應用

    傳統(tǒng)的數(shù)據(jù)包處理方式是數(shù)據(jù)包先到內(nèi)核最后再到用戶層進行處理。這種方式會增加額外的延遲和CPU開銷,嚴重影響數(shù)據(jù)包處理的性能。 DPDK 繞過內(nèi)核,在用戶空間中實現(xiàn)快速數(shù)據(jù)包處理。
    的頭像 發(fā)表于 02-25 11:28 ?793次閱讀
    DPDK在AI驅(qū)動的高效<b class='flag-5'>數(shù)據(jù)包</b>處理應用

    使用P4和Vivado工具簡化數(shù)據(jù)包處理設計

    電子發(fā)燒友網(wǎng)站提供《使用P4和Vivado工具簡化數(shù)據(jù)包處理設計.pdf》資料免費下載
    發(fā)表于 01-26 17:49 ?0次下載
    使用P4和Vivado工具簡化<b class='flag-5'>數(shù)據(jù)包</b>處理設計

    網(wǎng)絡丟率正常范圍及其影響因素

    網(wǎng)絡丟率正常范圍及其影響因素 網(wǎng)絡丟率是評估網(wǎng)絡性能和穩(wěn)定性的重要指標之一。 一、網(wǎng)絡丟率的定義和測量方法 網(wǎng)絡丟率是指在數(shù)據(jù)傳輸過程
    的頭像 發(fā)表于 12-29 14:45 ?5070次閱讀

    Linux場景下數(shù)據(jù)包是如何在協(xié)議層傳輸

    所有互聯(lián)網(wǎng)服務,均依賴于TCP/IP協(xié)議棧。懂得數(shù)據(jù)是如何在協(xié)議棧傳輸的,將會幫助你提升互聯(lián)網(wǎng)程序的性能和解決TCP相關問題的能力。 我們講述在Linux場景下數(shù)據(jù)包是如何在協(xié)議層傳輸
    的頭像 發(fā)表于 11-11 11:33 ?1021次閱讀
    Linux場景下<b class='flag-5'>數(shù)據(jù)包</b>是如何在協(xié)議層<b class='flag-5'>傳輸</b>的