的HID通信協(xié)議_第1頁
的HID通信協(xié)議_第2頁
的HID通信協(xié)議_第3頁
的HID通信協(xié)議_第4頁
的HID通信協(xié)議_第5頁
已閱讀5頁,還剩4頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、USB事務處理是主機和設(shè)備之間數(shù)據(jù)傳輸?shù)幕締挝?,由一系列具有特定格式的信息包組成。因此,要了解完整的USB通信協(xié)議,必須從USB的信息傳輸單元包及其數(shù)據(jù)域談起。通過由下而上,從簡單至復雜的通信協(xié)議單位組成各種復雜的通信協(xié)議,進而構(gòu)建出完整的通信協(xié)議。 16.4.1 包 包(Packet)是USB系統(tǒng)中信息傳輸?shù)幕締卧袛?shù)據(jù)都是經(jīng)過打包后在總線上傳輸?shù)?。首先了解一下包的組成。 USB包由五部分組成,即同步(SYNC)字段、包標識符(PID)字段、數(shù)據(jù)字段、循環(huán)冗余校驗(CRC)字段和包結(jié)尾(EOP)字段,包的基本格式如下: 同步字段(SYNC) PID字段 數(shù)據(jù)字段 CRC字段 包結(jié)尾字

2、段(EOP) 在USB的數(shù)據(jù)傳輸中,所有的傳輸包都起始于SYNC,接著是PID,后面是包中所包含的數(shù)據(jù)信息,接下來是用來檢測包中數(shù)據(jù)錯誤的循環(huán)冗余校驗信息,最后以包結(jié)尾作為結(jié)束標志。下面我們將一一介紹每個字段。 1同步(SYNC)字段 SYNC字段由8位組成,作為每個數(shù)據(jù)信息包的前導。顧名思義,它是用來產(chǎn)生同步作用的,目的是使USB設(shè)備與總線的包傳輸率同步,它的數(shù)值固定為00000001。 2包標識符(PID)字段 PID字段是緊隨在SYNC字段后面,用來表示數(shù)據(jù)信息包的類型。在USB協(xié)議中,根據(jù)PID的不同,USB包有著不同的類型,分別表示具有特定的意義。如下所示: PID0 PID1 PI

3、D2 PID3 包標識符長度為一個字節(jié)(8個數(shù)據(jù)位),由4個位的包類型字段和4個位的校驗字段構(gòu)成。PID是USB包類型的唯一標志,USB主機和USB設(shè)備在接收到包后,必須首先對包標識符解碼得到包的類型,并判斷其意義從而做出下一個反應。包標識符中的校驗字段是通過對類型字段的每個位求反碼產(chǎn)生的,它是用來對包類型字段進行錯誤檢測用的,旨在保證對包的標識符譯碼的可靠性,如果4個檢驗位不是它們各自的類型位的反碼,則說明標識符中的信息有錯誤。 表16-2中列出了信息包的類型,包括令牌、數(shù)據(jù)、握手或特殊四種信息包類型。為簡化對USB的認識,有關(guān)高速傳輸?shù)牟糠譀]有在表中列出。 3數(shù)據(jù)字段 在USB包中,數(shù)據(jù)字

4、段是用來攜帶主機與設(shè)備之間要傳遞的信息,其內(nèi)容和長度根據(jù)包標識符、傳輸類型的不同而各不相同。并非所有的USB包都必須有數(shù)據(jù)字段,例如握手包、專用包和SOF令牌包就沒有數(shù)據(jù)字段。在USB包中,數(shù)據(jù)字段可以包含設(shè)備地址、端點號、幀序列號以及數(shù)據(jù)等內(nèi)容。在總線傳輸中,總是首先傳輸字節(jié)的最低位,最后傳輸字節(jié)的最高位。 (1) 設(shè)備地址(ADDR)數(shù)據(jù)域 ADDR數(shù)據(jù)域由7位組成,可用來尋址多達127個外圍設(shè)備。 (2) 端點(ENDP)數(shù)據(jù)域 ENDP數(shù)據(jù)域由4位組成。通過這4個位最多可尋址出32個端點。這個ENDP數(shù)據(jù)域僅用在IN、OUT與SETUP令牌信息包中。對于慢速設(shè)備可支持端點0以及端點1作

