在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

USB通信協(xié)議必備基礎知識

嵌入式情報局 ? 來源:嵌入式情報局 ? 2023-11-25 14:39 ? 次閱讀

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

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

USB數(shù)據(jù)在【主機軟件】與【USB設備特定的端點】間被傳輸。【主機軟件】與【USB設備特定的端點】間的關聯(lián)叫做【pipes】。一個USB設備可以有多個管道(pipes)。2. 包(Packet)包(Packet)是 USB 系統(tǒng)中信息傳輸?shù)幕締卧袛?shù)據(jù)都是經過打包后在總線上傳輸?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位,最低三位作為微幀編號沒有使用,因此其幀編號的增加周期也為 1ms。

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

fae20156-8b45-11ee-939d-92fbcf53809c.png

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

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

faece648-8b45-11ee-939d-92fbcf53809c.png

2.1 PID類型(即包類型)

faf0dc6c-8b45-11ee-939d-92fbcf53809c.png

faf9979e-8b45-11ee-939d-92fbcf53809c.png

2.2 Token Packets

fb0d8be6-8b45-11ee-939d-92fbcf53809c.png

此格式適用于 IN、OUT、SETUP、PING。 PID 數(shù)據(jù)傳輸方向:

IN Device->Host

OUT Host->Device

SETUP Host->Device

PING Device->Host

2.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包構成如下圖所示

fb20e542-8b45-11ee-939d-92fbcf53809c.png

fb2f5ed8-8b45-11ee-939d-92fbcf53809c.png

2.4 Data Packets

fb332c20-8b45-11ee-939d-92fbcf53809c.png

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

2.5 Handshake Packets

fb3923aa-8b45-11ee-939d-92fbcf53809c.png

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

3.事務(Transaction)

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

一個token packet

可選的data pcket

可選的handshake packet

可選的special packet

3.1 輸入(IN)事務處理

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

fb457182-8b45-11ee-939d-92fbcf53809c.png

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

fb4c9480-8b45-11ee-939d-92fbcf53809c.png

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

fb53e104-8b45-11ee-939d-92fbcf53809c.png

3.2. 輸出(OUT)事務處理

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

fb57e27c-8b45-11ee-939d-92fbcf53809c.png

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

fb64fc82-8b45-11ee-939d-92fbcf53809c.png

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

fb72d03c-8b45-11ee-939d-92fbcf53809c.png

3.3 設置(SETUP)事務處理

【正常】的設置事務處理

fb84307a-8b45-11ee-939d-92fbcf53809c.png

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

fb921780-8b45-11ee-939d-92fbcf53809c.png

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

fb95d500-8b45-11ee-939d-92fbcf53809c.png

4.USB傳輸類型

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

控制傳輸 (Control Transfer)

中斷傳輸 (Interrupt Transfer)

批量傳輸 (Bulk Transfer)

同步傳輸 (Isochronous)

4.1 控制傳輸 (Control Transfer)

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

建立階段(Setup)

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

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

每個階段都由一次或多次(數(shù)據(jù)階段)事務傳輸組成(Transaction)。 控制數(shù)據(jù)由USB系統(tǒng)軟件用于配置設備(在枚舉時),其它的驅動軟件可以選擇使用control transfer實現(xiàn)具體的功能,數(shù)據(jù)傳輸是不可丟失的。

4.1.1 建立階段

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

fb9b328e-8b45-11ee-939d-92fbcf53809c.png

4.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ù)已經正確接收時,主機送出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ù)已經正確接收時,設備送出ACK令牌信息包;當設備正在忙碌時,設備發(fā)出NAK握手信息包;當發(fā)生了錯誤時,設備發(fā)出STALL握手信息包。

fbadac52-8b45-11ee-939d-92fbcf53809c.png

4.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握手封包。

4.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事務):

token

data

handshake

fbb35f8a-8b45-11ee-939d-92fbcf53809c.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已經正確無誤地接收到數(shù)據(jù)包,且通知Host可以按順序發(fā)送下一個數(shù)據(jù)包

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

STALL: 指示Device endpoint已經停止,且通知Host不再重傳

