電子產(chǎn)業(yè)一站式賦能平臺

PCB聯(lián)盟網(wǎng)

搜索
查看: 106|回復: 0
收起左側(cè)

新手都能看懂的 USB 通信協(xié)議

[復制鏈接]

531

主題

531

帖子

3817

積分

四級會員

Rank: 4

積分
3817
跳轉(zhuǎn)到指定樓層
樓主
發(fā)表于 2024-8-16 07:42:00 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
. j& G) H' \. p" |2 [+ F" l( f
點擊上方名片關注了解更多+ p) ?+ ]. S' V( `" g: s

6 p1 c% U2 u) R( d+ u8 `1 }  h+ ]5 }/ h  ~& P  R  w
USB接口隨處可見,手機、電腦、電視,以及各種電子產(chǎn)品充電口(雖然是USB-C,但它也是USB)都有USB的身影。# @; _6 z: G3 y; _, J! y
USB應用非常廣泛,很多嵌入式設備也具有USB通信能力,這里給大家分享一下USB通信協(xié)議主要內(nèi)容,新手都能看明白(當然,最好還是有一定通信協(xié)議基礎才行)。
# a8 p3 Z! L/ q7 F  H$ z: H! f- z0 g( h" s+ c- K
   1、基本概念一個【傳輸】(控制、批量、中斷、等時):由多個【事務】組成;一個【事務】(IN、OUT、SETUP):由一多個【Packet】組成。USB數(shù)據(jù)在【主機軟件】與【USB設備特定的端點】間被傳輸!局鳈C軟件】與【USB設備特定的端點】間的關聯(lián)叫做【pipes】。一個USB設備可以有多個管道(pipes)。  2 、包(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位,最低三位作為微幀編號沒有使用,因此其幀編號的增加周期也為 1mSUSB總線上的情形是怎樣的?+ i( f  k' [+ K7 h, G. E" p

% v  T# X- ~( o; `7 w. x
3 O' b; E, u# E, z. s4 l! I包是USB總線上數(shù)據(jù)傳輸?shù)淖钚挝,不能被打斷或干擾,否則會引發(fā)錯誤。若干個數(shù)據(jù)包組成一次事務傳輸,一次事務傳輸也不能打斷,屬于一次事務傳輸?shù)膸讉包必須連續(xù),不能跨幀完成。一次傳輸由一次到多次事務傳輸構(gòu)成,可以跨幀完成。
/ `. {( r) C0 w, r3 xUSB包由五部分組成,即同步字段(SYNC)、包標識符字段(PID)、數(shù)據(jù)字段、循環(huán)冗余校驗字段(CRC)和包結(jié)尾字段(EOP),包的基本格式如下圖:
3 D9 _( _3 Q* O% G  ?% N9 ^
; I8 L% _4 p# V( m& @! a1.1 PID類型(即包類型)5 m5 n- t* P5 N) [" ~1 `5 D
" N- e4 ^6 Z. {
: ]) N* j! x: \- Z) J* u
( h8 g6 s9 V: a$ d
1.2 Token Packets+ o& P- i! r" k, a% a; w& O
& a( q7 y. w  t) s0 X
此格式適用于IN、OUT、SETUP、PING。
, u( t2 y. N/ \$ ^- HPID 數(shù)據(jù)傳輸方向IN Device->HostOUT Host->DeviceSETUP Host->DevicePING Device->Host1.3 Start-of-Frame(SOF) PacketsSOF包由Host發(fā)送給Device。對于full-speed總線,每隔1.00 ms ±0.0005 ms發(fā)送一次;
5 E; D% [0 R# |1 l; u對于high-speed總線,每隔125 μs ±0.0625 μs發(fā)送一次;; `2 A; E( {' H; J( K
[/ol]SOF包構(gòu)成如下圖所示1 y3 t% f3 j' v. G3 H) m; G3 d

7 `3 `. D3 v7 g: ~; ~* o# u
' b: O/ @+ M  u# T 6 F3 |) ~+ h; o9 y4 T
1.4 Data Packets
) v" F, X6 a; s+ p. N9 l
: i0 ~! }% ?. _8 T( w有四種類類型的數(shù)據(jù)包:DATA0, DATA1, DATA2,and MDATA,且由PID來區(qū)分。DATA0和DATA1被定義為支持數(shù)據(jù)切換同步(data toggle synchronization)。
5 O0 ?* p/ d6 P  U# N1.5 Handshake Packets
1 O1 W" e: M7 q$ s1 e: H $ [+ e* E: M  S! c
ACK: 對于IN事務,它將由host發(fā)出;對于OUT、SETUP和PING事務,它將由device發(fā)出。$ ~2 c8 X  Y. q* ~5 o. \
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 packet2.1 輸入(IN)事務處理輸入事務處理:表示USB主機從總線上的某個USB設備接收一個數(shù)據(jù)包的過程。【正!康妮斎胧聞仗幚: S3 A4 y* i% l9 M" E

6 _! S& b0 S" S8 N; m9 j 7 {* \3 F+ r# v! `$ `- [
【設備忙】時的輸入事務處理" d9 z" q4 ?# [' w2 e
  }% ]# w9 A* g+ T