5、為中斷傳輸模式,而全速設(shè)備則可以擁有16個輸入端點(IN)與16個輸出端點(OUT)共32個端點。 (3) 幀序列號 當USB令牌包的PID為SOF時,其數(shù)據(jù)字段必須為11位的幀序列號。幀序列號由主機產(chǎn)生,且每個數(shù)據(jù)幀自動加一,最大數(shù)值為0x7FF。當幀序列號達到最大數(shù)時將自動從0開始循環(huán)。 (4) 數(shù)據(jù) 它僅存于DATA信息包內(nèi),根據(jù)不同的傳輸類型,擁有不同的字節(jié)大小,從0到1023字節(jié)(實時傳輸)。 4循環(huán)冗余校驗(CRC)字段 根據(jù)不同的信息包類型,CRC數(shù)據(jù)域由不同數(shù)目的位所組成。其中重要的數(shù)據(jù)信息包采用CRC16的數(shù)據(jù)域(16個位),而其余的信息包類型則采用CRC5的數(shù)據(jù)域(5個位)

6、。其中的循環(huán)冗余碼校驗CRC,是一種錯誤檢測技術(shù)。由于數(shù)據(jù)在傳輸時,有時候會發(fā)生錯誤,因此CRC可根據(jù)數(shù)據(jù)算出一個校驗值,然后依此判斷數(shù)據(jù)的正確性。 5包結(jié)尾(EOP)字段 包的發(fā)送方在包的結(jié)尾發(fā)出包結(jié)尾信號。它表現(xiàn)為差分線路的兩根數(shù)據(jù)線保持2比特低位時間和1比特空閑位時間。USB主機根據(jù)EOP判斷數(shù)據(jù)包的結(jié)束。 16.4.2 信息包格式 根據(jù)信息包所實現(xiàn)的功能,其可以分為3種類型:令牌包、數(shù)據(jù)包和握手包。其中,令牌包定義了數(shù)據(jù)傳輸?shù)念愋?,?shù)據(jù)包中含有需要傳輸?shù)臄?shù)據(jù),握手包指明了數(shù)據(jù)接收是否成功。 1令牌(token)包 在USB系統(tǒng)中,只有主機才能發(fā)出令牌包。令牌包定義了數(shù)據(jù)傳輸?shù)念愋?,它?/p>

7、事務處理的第一階段。令牌包格式如下: 8位 8位 7位 4位 5位 SYNC PID ADDR ENDP CRC5 令牌包中較為重要的是SETUP、IN和OUT這三個令牌包。它們用來在根集線器和設(shè)備端點之間建立數(shù)據(jù)傳輸。一個IN包用來建立一個從設(shè)備到根集線器的數(shù)據(jù)傳送,一個OUT包用來建立從根集線器到設(shè)備的數(shù)據(jù)傳輸。IN包和OUT包可以對任何設(shè)備上的任何端點編址。一個SETUP包是一個OUT包的特殊情形,它是“高優(yōu)先級的”,也就是說設(shè)備必須接受它,即使設(shè)備正在進行數(shù)據(jù)傳輸操作的過程中也要對其進行響應。SETUP包總是指向端點0的。 2數(shù)據(jù)(data)包 一個數(shù)據(jù)信息包包含了4個數(shù)據(jù)域:SYNC

8、、PID、DATA與CRC16。在這里要注意的是DATA數(shù)據(jù)域內(nèi)所放置的位值,需根據(jù)USB設(shè)備的傳輸速度(慢速、高速與全速)以及傳輸類型(中斷傳輸、批量傳輸、等時傳輸)而定,且須以8字節(jié)為基本單位。也就是,若傳輸?shù)臄?shù)據(jù)不足8字節(jié),或傳輸?shù)阶詈笏S嗟囊膊蛔?字節(jié),仍須傳輸8字節(jié)的數(shù)據(jù)域。格式如下: 8位 8位 01023字節(jié) 16位 SYNC PID DATA CRC16 3握手(Handshake)包 握手信息包是最簡單的信息包類型。在這個握手信息包中僅包含一個PID數(shù)據(jù)域而已,它的格式如下所列: 8位 8位 SYNC PID 其中僅包含SYNC與PID兩個數(shù)據(jù)域。 16.4.3 事務 在U