Bulk讀寫序列

fbc40bb4-8b45-11ee-939d-92fbcf53809c.png

即由一系統(tǒng)IN事務或OUT事務組成。 4.3 中斷傳輸(Interrupt Transfer) 中斷傳輸由 IN 或 OUT 事務組成。 中斷傳輸在流程上除不支持PING 之外,其他的跟批量傳輸是一樣的。他們之間的區(qū)別也僅在于事務傳輸發(fā)生的端點不一樣、支持的最大包長度不一樣、優(yōu)先級不一樣等這樣一些對用戶來說透明的東西。 主機在排定中斷傳輸任務時,會根據(jù)對應中斷端點描述符中指定的查詢間隔發(fā)起中斷傳輸。中斷傳輸有較高的優(yōu)先級,僅次于同步傳輸。 同樣中斷傳輸也采用PID翻轉的機制來保證收發(fā)端數(shù)據(jù)同步。下圖為中斷傳輸?shù)牧鞒虉D。 中斷傳輸方式總是用于對設備的查詢,以確定是否有數(shù)據(jù)需要傳輸。因此中斷傳輸?shù)姆较蚩偸菑腢SB設備到主機。

fbc7cccc-8b45-11ee-939d-92fbcf53809c.png

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

4.4 同步傳輸(Isochronous Transfer)

它由兩種包組成:

token

data

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

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

fbd15274-8b45-11ee-939d-92fbcf53809c.png

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

    關注

    28

    文章

    975

    瀏覽量

    40853
  • usb
    usb
    +關注

    關注

    60

    文章

    8066

    瀏覽量

    269653
  • 數(shù)據(jù)傳輸

    關注

    9

    文章

    1991

    瀏覽量

    65431

原文標題:USB 通信協(xié)議必備基礎知識

