一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

USB總線上的情形是怎樣的

xCb1_yikoulinux ? 來源:一口Linux ? 作者:一口Linux ? 2022-07-07 14:10 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

0. 基本概念

一個【傳輸】(控制、批量、中斷、等時):由多個【事務】組成;

一個【事務】(IN、OUT、SETUP):由一多個【Packet】組成。

USB數(shù)據(jù)在【主機軟件】與【USB設備特定的端點】間被傳輸。【主機軟件】與【USB設備特定的端點】間的關(guān)聯(lián)叫做【pipes】。一個USB設備可以有多個管道(pipes)。

1. 包(Packet)

包(Packet)是USB系統(tǒng)中信息傳輸?shù)幕締卧?,所有?shù)據(jù)都是經(jīng)過打包后在總線上傳輸?shù)?。?shù)據(jù)在 USB總線上的傳輸以包為單位,包只能在幀內(nèi)傳輸。高速USB 總線的幀周期為125us,全速以及低速 USB 總線的幀周期為 1ms。幀的起始由一個特定的包(SOF 包)表示,幀尾為 EOF。EOF不是一個包,而是一種電平狀態(tài),EOF期間不允許有數(shù)據(jù)傳輸。

注意:雖然高速USB總線和全速/低速USB總線的幀周期不一樣,但是SOF包中幀編號的增加速度是一樣的,因為在高速USB系統(tǒng)中,SOF包中幀編號實際上取得是計數(shù)器的高11位,最低三位作為微幀編號沒有使用,因此其幀編號的增加周期也為 1mS

USB總線上的情形是怎樣的?

6fe9b8a4-fda8-11ec-ba43-dac502259ad0.png

包是USB總線上數(shù)據(jù)傳輸?shù)淖钚挝?,不能被打斷或干擾,否則會引發(fā)錯誤。若干個數(shù)據(jù)包組成一次事務傳輸,一次事務傳輸也不能打斷,屬于一次事務傳輸?shù)膸讉€包必須連續(xù),不能跨幀完成。一次傳輸由一次到多次事務傳輸構(gòu)成,可以跨幀完成。

USB包由五部分組成,即同步字段(SYNC)、包標識符字段(PID)、數(shù)據(jù)字段、循環(huán)冗余校驗字段(CRC)和包結(jié)尾字段(EOP),包的基本格式如下圖:

700dcfdc-fda8-11ec-ba43-dac502259ad0.png

1.1 PID類型(即包類型)

701e57ee-fda8-11ec-ba43-dac502259ad0.png

702f24c0-fda8-11ec-ba43-dac502259ad0.png

1.2 Token Packets

704635ac-fda8-11ec-ba43-dac502259ad0.png

此格式適用于IN、OUT、SETUP、PING。

PID 數(shù)據(jù)傳輸方向

IN Device-》Host

OUT Host-》Device

SETUP Host-》Device

PING Device-》Host

1.3 Start-of-Frame(SOF) Packets

SOF包由Host發(fā)送給Device。

對于full-speed總線,每隔1.00 ms ±0.0005 ms發(fā)送一次;

對于high-speed總線,每隔125 μs ±0.0625 μs發(fā)送一次;

SOF包構(gòu)成如下圖所示

7051c52a-fda8-11ec-ba43-dac502259ad0.png

705f6a2c-fda8-11ec-ba43-dac502259ad0.png

1.4 Data Packets

7072b01e-fda8-11ec-ba43-dac502259ad0.png

有四種類類型的數(shù)據(jù)包:DATA0, DATA1, DATA2,and MDATA,且由PID來區(qū)分。DATA0和DATA1被定義為支持數(shù)據(jù)切換同步(data toggle synchronization)。

1.5 Handshake Packets

7086d1e8-fda8-11ec-ba43-dac502259ad0.png

ACK: 對于IN事務,它將由host發(fā)出;對于OUT、SETUP和PING事務,它將由device發(fā)出。

NAK: 在數(shù)據(jù)階段,對于IN事務,它將由device發(fā)出;在握手階段,對于OUT和PING事務,它也將由device發(fā)出;host從不發(fā)送NAK包。

2. 事務(Transaction)

在USB上數(shù)據(jù)信息的一次接收或發(fā)送的處理過程稱為事務處理(Transaction)即:The delivery of service to an endpoint。一個事務由一系統(tǒng)packet組成,具體由哪些packet組成,它取決于具體的事務??赡苡扇缦掳M成:

一個token packet

可選的data pcket

可選的handshake packet

可選的special packet

2.1 輸入(IN)事務處理

輸入事務處理:表示USB主機從總線上的某個USB設備接收一個數(shù)據(jù)包的過程。

【正?!康妮斎胧聞仗幚?/p>

70985b20-fda8-11ec-ba43-dac502259ad0.png

【設備忙】時的輸入事務處理

70ac4072-fda8-11ec-ba43-dac502259ad0.png

【設備出錯】時的輸入事務處理

70b94f6a-fda8-11ec-ba43-dac502259ad0.png

2.2. 輸出(OUT)事務處理

輸出事務處理:表示USB主機把一個數(shù)據(jù)包輸出到總線上的某個USB設備接收的過程。

【正?!康妮敵鍪聞仗幚?/p>

70c6b6c8-fda8-11ec-ba43-dac502259ad0.png

【設備忙時】的輸出事務處理

70d5d4c8-fda8-11ec-ba43-dac502259ad0.png

【設備出錯】的輸出事務處理

70e2fca2-fda8-11ec-ba43-dac502259ad0.png

2.3 設置(SETUP)事務處理

【正常】的設置事務處理

70f14d48-fda8-11ec-ba43-dac502259ad0.png

【設備忙時】的設置事務處理

70fd9e86-fda8-11ec-ba43-dac502259ad0.png

【設備出錯】的設置事務處理

710ccf50-fda8-11ec-ba43-dac502259ad0.png

3. USB傳輸類型

在USB的傳輸中,定義了4種傳輸類型:

控制傳輸 (Control Transfer)

中斷傳輸 (Interrupt Transfer)

批量傳輸 (Bulk Transfer)

同步傳輸 (Isochronous)

3.1 控制傳輸 (Control Transfer)

控制傳輸由2~3個階段組成:

建立階段(Setup)

數(shù)據(jù)階段(無數(shù)據(jù)控制沒有此階段)(DATA)

狀態(tài)階段(Status)

每個階段都由一次或多次(數(shù)據(jù)階段)事務傳輸組成(Transaction)。

控制數(shù)據(jù)由USB系統(tǒng)軟件用于配置設備(在枚舉時),其它的驅(qū)動軟件可以選擇使用control transfer實現(xiàn)具體的功能,數(shù)據(jù)傳輸是不可丟失的。

3.1.1 建立階段

主機從USB設備獲取配置信息,并設置設備的配置值。建立階段的數(shù)據(jù)交換包含了SETUP令牌封包、緊隨其后的DATA0數(shù)據(jù)封包以及ACK握手封包。它的作用是執(zhí)行一個設置(概念含糊)的數(shù)據(jù)交換,并定義此控制傳輸?shù)膬?nèi)容(即:在Data Stage中IN或OUT的data包個數(shù),及發(fā)送方向,在Setup Stage已經(jīng)被設定)。

711d5ece-fda8-11ec-ba43-dac502259ad0.png

3.1.2 數(shù)據(jù)階段

根據(jù)數(shù)據(jù)階段的數(shù)據(jù)傳輸?shù)姆较?,控制傳輸又可分?種類型:

控制讀取(讀取USB描述符)

控制寫入(配置USB設備)

無數(shù)據(jù)控制

數(shù)據(jù)傳輸階段:用來傳輸主機與設備之間的數(shù)據(jù)。

控制讀取

是將數(shù)據(jù)從設備讀到主機上,讀取的數(shù)據(jù)USB設備描述符。該過程如下圖的【Control Read】所示。對每一個數(shù)據(jù)信息包而言,首先,主機會發(fā)送一個IN令牌信息包,表示要讀數(shù)據(jù)進來。然后,設備將數(shù)據(jù)通過DATA1/DATA0數(shù)據(jù)信息包回傳給主機。最后,主機將以下列的方式加以響應:當數(shù)據(jù)已經(jīng)正確接收時,主機送出ACK令牌信息包;當主機正在忙碌時,發(fā)出NAK握手信息包;當發(fā)生了錯誤時,主機發(fā)出STALL握手信息包。

控制寫入