9、SB上數(shù)據(jù)信息的一次接收或發(fā)送的處理過程稱為事務處理(Transaction)。事務處理的類型包括輸入(IN)事務處理、輸出(OUT)事務處理、設(shè)置(SETUP)事務處理和幀開始、幀結(jié)尾等類型。在輸出(OUT)事務處理和設(shè)置(SETUP)事務處理中,緊接著SETUP和OUT包后的是DATA包,DATA0和DATA1包是交替地發(fā)送的,在DATA包后面,設(shè)備將回應一個握手信號,如果設(shè)備可以接收數(shù)據(jù),就回應ACK包,如果設(shè)備忙,就回應NAK包,如果設(shè)備出錯,則回應STALL包;在IN事務中,IN包后面是設(shè)備發(fā)來的DATA包或NAK包或STALL包,若設(shè)備忙或出錯,就發(fā)NAK包或STALL包給主機,若

10、設(shè)備數(shù)據(jù)準備好發(fā)送,則發(fā)DATA包,DATA0和DATA1包也是交替地發(fā)送的,緊接著DATA包后面是主機發(fā)給設(shè)備的握手包,ACK表示主機可以接收數(shù)據(jù),NAK包代表主機忙,STALL包代表主機出錯。下面我們再分別介紹這些事務。 1輸入(IN)事務處理 輸入事務處理表示USB主機從總線上的某個USB設(shè)備接收一個數(shù)據(jù)包的過程,接下來分析輸入事務處理的各種典型情況: (1) 正常的輸入事務處理 1主機-設(shè)備(令牌信息包) SYNC IN ADDR ENDP CRC5 2設(shè)備-主機(數(shù)據(jù)信息包) SYNC DATA0 DATA CRC16 3主機-設(shè)備(握手信息包) SYNC ACK (2) 設(shè)備忙時的

11、輸入事務處理 1主機-設(shè)備(令牌信息包) SYNC IN ADDR ENDP CRC5 2設(shè)備-主機(握手信息包) SYNC NAK (3) 設(shè)備出錯時的輸入事務處理 1主機-設(shè)備(令牌信息包) SYNC IN ADDR ENDP CRC5 2設(shè)備-主機(握手信息包) SYNC STALL 2輸出(OUT)事務處理 (1) 正常的輸出事務處理 1主機-設(shè)備(令牌信息包) SYNC OUT ADDR ENDP CRC5 2主機-設(shè)備(數(shù)據(jù)信息包) SYNC DATA0 DATA CRC16 3設(shè)備-主機(握手信息包) SYNC ACK (2) 設(shè)備忙時的輸出事務處理 1主機-設(shè)備(令牌信息包)

12、SYNC OUT ADDR ENDP CRC5 2主機-設(shè)備(數(shù)據(jù)信息包) SYNC DATA0 DATA CRC16 3設(shè)備-主機(握手信息包) SYNC NAK (3) 設(shè)備出錯時的輸出事務處理 1主機-設(shè)備(令牌信息包) SYNC OUT ADDR ENDP CRC5 2主機-設(shè)備(數(shù)據(jù)信息包) SYNC DATA0 DATA CRC16 3設(shè)備-主機(握手信息包) SYNC STALL 3設(shè)置(SETUP)事務處理 (1) 正常的設(shè)置事務處理 1主機-設(shè)備(令牌信息包) SYNC SETUP ADDR ENDP CRC5 2主機-設(shè)備(數(shù)據(jù)信息包) SYNC DATA0 DATA CR

