|
1bydqljjf4y64078231.gif (1.67 KB, 下載次數(shù): 0)
下載附件
保存到相冊
1bydqljjf4y64078231.gif
2024-8-19 12:23 上傳
: F* ]: p% H, Q
點擊上方名片關注了解更多
. y R7 w) R$ Q# _5 G0 H+ M5 }" I I4 t" _
; z! B) x' V3 l: J- f' m
USB接口隨處可見,手機、電腦、電視,以及各種電子產(chǎn)品充電口(雖然是USB-C,但它也是USB)都有USB的身影。5 {3 t. \5 s: t$ B o# J# A
USB應用非常廣泛,很多嵌入式設備也具有USB通信能力,這里給大家分享一下USB通信協(xié)議主要內容,新手都能看明白(當然,最好還是有一定通信協(xié)議基礎才行)。
2 v1 o6 ]2 X, e9 p& i* o
! J6 g: u, o# e5 E 1、基本概念一個【傳輸】(控制、批量、中斷、等時):由多個【事務】組成;一個【事務】(IN、OUT、SETUP):由一多個【Packet】組成。USB數(shù)據(jù)在【主機軟件】與【USB設備特定的端點】間被傳輸。【主機軟件】與【USB設備特定的端點】間的關聯(lián)叫做【pipes】。一個USB設備可以有多個管道(pipes)。 2 、包(Packet)包(Packet)是USB系統(tǒng)中信息傳輸?shù)幕締卧袛?shù)據(jù)都是經(jīng)過打包后在總線上傳輸?shù)。?shù)據(jù)在 USB總線上的傳輸以包為單位,包只能在幀內傳輸。高速USB 總線的幀周期為125us,全速以及低速 USB 總線的幀周期為 1ms。幀的起始由一個特定的包(SOF 包)表示,幀尾為 EOF。EOF不是一個包,而是一種電平狀態(tài),EOF期間不允許有數(shù)據(jù)傳輸。注意:雖然高速USB總線和全速/低速USB總線的幀周期不一樣,但是SOF包中幀編號的增加速度是一樣的,因為在高速USB系統(tǒng)中,SOF包中幀編號實際上取得是計數(shù)器的高11位,最低三位作為微幀編號沒有使用,因此其幀編號的增加周期也為 1mSUSB總線上的情形是怎樣的?
. n7 B7 N! n; E- y4 N! ]: U0 `
9 f6 `2 W [% H8 V% F' z v
opjkfvdiib164078331.png (23.61 KB, 下載次數(shù): 0)
下載附件
保存到相冊
opjkfvdiib164078331.png
2024-8-19 12:23 上傳
! M! C3 a& G) C
包是USB總線上數(shù)據(jù)傳輸?shù)淖钚挝,不能被打斷或干擾,否則會引發(fā)錯誤。若干個數(shù)據(jù)包組成一次事務傳輸,一次事務傳輸也不能打斷,屬于一次事務傳輸?shù)膸讉包必須連續(xù),不能跨幀完成。一次傳輸由一次到多次事務傳輸構成,可以跨幀完成。
" G4 r$ P. w4 ?* NUSB包由五部分組成,即同步字段(SYNC)、包標識符字段(PID)、數(shù)據(jù)字段、循環(huán)冗余校驗字段(CRC)和包結尾字段(EOP),包的基本格式如下圖:
+ w) c: E1 q* }0 n
01gr0c2eo4d64078431.png (27.38 KB, 下載次數(shù): 0)
下載附件
保存到相冊
01gr0c2eo4d64078431.png
2024-8-19 12:23 上傳
: J5 h) }) L2 ]2 A
1.1 PID類型(即包類型)% c! M( } Y1 m1 |
1pklyhoeoks64078531.png (56.36 KB, 下載次數(shù): 0)
下載附件
保存到相冊
1pklyhoeoks64078531.png
2024-8-19 12:23 上傳
j6 a I3 y) U4 @1 L
3 i3 A4 u6 y. t- M; y+ W
kxpmkxludm064078631.png (55.32 KB, 下載次數(shù): 0)
下載附件
保存到相冊
kxpmkxludm064078631.png
2024-8-19 12:23 上傳
* p' S/ W% \+ M# P1.2 Token Packets
( w" k" c, B J- k
hleb0a3vdac64078731.png (10.87 KB, 下載次數(shù): 0)
下載附件
保存到相冊
hleb0a3vdac64078731.png
2024-8-19 12:23 上傳
8 E! `0 l9 ^- ]+ Y+ M' z8 o此格式適用于IN、OUT、SETUP、PING。
; H; |2 V3 |( WPID 數(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ā)送一次;% Y8 V- h& R ]9 b; }( [
對于high-speed總線,每隔125 μs ±0.0625 μs發(fā)送一次;
4 w' o) }! B) Y& E[/ol]SOF包構成如下圖所示" V5 X! ^) n( i/ _: B, U# `) g
sp3ej04vliq64078831.png (11.4 KB, 下載次數(shù): 0)
下載附件
保存到相冊
sp3ej04vliq64078831.png
2024-8-19 12:23 上傳
& v& u; `+ |6 F4 c* }
5 W! k4 m; ~) s) g$ A% m& C4 K) U
5vdybx5mxxx64078931.png (36.3 KB, 下載次數(shù): 0)
下載附件
保存到相冊
5vdybx5mxxx64078931.png
2024-8-19 12:23 上傳
. l( z( r' ?$ [+ G( ?) j6 V& x' K# ~1.4 Data Packets: r, A7 D6 O3 T5 s1 X
dhai3aabr0z64079031.png (12.03 KB, 下載次數(shù): 0)
下載附件
保存到相冊
dhai3aabr0z64079031.png
2024-8-19 12:23 上傳
@" I2 b: f5 p( C8 P, U0 E
有四種類類型的數(shù)據(jù)包:DATA0, DATA1, DATA2,and MDATA,且由PID來區(qū)分。DATA0和DATA1被定義為支持數(shù)據(jù)切換同步(data toggle synchronization)。
7 w, h& z. Y3 x* y! E) v# u" D1.5 Handshake Packets
: W+ V5 x% }7 D" j4 s; q ]1 E
4fmdgwr1aee64079131.png (5.26 KB, 下載次數(shù): 0)
下載附件
保存到相冊
4fmdgwr1aee64079131.png
2024-8-19 12:23 上傳
6 r n- [' d R) gACK: 對于IN事務,它將由host發(fā)出;對于OUT、SETUP和PING事務,它將由device發(fā)出。% D9 w( U9 Q. j" ?9 d
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ù)包的過程。【正!康妮斎胧聞仗幚9 K& s( ?" s! o$ g
( E$ y7 h2 l5 q2 Q- l& L. p
2cl3dbu03pd64079231.png (6.42 KB, 下載次數(shù): 0)
下載附件
保存到相冊
2cl3dbu03pd64079231.png
2024-8-19 12:23 上傳
$ }. d8 p1 ?8 r* y【設備忙】時的輸入事務處理
$ A/ L7 @) x: F$ Z2 E; k2 S9 ^
6 o1 S; T2 _+ W2 R0 j' O
lmmn53jowkm64079331.png (5.05 KB, 下載次數(shù): 0)
下載附件
保存到相冊
lmmn53jowkm64079331.png
2024-8-19 12:23 上傳
$ X. J# x1 I2 r, t
【設備出錯】時的輸入事務處理
& U' r7 E+ t P6 D. W' Q
" o& t4 G5 s$ I: o
ccucuo2dlwo64079431.png (3.77 KB, 下載次數(shù): 0)
下載附件
保存到相冊
ccucuo2dlwo64079431.png
2024-8-19 12:23 上傳
. X1 |, k+ J, A
2.2. 輸出(OUT)事務處理輸出事務處理:表示USB主機把一個數(shù)據(jù)包輸出到總線上的某個USB設備接收的過程。【正!康妮敵鍪聞仗幚
- q5 C4 P! l8 u, k) q1 {" A# Q* ^: D
tj53ayenevq64079531.png (5.41 KB, 下載次數(shù): 0)
下載附件
保存到相冊
tj53ayenevq64079531.png
2024-8-19 12:23 上傳
. U% O" n- z. f$ P& _
【設備忙時】的輸出事務處理
2 D* p8 W; ]: B+ B0 k* M" _% A* @
4 H8 C; \- m# P& {6 g) h
nrilgfx3un364079631.png (3.01 KB, 下載次數(shù): 0)
下載附件
保存到相冊
nrilgfx3un364079631.png
2024-8-19 12:23 上傳
& Q: f2 O( r- d3 U0 s
【設備出錯】的輸出事務處理) f/ w; r+ L |& j/ R, ]
* s& _0 C2 H7 E% ]! O
dk1rsrqswkv64079731.png (3.04 KB, 下載次數(shù): 0)
下載附件
保存到相冊
dk1rsrqswkv64079731.png
2024-8-19 12:23 上傳
( |4 K" f& O. j1 B, U7 U" w
2.3 設置(SETUP)事務處理【正!康脑O置事務處理! c6 X: U+ l3 R& x$ I5 g' J! c3 I
! @& d8 i# ^1 p: J# u* D& W/ F
pplhmxkgftf64079831.png (5.06 KB, 下載次數(shù): 0)
下載附件
保存到相冊
pplhmxkgftf64079831.png
2024-8-19 12:23 上傳
- A& i+ S Q; I0 \6 j! k: a
【設備忙時】的設置事務處理
9 s4 v- ~6 I5 p8 H% R" x
" K$ ?2 ?0 O8 y9 d
o51wtuzohsx64079931.png (4.37 KB, 下載次數(shù): 0)
下載附件
保存到相冊
o51wtuzohsx64079931.png
2024-8-19 12:23 上傳
- f0 I4 ~) a2 ~5 t& C; ]' O( a* q【設備出錯】的設置事務處理, g0 W) @: u6 v
5 p% ^9 W( U8 a: A+ q! v
irkujbf34hv64080031.png (3.16 KB, 下載次數(shù): 0)
下載附件
保存到相冊
irkujbf34hv64080031.png
2024-8-19 12:23 上傳
; b7 h, w8 X" U/ C 3、USB傳輸類型 在USB的傳輸中,定義了4種傳輸類型:控制傳輸 (Control Transfer)/ {+ _) k& d% L
中斷傳輸 (Interrupt Transfer)
* x: [8 @* `$ |& B, m; Q批量傳輸 (Bulk Transfer)
$ d# O. y0 O# D( g7 x. U8 C* B同步傳輸 (Isochronous)) [! ~3 s- c1 a; S1 V, e3 `' \
3.1 控制傳輸 (Control Transfer)控制傳輸由2~3個階段組成:建立階段(Setup)
{% [7 b9 J+ E7 D數(shù)據(jù)階段(無數(shù)據(jù)控制沒有此階段)(DATA)
* m$ Q; f3 R) U狀態(tài)階段(Status)0 z9 l. }- \0 q+ T" W
[/ol]每個階段都由一次或多次(數(shù)據(jù)階段)事務傳輸組成(Transaction)?刂茢(shù)據(jù)由USB系統(tǒng)軟件用于配置設備(在枚舉時),其它的驅動軟件可以選擇使用control transfer實現(xiàn)具體的功能,數(shù)據(jù)傳輸是不可丟失的。3.1.1 建立階段主機從USB設備獲取配置信息,并設置設備的配置值。建立階段的數(shù)據(jù)交換包含了SETUP令牌封包、緊隨其后的DATA0數(shù)據(jù)封包以及ACK握手封包。它的作用是執(zhí)行一個設置(概念含糊)的數(shù)據(jù)交換,并定義此控制傳輸?shù)膬热?即:在Data Stage中IN或OUT的data包個數(shù),及發(fā)送方向,在Setup Stage已經(jīng)被設定)。$ G$ d5 L+ N% C, G1 U
yvyhbyotvan64080131.png (16.36 KB, 下載次數(shù): 0)
下載附件
保存到相冊
yvyhbyotvan64080131.png
2024-8-19 12:23 上傳
9 O# L) ?( {$ B" g+ {, t
3.1.2 數(shù)據(jù)階段根據(jù)數(shù)據(jù)階段的數(shù)據(jù)傳輸?shù)姆较,控制傳輸又可分?種類型:控制讀取(讀取USB描述符)
2 z( b/ h" C3 o( M控制寫入(配置USB設備)
0 `: c) X" }( Y. U/ |無數(shù)據(jù)控制
! o6 k& \/ r7 h/ w9 R5 {[/ol]數(shù)據(jù)傳輸階段:用來傳輸主機與設備之間的數(shù)據(jù)。控制讀取' L; [8 F" T0 o9 P! j$ B
是將數(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握手信息包。控制寫入
6 m2 ^/ s3 s' t! F是將數(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握手信息包。
; V; J8 z) E. {( | |* c+ }9 _% P4 U1 \$ {2 \! ]
3.1.3 狀態(tài)階段狀態(tài)階段:用來表示整個傳輸?shù)倪^程已完全結束。狀態(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果。若數(shù)據(jù)量比較大,將采用多次批量事務傳輸來完成全部數(shù)據(jù)的傳輸,傳輸過程中數(shù)據(jù)包的PID 按照 DATA0-DATA1-DATA0-…的方式翻轉,以保證發(fā)送端和接收端的同步。USB 允許連續(xù) 3次以下的傳輸錯誤,會重試該傳輸,若成功則將錯誤次數(shù)計數(shù)器清零,否則累加該計數(shù)器。超過三次后,HOST 認為該端點功能錯誤(STALL),放棄該端點的傳輸任務。一次批量傳輸(Transfer)由 1 次到多次批量事務傳輸(Transaction)組成。翻轉同步:發(fā)送端按照 DATA0-DATA1-DATA0-…的順序發(fā)送數(shù)據(jù)包,只有成功的事務傳輸才會導致 PID 翻轉,也就是說發(fā)送端只有在接收到 ACK 后才會翻轉 PID,發(fā)送下一個數(shù)據(jù)包,否則會重試本次事務傳輸。同樣,若在接收端發(fā)現(xiàn)接收到到的數(shù)據(jù)包不是按照此順序翻轉的,比如連續(xù)收到兩個 DATA0,那么接收端認為第二個 DATA0 是前一個 DATA0 的重傳。它通過在硬件級執(zhí)行“錯誤檢測”和“重傳”來確保host與device之間“準確無誤”地傳輸數(shù)據(jù),即可靠傳輸。它由三種包組成(即IN事務或OUT事務):token5 |! A" }# x: [) K
data
% s9 J) h1 M6 s$ y7 P5 z! hhandshake
u2 |9 D; \/ K! B: J[/ol]" ]. L7 p7 X0 }5 k" ?
) |7 n7 a+ b. F1 |+ ?For IN Token (即:IN Transaction)
5 F' I, b( u l0 D' u1 u[/ol]ACK: 表示host正確無誤地接收到數(shù)據(jù)$ b% p8 r6 M) {' h3 u& x4 o
NAK: 指示設備暫時不能返回或接收數(shù)據(jù) (如:設備忙)
2 ?) @; m& Q ESTALL:指示設備永遠停止,需要host軟件的干預 (如:設備出錯), a- M( A+ t' I. n" ]2 K
For OUT Token (即:OUT Transaction)
5 a% I4 c/ f0 u8 X( w3 V+ |. ^# q[/ol]如果接收到的數(shù)據(jù)包有誤,如:CRC錯誤,Device不發(fā)送任何handshake包ACK: Device已經(jīng)正確無誤地接收到數(shù)據(jù)包,且通知Host可以按順序發(fā)送下一個數(shù)據(jù)包. y5 i# {$ q+ ~
NAK: Device 已經(jīng)正確無誤地接收到數(shù)據(jù)包,且通知Host重傳數(shù)據(jù),由于Device臨時狀況(如buffer滿)
" b( E% l1 E1 \/ p8 u1 t8 S" TSTALL: 指示Device endpoint已經(jīng)停止,且通知Host不再重傳
( {* F) n( L2 O9 i) OBulk讀寫序列$ L$ s9 p% d7 O9 T9 [
[/ol]9 Y: E/ J( K X
5 Y* s- c% Z1 i4 ?9 G即由一系統(tǒng)IN事務或OUT事務組成。3.3 中斷傳輸(Interrupt Transfer)中斷傳輸由IN或OUT事務組成。中斷傳輸在流程上除不支持PING 之外,其他的跟批量傳輸是一樣的。他們之間的區(qū)別也僅在于事務傳輸發(fā)生的端點不一樣、支持的最大包長度不一樣、優(yōu)先級不一樣等這樣一些對用戶來說透明的東西。主機在排定中斷傳輸任務時,會根據(jù)對應中斷端點描述符中指定的查詢間隔發(fā)起中斷傳輸。中斷傳輸有較高的優(yōu)先級,僅次于同步傳輸。同樣中斷傳輸也采用PID翻轉的機制來保證收發(fā)端數(shù)據(jù)同步。下圖為中斷傳輸?shù)牧鞒虉D。中斷傳輸方式總是用于對設備的查詢,以確定是否有數(shù)據(jù)需要傳輸。因此中斷傳輸?shù)姆较蚩偸菑腢SB設備到主機。0 M* s- x0 A/ T& r
2 ?1 n( J! k6 L& c* E
DATA0或DATA1中的包含的是中斷信息,而不是中斷數(shù)據(jù)。3.4 同步傳輸(Isochronous Transfer)它由兩種包組成:
$ G/ t6 M" p$ K, u8 d# d; Z/ a' Stoken2 _% G) `9 u" o
data! h9 u# N& k6 y; d
[/ol]同步傳輸不支持“handshake”和“重傳能力”,所以它是不可靠傳輸。同步傳輸是不可靠的傳輸,所以它沒有握手包,也不支持PID翻轉。主機在排定事務傳輸時,同步傳輸有最高的優(yōu)先級。同步傳輸適用于必須以固定速率抵達或在指定時刻抵達,可以容忍偶爾錯誤的數(shù)據(jù)上。實時傳輸一般用于麥 克風、喇叭、UVC Camera等設備。實時傳輸只需令牌與數(shù)據(jù)兩個信息包階段,沒有握手包,故數(shù)據(jù)傳錯時不會重傳。
" K8 i3 v' I6 N% k# M# l* S( b2 [7 K) P( `# d; X5 x/ f
: ^- p9 A5 T1 L V; v! u
' X& a8 }) v0 ^1 f3 M$ p
來源地址:https://blog.csdn.net/myarrow/article/details/8484113
8 I) |) o, U5 ^& |- b% @. B' ^0 I) }5 U( g& ?6 N, V
1 j# H0 s2 A0 Q* V, g' s/ `
! L+ J: e$ r1 z/ [聲明:
5 Q4 l4 v( {" Z/ U! n聲明:文章來源網(wǎng)絡,作者:Arrow。本號對所有原創(chuàng)、轉載文章的陳述與觀點均保持中立,推送文章僅供讀者學習和交流。文章、圖片等版權歸原作者享有,如有侵權,聯(lián)系刪除。投稿/招聘/推廣/宣傳 請加微信:woniu26a推薦閱讀▼
* u3 i/ }8 g2 }: g電路設計-電路分析7 f( |' O0 [) l$ q) Q5 g5 q& F
emc相關文章
! N; k9 c9 b! p電子元器件
( G# f2 [ y4 ~( ]& S/ n, H后臺回復“加群”,管理員拉你加入同行技術交流群。 |
|