是將數(shù)據(jù)從主機傳到設備上,所傳的數(shù)據(jù)即為對USB設備的配置信息,該過程如下的圖【Control Wirte】所示。對每一個數(shù)據(jù)信息包而言,主機將會送出一個OUT令牌信息包,表示數(shù)據(jù)要送出去。緊接著,主機將數(shù)據(jù)通過DATA1/DATA0數(shù)據(jù)信息包傳遞至設備。最后,設備將以下列方式加以響應:當數(shù)據(jù)已經(jīng)正確接收時,設備送出ACK令牌信息包;當設備正在忙碌時,設備發(fā)出NAK握手信息包;當發(fā)生了錯誤時,設備發(fā)出STALL握手信息包。

712b0790-fda8-11ec-ba43-dac502259ad0.png

3.1.3 狀態(tài)階段

狀態(tài)階段:用來表示整個傳輸?shù)倪^程已完全結(jié)束。

狀態(tài)階段傳輸?shù)姆较虮仨毰c數(shù)據(jù)階段的方向相反,即原來是IN令牌封包,這個階段應為OUT令牌封包;反之,原來是OUT令牌封包,這個階段應為IN令牌封包。

對于【控制讀取】而言,主機會送出OUT令牌封包,其后再跟著0長度的DATA1封包。而此時,設備也會做出相對應的動作,送ACK握手封包、NAK握手封包或STALL握手封包。

相對地對于【控制寫入】傳輸,主機會送出IN令牌封包,然后設備送出表示完成狀態(tài)階段的0長度的DATA1封包,主機再做出相對應的動作:送ACK握手封包、NAK握手封包或STALL握手封包。

3.2 批量傳輸 (Bulk Transfer)

用于傳輸大量數(shù)據(jù),要求傳輸不能出錯,但對時間沒有要求,適用于打印機、存儲設備等。

批量傳輸是可靠的傳輸,需要握手包來表明傳輸?shù)慕Y(jié)果。若數(shù)據(jù)量比較大,將采用多次批量事務傳輸來完成全部數(shù)據(jù)的傳輸,傳輸過程中數(shù)據(jù)包的PID 按照 DATA0-DATA1-DATA0-…的方式翻轉(zhuǎn),以保證發(fā)送端和接收端的同步。

USB 允許連續(xù) 3次以下的傳輸錯誤,會重試該傳輸,若成功則將錯誤次數(shù)計數(shù)器清零,否則累加該計數(shù)器。超過三次后,HOST 認為該端點功能錯誤(STALL),放棄該端點的傳輸任務。

一次批量傳輸(Transfer)由 1 次到多次批量事務傳輸(Transaction)組成。

翻轉(zhuǎn)同步:發(fā)送端按照 DATA0-DATA1-DATA0-…的順序發(fā)送數(shù)據(jù)包,只有成功的事務傳輸才會導致 PID 翻轉(zhuǎn),也就是說發(fā)送端只有在接收到 ACK 后才會翻轉(zhuǎn) PID,發(fā)送下一個數(shù)據(jù)包,否則會重試本次事務傳輸。同樣,若在接收端發(fā)現(xiàn)接收到到的數(shù)據(jù)包不是按照此順序翻轉(zhuǎn)的,比如連續(xù)收到兩個 DATA0,那么接收端認為第二個 DATA0 是前一個 DATA0 的重傳。

它通過在硬件級執(zhí)行“錯誤檢測”和“重傳”來確保host與device之間“準確無誤”地傳輸數(shù)據(jù),即可靠傳輸。它由三種包組成(即IN事務或OUT事務):

token

data

handshake

71481484-fda8-11ec-ba43-dac502259ad0.png

For IN Token (即:IN Transaction)

ACK: 表示host正確無誤地接收到數(shù)據(jù)

NAK: 指示設備暫時不能返回或接收數(shù)據(jù) (如:設備忙)

STALL:指示設備永遠停止,需要host軟件的干預 (如:設備出錯)

For OUT Token (即:OUT Transaction)

如果接收到的數(shù)據(jù)包有誤,如:CRC錯誤,Device不發(fā)送任何handshake包

ACK: Device已經(jīng)正確無誤地接收到數(shù)據(jù)包,且通知Host可以按順序發(fā)送下一個數(shù)據(jù)包

NAK: Device 已經(jīng)正確無誤地接收到數(shù)據(jù)包,且通知Host重傳數(shù)據(jù),由于Device臨時狀況(如buffer滿)

STALL: 指示Device endpoint已經(jīng)停止,且通知Host不再重傳

Bulk讀寫序列