13、C16 3設(shè)備-主機(握手信息包) SYNC ACK (2) 設(shè)備忙時的設(shè)置事務處理 1主機-設(shè)備(令牌信息包) SYNC SETUP ADDR ENDP CRC5 2主機-設(shè)備(數(shù)據(jù)信息包) SYNC DATA0 DATA CRC16 3設(shè)備-主機(握手信息包) SYNC NAK (3) 設(shè)備出錯時的設(shè)置事務處理 1主機-設(shè)備(令牌信息包) SYNC SETUP ADDR ENDP CRC5 2主機-設(shè)備(數(shù)據(jù)信息包) SYNC DATA0 DATA CRC16 3設(shè)備-主機(握手信息包) SYNC STALL 16.4.4 USB傳輸類型 在USB的傳輸中,制定了4種傳輸類型:控制傳輸、中

14、斷傳輸、批量傳輸以及實時傳輸。這里只詳細介紹控制傳輸,其他傳輸類型只作簡要說明。 1控制傳輸 控制傳輸是USB傳輸中最重要的傳輸,唯有正確地執(zhí)行完控制傳輸,才能進一步正確地執(zhí)行其他傳輸模式。 由于每個USB設(shè)備可能速度、傳輸?shù)陌拇笮〉刃畔⒂锌赡懿煌?,因此每個USB設(shè)備內(nèi)部都記錄著該設(shè)備的一些信息(也就是接下來將要介紹的設(shè)備描述符),當在主機上檢測到USB設(shè)備時,系統(tǒng)軟件必須讀取設(shè)備描述符,以確定該設(shè)備的類型和操作特性,以及對該設(shè)備進行相應的配置,這些工作都是通過控制傳輸來完成。每個USB設(shè)備都必須實現(xiàn)一個缺省的控制端點,該端點總是0號端點。 控制傳輸類型分為23個階段:設(shè)置階段、數(shù)據(jù)階段(無

15、數(shù)據(jù)控制沒有此階段)以及狀態(tài)階段。根據(jù)數(shù)據(jù)階段的數(shù)據(jù)傳輸?shù)姆较?,控制傳輸又可分?種類型:控制讀?。ㄗx取USB描述符)、控制寫入(配置USB設(shè)備)以及無數(shù)據(jù)控制。以下介紹各階段的工作。 階段一:設(shè)置階段 USB設(shè)備在正常使用之前,必須先配置,本階段由主機將信息傳送給USB設(shè)備,定義對USB設(shè)備的請求信息(如:讀設(shè)備描述符)。主機一般會從USB設(shè)備獲取配置信息后再確定此設(shè)備有哪些功能。作為配置的一部分,主機會設(shè)置設(shè)備的配置值。我們統(tǒng)稱這一階段為設(shè)置階段。 設(shè)置階段由設(shè)置事務完成,也就是該階段包含了SETUP令牌信息包、緊隨其后的DATA0數(shù)據(jù)信息包(該信息包里的數(shù)據(jù)即為設(shè)備請求,本章將后續(xù)介紹)

16、以及ACK握手信息包。它的作用是執(zhí)行一個設(shè)置的數(shù)據(jù)交換,并定義此控制傳輸?shù)膬?nèi)容。 階段二:數(shù)據(jù)傳輸階段 數(shù)據(jù)傳輸階段是用來傳輸主機與設(shè)備之間的數(shù)據(jù)。 控制讀取是將數(shù)據(jù)從設(shè)備讀到主機上,讀取的數(shù)據(jù)USB設(shè)備描述符。該過程如圖16-8所示。對每一個數(shù)據(jù)信息包而言,首先,主機會發(fā)送一個IN令牌信息包,表示要讀數(shù)據(jù)進來。然后,設(shè)備將數(shù)據(jù)通過DATA1數(shù)據(jù)信息包回傳給主機。最后,主機將以下列的方式加以響應:當數(shù)據(jù)已經(jīng)正確接收時,主機送出ACK令牌信息包;當主機正在忙碌時,發(fā)出NAK握手信息包;當發(fā)生了錯誤時,主機發(fā)出STALL握手信息包。 控制寫入則是將數(shù)據(jù)從主機傳到設(shè)備上,所傳的數(shù)據(jù)即為對USB設(shè)備的