* k$ m4 n5 M8 `6 g5 S
【設備出錯】時的輸入事務處理
6 l* A! O3 G' i. Y( U3 x' w. w8 c
' H8 ^. T/ j/ `* j9 x" g

/ p7 Y" C4 Z/ m* M; r: }3 ]2.2. 輸出(OUT)事務處理輸出事務處理:表示USB主機把一個數(shù)據(jù)包輸出到總線上的某個USB設備接收的過程。【正常】的輸出事務處理
- }9 T0 e+ O/ c8 o. R

2 |6 P% @3 @( Z) X) |
$ \) G5 ^$ g* F' B& N【設備忙時】的輸出事務處理
# f( i; G( Q$ I5 T5 x8 Q

5 k2 d- _  l% {+ g7 \
4 `1 q5 S9 ~, ~6 i) k【設備出錯】的輸出事務處理5 z# \) k! c3 z* ~8 C/ @
9 x6 R4 [0 f: w7 Z: M

8 [+ ~/ I: L2 s" h2.3 設置(SETUP)事務處理【正!康脑O置事務處理- u8 @5 b8 Q+ k" D

+ H0 ?  `' }" l6 u# c . w5 S4 j: e0 A
【設備忙時】的設置事務處理1 H; [) E0 G  T* E
. u3 e+ U2 h1 b8 H$ Z; I( u
/ k  S5 \! Z6 {, H2 W
【設備出錯】的設置事務處理7 F3 e# Y& _4 Y2 i

6 _8 F" Q/ q( _- ^6 w/ e- S / s$ m' U) g6 t8 t. I& b4 [
   3、USB傳輸類型 在USB的傳輸中,定義了4種傳輸類型:控制傳輸 (Control Transfer)" ]4 N" ?7 x, S% |/ j5 e# l8 u/ E
中斷傳輸 (Interrupt Transfer)
3 e& x) r$ X5 _. y. x% f2 N6 u批量傳輸 (Bulk Transfer)% z, p) F. K1 ~2 P
同步傳輸 (Isochronous)& o8 j+ M' G% O. A/ K& }2 T3 l
3.1 控制傳輸 (Control Transfer)控制傳輸由2~3個階段組成:建立階段(Setup)
3 R& L% L8 U1 L數(shù)據(jù)階段(無數(shù)據(jù)控制沒有此階段)(DATA)5 j5 Z6 F5 s5 O( {, V+ T$ W7 T
狀態(tài)階段(Status)
* C5 d  t9 ^0 B2 x7 Q' H4 G! P; }[/ol]每個階段都由一次或多次(數(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)被設定)。; ^4 _! l( c* s1 k) i7 U1 i, f

% m6 ~$ U; w5 I0 R9 t3.1.2 數(shù)據(jù)階段根據(jù)數(shù)據(jù)階段的數(shù)據(jù)傳輸?shù)姆较,控制傳輸又可分?種類型:控制讀取(讀取USB描述符)
5 M: K* X, R, E5 [控制寫入(配置USB設備)
' F8 S5 g( [6 `3 {+ S無數(shù)據(jù)控制
# A; x( v. J8 @! J* J[/ol]數(shù)據(jù)傳輸階段:用來傳輸主機與設備之間的數(shù)據(jù)。控制讀取
2 R9 ~6 q7 ?2 W1 C
是將數(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握手信息包。控制寫入5 t8 \3 [( G/ I7 A, @6 q2 s. h
是將數(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握手信息包。2 r% l1 S+ F5 Y2 h$ e4 r0 p) H

2 i9 |3 ?$ k. M' E' o3.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* Z' G2 \* N" x, {
data, N3 C$ V. }3 U$ Y8 i& |
handshake
7 A8 m: g) Q$ m9 A5 ^( N[/ol]
" G' Y4 w; r4 T% i$ E5 [* ^
' Z$ x4 q) a9 |. {3 x! t% @For IN Token (即:IN Transaction)! D6 N# c# e8 N3 h! t  I1 c
[/ol]ACK: 表示host正確無誤地接收到數(shù)據(jù)5 t5 z$ A3 g5 m5 h# [6 L1 O' |7 U
NAK: 指示設備暫時不能返回或接收數(shù)據(jù) (如:設備忙)
4 Q7 c& L/ f5 q8 q. B+ u) NSTALL:指示設備永遠停止,需要host軟件的干預 (如:設備出錯)- w1 q6 R1 O$ `2 i% w$ U
For OUT Token (即:OUT Transaction); L+ _1 t* R: }8 M
[/ol]如果接收到的數(shù)據(jù)包有誤,如:CRC錯誤,Device不發(fā)送任何handshake包ACK: Device已經(jīng)正確無誤地接收到數(shù)據(jù)包,且通知Host可以按順序發(fā)送下一個數(shù)據(jù)包4 S7 C, p+ ~) P+ J7 o* g6 ]' S' [% y* _
NAK: Device 已經(jīng)正確無誤地接收到數(shù)據(jù)包,且通知Host重傳數(shù)據(jù),由于Device臨時狀況(如buffer滿)4 @% c( Q: N  Q. ]4 D4 ^( e6 S
STALL: 指示Device endpoint已經(jīng)停止,且通知Host不再重傳6 f" P# L3 V: N
Bulk讀寫序列$ s' H  ^2 D* }  _: Y3 J% e
[/ol]
4 _/ `1 [, W8 _- o, {7 c& p1 o: @' x# o6 \
即由一系統(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設備到主機。* F, v( S9 s0 O) ^

2 T! Z. z$ G4 Y# `, Q- sDATA0或DATA1中的包含的是中斷信息,而不是中斷數(shù)據(jù)。3.4 同步傳輸(Isochronous Transfer)它由兩種包組成:
1 Z' o$ \9 P9 L0 R, v8 q! C9 Y1 \* Btoken5 i  H3 s! _! R
data9 Q$ n2 _6 D' ~$ _8 p) D
[/ol]同步傳輸不支持“handshake”和“重傳能力”,所以它是不可靠傳輸。同步傳輸是不可靠的傳輸,所以它沒有握手包,也不支持PID翻轉(zhuǎn)。主機在排定事務傳輸時,同步傳輸有最高的優(yōu)先級。同步傳輸適用于必須以固定速率抵達或在指定時刻抵達,可以容忍偶爾錯誤的數(shù)據(jù)上。實時傳輸一般用于麥 克風、喇叭、UVC Camera等設備。實時傳輸只需令牌與數(shù)據(jù)兩個信息包階段,沒有握手包,故數(shù)據(jù)傳錯時不會重傳。
* F$ o5 g$ t$ Z8 N4 }( ]0 t! J! q# c( }

; Y' E, \  G: _% y- W0 M
, I1 E3 Y/ T% s* a& v6 w' s3 p來源地址:https://blog.csdn.net/myarrow/article/details/84841139 h2 e5 H! J4 {/ N# W6 [  ]

5 c) d, K& Z1 m4 M& ^4 `9 _) Q( R+ [0 K
3 L" W8 [& F9 Y
聲明:
! q# v. y: ]$ m聲明:文章來源網(wǎng)絡,作者:Arrow。本號對所有原創(chuàng)、轉(zhuǎn)載文章的陳述與觀點均保持中立,推送文章僅供讀者學習和交流。文章、圖片等版權(quán)歸原作者享有,如有侵權(quán),聯(lián)系刪除。投稿/招聘/推廣/宣傳 請加微信:woniu26a推薦閱讀▼& `3 j5 X; u% d( E+ B# b
電路設計-電路分析
: L* k+ s7 G* B" E2 h) Y8 X2 Semc相關文章
( }7 A8 J5 k7 A9 f1 y9 t電子元器件
4 a# o: h, J) ]8 ]
后臺回復“加群”,管理員拉你加入同行技術交流群。
回復

使用道具 舉報

發(fā)表回復

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則


聯(lián)系客服 關注微信 下載APP 返回頂部 返回列表