715dccd4-fda8-11ec-ba43-dac502259ad0.png

即由一系統(tǒng)IN事務或OUT事務組成。

3.3 中斷傳輸(Interrupt Transfer)

中斷傳輸由IN或OUT事務組成。

中斷傳輸在流程上除不支持PING 之外,其他的跟批量傳輸是一樣的。他們之間的區(qū)別也僅在于事務傳輸發(fā)生的端點不一樣、支持的最大包長度不一樣、優(yōu)先級不一樣等這樣一些對用戶來說透明的東西。

主機在排定中斷傳輸任務時,會根據(jù)對應中斷端點描述符中指定的查詢間隔發(fā)起中斷傳輸。中斷傳輸有較高的優(yōu)先級,僅次于同步傳輸。

同樣中斷傳輸也采用PID翻轉(zhuǎn)的機制來保證收發(fā)端數(shù)據(jù)同步。下圖為中斷傳輸?shù)牧鞒虉D。

中斷傳輸方式總是用于對設備的查詢,以確定是否有數(shù)據(jù)需要傳輸。因此中斷傳輸?shù)姆较蚩偸菑腢SB設備到主機。

71797b96-fda8-11ec-ba43-dac502259ad0.png

DATA0或DATA1中的包含的是中斷信息,而不是中斷數(shù)據(jù)。

3.4 同步傳輸(Isochronous Transfer)

它由兩種包組成:

token

data

同步傳輸不支持“handshake”和“重傳能力”,所以它是不可靠傳輸。

同步傳輸是不可靠的傳輸,所以它沒有握手包,也不支持PID翻轉(zhuǎn)。主機在排定事務傳輸時,同步傳輸有最高的優(yōu)先級。

同步傳輸適用于必須以固定速率抵達或在指定時刻抵達,可以容忍偶爾錯誤的數(shù)據(jù)上。實時傳輸一般用于麥 克風、喇叭、UVC Camera等設備。實時傳輸只需令牌與數(shù)據(jù)兩個信息包階段,沒有握手包,故數(shù)據(jù)傳錯時不會重傳。

718c4ee2-fda8-11ec-ba43-dac502259ad0.png

原文標題:USB通信協(xié)議深入理解

文章出處:【微信公眾號:一口Linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

    關(guān)注

    9

    文章

    2015

    瀏覽量

    66043
  • USB總線
    +關(guān)注

    關(guān)注

    1

    文章

    71

    瀏覽量

    37500
  • 計數(shù)器
    +關(guān)注

    關(guān)注

    32

    文章

    2291

    瀏覽量

    96375

原文標題:USB通信協(xié)議深入理解

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

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

掃碼添加小助手