17、配置信息,該過程如圖16-9所示。對每一個數(shù)據(jù)信息包而言,主機將會送出一個OUT令牌信息包,表示數(shù)據(jù)要送出去。緊接著,主機將數(shù)據(jù)通過DATA0數(shù)據(jù)信息包傳遞至設(shè)備。最后,設(shè)備將以下列方式加以響應:當數(shù)據(jù)已經(jīng)正確接收時,設(shè)備送出ACK令牌信息包;當設(shè)備正在忙碌時,設(shè)備發(fā)出NAK握手信息包;當發(fā)生了錯誤時,設(shè)備發(fā)出STALL握手信息包。 階段三:狀態(tài)階段 狀態(tài)階段用來表示整個傳輸?shù)倪^程已經(jīng)完全結(jié)束了。請注意,狀態(tài)階段傳輸?shù)姆较虮仨毰c數(shù)據(jù)階段的方向相反。即原來是IN令牌信息包,這個階段應為OUT令牌信息包;反之,原來是OUT令牌信息包,這個階段應為IN令牌信息包。對于控制讀取而言,主機會送出OUT令

18、牌信息包,其后再跟著0長度的DATA1信息包。而此時,設(shè)備也會做出相對應的動作,送ACK握手信息包、NAK握手信息包或STALL握手信息包。相對地對于控制寫入傳輸,主機會送出IN令牌信息包,然后設(shè)備送出表示完成狀態(tài)階段的0長度的DATA1信息包,主機再做出相對應的動作:送ACK握手信息包、NAK握手信息包或STALL握手信息包。 2實時傳輸 實時傳輸適用于必須以固定速率抵達或在指定時刻抵達,可以容忍偶爾錯誤的數(shù)據(jù)上。實時傳輸一般用于麥克風、喇叭等設(shè)備。 實時傳輸只需令牌與數(shù)據(jù)兩個信息包階段,沒有握手包,故數(shù)據(jù)傳錯時不會重傳。 3批量傳輸 用于傳輸大量數(shù)據(jù),要求傳輸不能出錯,但對時間沒有要求,適

19、用于打印機、存儲設(shè)備等。 4中斷傳輸 中斷傳輸方式總是用于對設(shè)備的查詢,以確定是否有數(shù)據(jù)需要傳輸。因此中斷傳輸?shù)姆较蚩偸菑腢SB設(shè)備到主機。 16.4.5設(shè)備列舉 1描述符 USB描述符就好像是USB外圍設(shè)備的“身份證”一樣,詳細地記錄著外圍設(shè)備相關(guān)的一切信息。為了描述不同的數(shù)據(jù),就需以不同類型的USB描述符來加以描述,它共有以下幾種類型:設(shè)備描述符、配置描述符、接口描述符和端點描述符,這幾個描述符是必須具有的,下面將結(jié)合實例詳細介紹;其他的描述符,例如,字符串描述符、數(shù)種不同的群組描述符以及報告描述符則可以根據(jù)不同的設(shè)備進行選擇。 (1) 設(shè)備描述符 設(shè)備描述符具有18字節(jié)的長度,并且是主機

20、向設(shè)備請求的第一個描述符。以下列出設(shè)備描述符的范例、數(shù)值以及各個字段的意義: DeviceDesc: ;表示設(shè)備描述符 .byte $12 ; bLength域,表示該描述符的字節(jié)長度為18個字節(jié) .byte $01 ; bDescriptorType域描述符類型,1代表設(shè)備 .byte $10,$01 ; bcdUSB域表示符合USB 1.10規(guī)范,$210代表2.10規(guī)范 .byte $00 ; bDeviceClass域,群組碼,0表示每個接口都有自身的群信息, ;不同的接口操作相互獨立 .byte $00 ; bDeviceSubClass域,設(shè)備次群組(如果群組碼為0,設(shè)備次群組必須

21、為0) .byte $00 ; bDeviceProtocol域,設(shè)備協(xié)議(0表示無群組特定協(xié)議) .byte $08 ; bMaxPacketSize0域,端點0的最大信息包大?。ㄖ荒転?、16、32或64) .byte $70,$0C ; idVendor域,制造商ID(2字節(jié)) .byte $00,$00 ; idProduct域,產(chǎn)品ID(2字節(jié)) .byte $00,$01 ; bcdDevice域,以BCD表示設(shè)備發(fā)行序號(2字節(jié)) .byte $01 ; iManufacturer域,制造商的字符串描述符索引(1字節(jié)),本實例中指 ; String1Desc處的字符串描述符 .b