文章出處:【微信號:嵌入式情報局,微信公眾號:嵌入式情報局】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    拆解USB通信協(xié)議主要內容

    USB應用非常廣泛,電腦手機必備接口,很多嵌入式設備也具有USB通信能力,這里給大家分享一下USB通信協(xié)
    發(fā)表于 11-11 09:19 ?960次閱讀

    CAN總線通信協(xié)議基礎知識

    本文將介紹CAN總線通信協(xié)議基礎知識,目前的內容僅為通用的協(xié)議部分,暫不涉及具體的外設模塊的用法。研究通信協(xié)議的具體內容,主要是看建立通信
    的頭像 發(fā)表于 06-16 10:58 ?7369次閱讀
    CAN總線<b class='flag-5'>通信協(xié)議</b>的<b class='flag-5'>基礎知識</b>

    通信技術基礎知識

    通信技術基礎知識電信網(telecommunication network)是構成多個用戶相互通信的多個電信系統(tǒng)互連的通信體系,是人類實現(xiàn)遠距離通信
    發(fā)表于 12-12 11:44

    FPGA基礎知識,初學者必備

    FPGA基礎知識,初學者必備
    發(fā)表于 11-27 15:03

    【資料】HarmonyOS開發(fā)必備基礎知識

    HarmonyOS開發(fā)必備基礎知識回復帖子查看資料下載鏈接:[hide][/hide]
    發(fā)表于 08-12 11:47

    SPI通信協(xié)議基礎知識解析

    SPI通信協(xié)議詳解寫在最前: 本文講述了SPI通信協(xié)議的基本內容包括如下SPI的基礎知識SPI的讀寫時序本文重點參考 英文維基百科 中文維基百科 百度百科注意: 倘若讀者有足夠的耐心和英文
    發(fā)表于 12-13 08:05

    通信協(xié)議的相關資料分享

    嵌入式通信協(xié)議:分為“大協(xié)議”和“小協(xié)議”兩種“大協(xié)議”:主要用來進行系統(tǒng)外的整個系統(tǒng)之間的通信協(xié)議
    發(fā)表于 12-24 08:15

    如何實現(xiàn)基礎通信協(xié)議的設計?

    常見的通信協(xié)議格式是什么?如何實現(xiàn)基礎通信協(xié)議的設計?
    發(fā)表于 02-14 07:35

    SPI是什么?SPI通信協(xié)議說明

    文章目錄目錄前言一、SPI是什么?二、SPI通信協(xié)議1.通信引腳說明2.通信格式說明3.實現(xiàn)形式4.三線制SPI總結前言通信是各種設備之間的必備
    發(fā)表于 02-17 06:45

    通信基礎知識教程

    通信基礎知識 1、電信基礎知識2、通信電源技術3、配線設備結構、原理與防護4、防雷基礎知識5、EMC
    發(fā)表于 03-04 16:48 ?33次下載

    Modbus通信協(xié)議教程

    Modbus通信協(xié)議教程Modbus通信協(xié)議教程Modbus通信協(xié)議教程
    發(fā)表于 12-08 14:14 ?75次下載

    usb通信的一些基礎知識

    目前了解了usb通信層面的一些基礎知識如下。如果有空還要再了解hid報告描述符及協(xié)議的數(shù)據(jù)包波形。
    發(fā)表于 05-18 10:18 ?4560次閱讀

    通信協(xié)議的一些相關知識點資料合集免費下載

    本文檔的主要內容詳細介紹的是通信協(xié)議的一些相關知識點資料合集免費下載包括了:SPI,全雙工、半雙工、單工,集線器,交換機,RS-232通信協(xié)議通信協(xié)議,RS-485
    發(fā)表于 06-04 08:00 ?11次下載
    <b class='flag-5'>通信協(xié)議</b>的一些相關<b class='flag-5'>知識</b>點資料合集免費下載

    物聯(lián)網通信協(xié)議基礎知識合集

    本文介紹了幾個可用的物聯(lián)網通信協(xié)議,它們具有不同的性能、數(shù)據(jù)速率、覆蓋范圍、功率和內存,而且每一種協(xié)議都有各自的優(yōu)點和或多或少的缺點。其中一些通信協(xié)議只適合小型家用電器,而其他一些通信協(xié)議
    的頭像 發(fā)表于 03-23 14:32 ?1397次閱讀

    IP地址、端口號、通信協(xié)議的相關知識 TCP和UDP通信協(xié)議簡述

    網絡編程有三個要素,分別是IP地址、端口號和通信協(xié)議。本文主要講述的是TCP與UDP這兩種通信協(xié)議,以及編程的實現(xiàn)。首先,我們需要了解一下IP地址、端口號、通信協(xié)議的相關知識
    的頭像 發(fā)表于 07-18 11:20 ?2466次閱讀
    IP地址、端口號、<b class='flag-5'>通信協(xié)議</b>的相關<b class='flag-5'>知識</b> TCP和UDP<b class='flag-5'>通信協(xié)議</b>簡述
    主站蜘蛛池模板: 国产一级在线观看www色 | 丁香5月婷婷 | 天天干天天草 | 亚洲特黄大黄一级毛片 | 色综合久久久久综合99 | 在线观看h视频 | 久久午夜宅男免费网站 | 亚洲影视久久 | 五月婷婷六月丁香在线 | 35qao强力打造免费上线高清 | 伊人涩| 波多野结衣在线网站 | 久久国产高清字幕中文 | 四虎永久免费影院 | 国产精品午夜寂寞视频 | 欧美日本一区二区三区 | 六月婷婷综合激情 | 黄色三级三级三级免费看 | 性感美女逼 | 91在线视频观看 | 日韩亚洲人成在线综合 | 国产永久视频夜色资源网 | 你懂的在线看 | 亚洲成av人片在线观看无码 | 国产午夜精品一区二区理论影院 | 成人看片免费无限观看视频 | 四虎4hu影库永久地址 | 操综合网| 性色视频在线观看 | 久久国产免费观看 | 日韩精品另类天天更新影院 | 国产性做久久久久久 | 777777777妇女亚洲 | 国产精品黄页网站在线播放免费 | 亚洲午夜精品久久久久久成年 | 免费 视频 1级 | 日本一区免费在线观看 | 欧美色频 | 午夜在线观看免费观看大全 | 操美女大逼逼 | 久久精品香蕉视频 |