加入工程師交流群

    評論

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

    是否有關(guān)于如何通過 I2C 總線上的 uProcessor 或 FPGA 與芯片通信的文檔?

    我們正在做一個項目,我們想回讀電纜中的eMarker芯片。 瀏覽不同的評估板和數(shù)據(jù)表,看來我們需要為芯片編譯代碼。 1. 芯片是否預配置了默認固件? 2. 是否有關(guān)于如何通過 I2C 總線上
    發(fā)表于 05-29 06:13

    在一個i2c總線上掛多個ads1100時候,ads1100的地址是怎樣的?

    在一個i2c總線上掛多個ads1100時候,ads1100的地址是怎樣的?
    發(fā)表于 02-14 08:31

    想把ths1230的輸出數(shù)據(jù)直接連接到DSP的數(shù)據(jù)總線上,可以嗎?

    你好!我看到ths1230與DSP連接時,你們推薦使用SN74ALVCH16841芯片或者FIFO進行連接。但我想把ths1230的輸出數(shù)據(jù)直接連接到DSP的數(shù)據(jù)總線上,可以嗎?
    發(fā)表于 02-11 07:17

    使用ADS7828和I2C總線的器件掛在ARM的一個總線上,連續(xù)工作2~5小時后會發(fā)現(xiàn)總線掛掉并且不能恢復,為什么?

    在使用TI的ADS7828芯片的時候出現(xiàn)了一個問題,這個芯片和其他I2C總線的器件掛在ARM的一個總線上,當連續(xù)工作2~5小時后,會發(fā)現(xiàn)總線掛掉,并且不能恢復,測量發(fā)現(xiàn)是數(shù)據(jù)線被拉低,連續(xù)工作期間
    發(fā)表于 01-14 07:11

    如何高效調(diào)整CAN總線上的終端電阻?

    導讀在CAN總線技術(shù)里,為何終端電阻是120Ω?怎樣高效調(diào)整?本文將簡要說明線纜阻抗測量和介紹測試平臺調(diào)節(jié)手段,用實例展現(xiàn)效果,助您快速掌握要點。1.為什么選120Ω終端電阻?在汽車電子通信領域
    的頭像 發(fā)表于 01-02 11:36 ?888次閱讀
    如何高效調(diào)整CAN<b class='flag-5'>總線上</b>的終端電阻?

    I2C總線上拉電阻阻值如何確定?

    導讀I2C總線在產(chǎn)品設計中被廣泛應用,盡管其結(jié)構(gòu)簡單,但經(jīng)常發(fā)生上拉電阻設計不合理的問題。本文將對I2C上拉電阻的選擇進行簡要分析。一根信號線上,通過電阻連接一個固定的高電平VCC,信號線初始、空閑
    的頭像 發(fā)表于 12-27 11:34 ?1833次閱讀
    I2C<b class='flag-5'>總線上</b>拉電阻阻值如何確定?

    SN6501DBVR和TD301配合時總線上出現(xiàn)錯誤字節(jié)怎么處理?

    SN6501DBVR和TD301配合時總線上SN65發(fā)送命令時出現(xiàn)錯誤字節(jié),1個SN65,5個TD301H485,斷開SN65時恢復正常。不知是否有類似故障發(fā)生,怎樣處理。感謝!
    發(fā)表于 11-29 11:54

    I2C總線上拉電阻計算

    電子發(fā)燒友網(wǎng)站提供《I2C總線上拉電阻計算.pdf》資料免費下載
    發(fā)表于 10-08 09:54 ?1次下載
    I2C<b class='flag-5'>總線上</b>拉電阻計算

    usb主機控制器位于ahp總線上

    關(guān)于“USB主機控制器是否位于AHP總線上”的問題,首先需要明確幾個概念: USB主機控制器 :在USB系統(tǒng)中,主機控制器是控制所有USB
    的頭像 發(fā)表于 09-25 09:20 ?625次閱讀

    usb主機模式和設備模式的區(qū)別

    USB主機模式 在USB主機模式下,計算機或其他設備扮演主機的角色,負責管理USB總線上的通信。主機控制數(shù)據(jù)流,包括初始化連接、傳輸數(shù)據(jù)和管理設備。 主要特點: 控制權(quán) :主機控制
    的頭像 發(fā)表于 09-25 09:06 ?2373次閱讀

    I2C總線上拉電阻的必要性

    數(shù)據(jù)線加上拉電阻。這一設計不僅關(guān)乎技術(shù)的實現(xiàn),更涉及系統(tǒng)安全和信號傳輸效率的優(yōu)化。本文將深入探討在I2C總線上加上拉電阻的必要性及其帶來的技術(shù)優(yōu)勢。 我們需要理解I2C總線的基本架構(gòu)。I2C總線是一種多主多從的通信網(wǎng)絡,允許多個
    的頭像 發(fā)表于 09-09 17:16 ?2080次閱讀

    優(yōu)秀實踐:I3C共享總線上的I2C器件

    電子發(fā)燒友網(wǎng)站提供《優(yōu)秀實踐:I3C共享總線上的I2C器件.pdf》資料免費下載
    發(fā)表于 09-06 09:49 ?0次下載
    優(yōu)秀實踐:I3C共享<b class='flag-5'>總線上</b>的I2C器件

    USB是通用串行總線

    USB是通用串行總線 USB是通用串行總線USB協(xié)議版本包括 USB1.0、
    的頭像 發(fā)表于 08-21 10:52 ?556次閱讀

    求助,INA226 I2C總線上的地址配置問題求解

    我們的項目需要用到很多片INA226,現(xiàn)有的設計計劃安排1個I2C總線上掛12片INA226芯片,我們沒有這樣用過,有些擔心INA226芯片的A1和A0腳的配置影響I2C總線的通訊。 具體說就是
    發(fā)表于 08-01 07:00

    如何使用XMC4700在變量中讀取LIN總線上的可用數(shù)據(jù)?

    如何使用 XMC4700 在變量中讀取 LIN 總線上的可用數(shù)據(jù)
    發(fā)表于 07-23 07:51