22、yte $02 ; iProduct域,產(chǎn)品的字符串描述符索引(1字節(jié)),本實例中指 ; String2Desc處的字符串描述符 .byte $00 ; iSerialNumber域,設(shè)備序號的字符串描述符索引(1字節(jié)), ;本實例中指String0Desc處的字符串描述符 .byte $01 ; bNumConfigurations域,配置數(shù)目為1 (2) 配置描述符 配置描述符具有9字節(jié)的長度,針對設(shè)備給予配置的信息。以下列出配置描述符的范例、數(shù)值以及各個字段的意義: ConfigDesc: ;表示配置描述符 .byte $09 ; bLength域,表示該描述符的字節(jié)長度為9個字節(jié)(1字

23、節(jié)) .byte $02 ; bDescriptorType域,描述符類型,2代表配置(1字節(jié)) .byte $20,$00 ; wTotalLength域,描述符的總長度為32個字節(jié),(包括配置描述符 ; 9字節(jié),接口描述符9字節(jié),兩個端點描述符各7字節(jié)) .byte $01 ; bNumInterfaces域,該配置支持的接口數(shù)目(1字節(jié)) .byte $01 ; bConfigurationValue域,配置值,作為Set Configuration請求的配置值 .byte $00 ; iConfiguration域,配置的字符串描述符的索引(1字節(jié)) .byte $C0 ; bmAtt

24、ributes域,配置的屬性(自供電,不具有遠程喚醒的特征) .byte $00 ; MaxPower域,表示當USB設(shè)備操作時,它從總線上 ;獲得的最大電源(以2mA為單位) (3) 接口描述符 接口描述符具有9字節(jié)的長度,用來描述每一個設(shè)備的接口特性。以下列出接口描述符的范例、數(shù)值以及各個字段的意義: InterfaceDesc: ;表示接口描述符 .byte $09 ; bLength域,表示該描述符的字節(jié)長度為9個字節(jié) .byte $04 ; bDescriptorType域,描述符類型,4代表接口 .byte $00 ; bInterfaceNumber域,接口數(shù)目以0為基值(表示一

25、個接口) .byte $00 ; bAlternateSetting域,交互設(shè)置值為0(因為只有一個接口) .byte $02 ; bNumEndpoints域,端點數(shù)目設(shè)置為2 .byte $FF ; bInterfaceClass域,接口群組,$FF表示是供應商說明書 .byte $01 ; bInterfaceSubClass域,接口次群組 .byte $FF ; bInterfaceProtocol域,接口協(xié)議,$FF表示該接口使用的 ;是供應商說明的協(xié)議 .byte $00 ; iInterface域,接口的字符串描述符的索引,本實例沒有 (4) 端點描述符 端點描述符具有7字節(jié)長度

26、,用來描述端點的屬性以及各個端點的位置。該實例中有兩個端點,我們首先介紹端點1描述符: Endpoint1Desc: ;表示端點1描述符 .byte $07 ; bLength域,表示該描述符的字節(jié)長度為7個字節(jié) .byte $05 ; bDescriptorType域,描述符類型,5代表端點 .byte $81 ; bEndpointAddress域,端點地址(0x81IN,0x02=OUT), ;本實例端點編號為1且為IN端點 .byte $03 ; bmAttributes域,傳輸類型的屬性設(shè)置為中斷傳輸 ;(0控制,1實時,2批量,3中斷) .byte $08,$00 ; wMaxPa

27、cketSize域,最大信息包的大小設(shè)置為8個字節(jié) .byte $0A ; bInterval域,輪詢間隔,以ms為單位,在此設(shè)置為10ms 接下來介紹端點2描述符: Endpoint2Desc: ;表示端點2描述符 .byte $07 ; bLength域,表示該描述符的字節(jié)長度為7個字節(jié) .byte $05 ; bDescriptorType域,描述符類型,5代表端點 .byte $02 ; bEndpointAddress域,端點地址(0x81IN,0x02=OUT), ;本實例端點編號為2且為OUT端點 .byte $03 ; bmAttributes域,傳輸類型的屬性設(shè)置為中斷傳輸

28、;(0控制,1實時,2批量,3中斷) .byte $08,$00 ; wMaxPacketSize域,最大信息包的大小設(shè)置為8個字節(jié) .byte $0A ; bInterval域,輪詢間隔,以ms為單位,在此設(shè)置為10ms 2USB設(shè)備請求 在USB接口的通信協(xié)議中,由于主機是取得絕對的主控權(quán),因此,主機與設(shè)備之間就必須遵循某種已溝通的特定命令格式,以達到通信的目的。而這個命令格式就是USB規(guī)范書中所制定的“設(shè)備請求”。這個設(shè)備請求的設(shè)置、清除與取得都須通過控制傳輸?shù)臄?shù)據(jù)交換來完成。表16-3中列出了標準設(shè)備請求的數(shù)據(jù)格式內(nèi)容。 表16-3各字段含義解釋如下。 bmRequestType域決定

29、了特定請求的特征,該域的D7表示在控制傳輸?shù)臄?shù)據(jù)階段,數(shù)據(jù)傳輸?shù)姆较?。如果wLength的值為0,表示沒有數(shù)據(jù)階段,該位可以忽略;D6:5表示了該請求所屬的類型,USB標準中定義了所有的USB設(shè)備必須支持的一系列的標準請求,此外,群組和供應商也可以定義一些其他的請求;D4:0表示接收端,請求可以針對設(shè)備、接口或設(shè)備的一個端點,當針對一個接口或端點時,wIndex域決定了是哪個接口或端點。 bRequest域表示特定請求,如果bmRequestType域的類型字段為0,可以根據(jù)USB指定的一系列的標準請求,結(jié)合該域的值,知道這是什么請求。將在下面介紹這些請求。 wValue域的值根據(jù)請求的不同而

30、不同,用來傳遞一個參數(shù)給設(shè)備。 wIndex域的值根據(jù)請求的不同而不同,用來指定一個接口或端點。 wLength域表示控制傳輸?shù)臄?shù)據(jù)階段中傳輸數(shù)據(jù)的字節(jié)大小,數(shù)據(jù)傳輸?shù)姆较蛴蒪mRequestType域中的D7位決定,如果該域的值為0,表示沒有數(shù)據(jù)階段。 下面結(jié)合實例分別介紹幾個主要的設(shè)備請求。 (1) 清除特性(Clear Feature) 該請求是用來取消一個特性,其格式如下: bmRequestType bRequest wValue wIndex wLength Data 00000000B(設(shè)備) 00000001B(接口) 00000010B(端點) CLEAR_FEATURE(0

31、1H) 特性選擇 0 接口 端點 0 無 該請求中的wValue表示特性選擇器,它對應的值為:0端點,1設(shè)備。當某個特性不允許取消,或該特性根本不存在,或者是指向一個根本不存在的接口或端點時,該請求將會導致設(shè)備請求失敗。如果端點被固件設(shè)為停止狀態(tài),主機軟件(總線驅(qū)動程序)也可以發(fā)送一個值為0的CLEAR_FEATURE命令清除該端點的停止狀態(tài),本實例中就是這樣使用該請求的。 (2) 取得描述符(Get Descriptor) 該請求可以取得USB設(shè)備中存在的特定的描述符,其格式如下: bmRequestType bRequest wValue wIndex wLength Data 10000000B GET_DESCRIPTOR (06H) 描述符類型與描述符指針 0或語言ID 描述符的長度 各個描述符 該請求中的wValue的高字節(jié)表示要取得描述符類型,低字節(jié)表示描述符的索引值,描述的類型有:1表示設(shè)備描述符,2表示配置描述符,3表示字符串描述符,4表示接口描述符,5表示端點描述符。wIndex的值為

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論