色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

我們看看UFS中命令或請求是怎么執(zhí)行的

SSDFans ? 來源:未知 ? 作者:李倩 ? 2018-06-08 15:29 ? 次閱讀

UFS中流淌的數(shù)據(jù)包叫做UPIU(UFS Protocol Information Unit,UFS協(xié)議信息單元),它是固定格式的數(shù)據(jù)結(jié)構(gòu),用以傳輸應用層發(fā)來的命令或者請求,以及跟它們相關的數(shù)據(jù)或者狀態(tài)信息。它就是SATA中的FIS,PCIe中的TLP。我們看看UFS中命令或請求是怎么執(zhí)行的。

UFS采用“客戶-服務器”或者說主從的命令架構(gòu),UFS主機(Client,命令發(fā)起者,Initiator,他們都是一個意思)發(fā)送命令或者請求(Request)給UFS設備(服務器,Target),然后UFS設備執(zhí)行命令并返回命令狀態(tài)(Response)。

一個命令或者請求的執(zhí)行包含下面幾個階段:

命令階段:主機發(fā)起命令或請求給設備,這是“因”;

數(shù)據(jù)階段:傳輸跟命令相關的數(shù)據(jù),比如讀寫命令,都涉及到數(shù)據(jù)的傳輸;有些命令不涉及數(shù)據(jù)的傳輸,所以這個階段并不是總是存在的,跟具體命令和請求相關。

狀態(tài)階段:設備執(zhí)行完命令,必須給主機返回命令執(zhí)行狀態(tài)信息。這個是“果”,必不可少的。在PCIe中,有Posted和Non-posted的TLP。對前者,命令執(zhí)行者無需返回命令執(zhí)行狀態(tài)給命令發(fā)起者,對后者,命令執(zhí)行者必須返回狀態(tài)給命令發(fā)起者。對UFS來說,它的命令總是non-posted,即設備必須返回命令狀態(tài)給主機。

在命令執(zhí)行過程中,無論是處在哪個階段,UFS主機和設備間都是通過UPIU進行信息的交互。

1. UFS主機通過命令或者請求UPIU發(fā)命令請求給設備;

2. UFS主機或者設備通過UPIU傳輸數(shù)據(jù);

3. UFS設備通過UPIU返回命令狀態(tài)信息給主機。

下面我們看看UFS當中都有哪些UPIU。

命令或者請求UPIU

前一章看到,應用層包括UFS命令、設備管理器和任務管理器三個模塊,傳輸層根據(jù)不同模塊發(fā)來的命令或者請求,分別產(chǎn)生不同類型的UPIU。

UFS命令模塊發(fā)送簡化版本的SCSI命令,當傳輸層收到命令請求后,它會生成:COMMAND UPIU,把命令封裝起來。

應用層通過任務管理器來管理任務隊列,比如終止(Abort)和查詢命令隊列中的命令。當傳輸層收到來自任務管理器中的請求后,它會生成:TASK MANAGEMENT REQUEST UPIU,把請求封裝起來。

UFS通過設備管理器來管理UFS設備,比如設置和查詢UFS設備的配置(Configuration)。當傳輸層收到來自設備管理器發(fā)來的請求后,它會生成:QUERY REQUEST UPIU,把請求封裝起來。

數(shù)據(jù)傳輸相關UPIU

當主機發(fā)送了類似讀命令給設備之后,設備需要返回數(shù)據(jù)給主機,設備通過DATA IN UPIU向主機傳輸數(shù)據(jù)。

當主機發(fā)送了類似寫命令給設備之后,主機需要往設備寫數(shù)據(jù),主機通過DATA OUT UPIU向設備傳輸數(shù)據(jù)。

UFS的主機是個暖男,它在向設備寫數(shù)據(jù)的時候,會考慮到設備這個時候能不能接收數(shù)據(jù)(因為設備可能這個時候沒有足夠的空間接收主機數(shù)據(jù)),它在向設備發(fā)了寫命令之后,不會立刻把數(shù)據(jù)傳輸給設備,而是在那里等設備的通知。當設備準備好接收數(shù)據(jù),以及接收多少數(shù)據(jù),設備通過READY TO TRANSFER UPIU (RTT)告知主機。當主機接收到該RTT后,才開始按照RTT的信息傳輸數(shù)據(jù)。至于每次傳輸數(shù)據(jù)的多少,RTT中包含這信息,主機根據(jù)RTT進行傳輸。

所以,主機只有在收到設備的RTT,才能發(fā)DATA OUT UPIU!

注意,讀命令無需這種機制。因為設備從閃存中獲得數(shù)據(jù)后,是設備控制數(shù)據(jù)的傳輸。對主機來說,它在發(fā)讀命令之前,已經(jīng)準備好足夠的空間用以接收數(shù)據(jù),所以不存在主機沒有空間接收數(shù)據(jù)的情況。

狀態(tài)UPIU

前面看到,主機有三種請求:SCSI命令,任務管理器發(fā)出的Task Management Request,以及設備管理器發(fā)出的Query request。針對不同的命令或者請求,設備在執(zhí)行完相應的任務后,分別返回對應的狀態(tài)UPIU給主機。

其它UPIU

除了以上常規(guī)的UPIU,還有其它一些UPIU作為他用。

設備上電后,主機檢測是否與之連接,會發(fā)NOP OUT UPIU給設備。我們平時想看看跟某個電腦或者網(wǎng)站能否連接上,會發(fā)一個ping命令。NOP OUT UPIU跟ping命令作用類似。

當設備收到NOP OUT UPIU后,會返回NOP IN UPIU。主機收到該UPIU后,確認與設備連接,然后可以進行后續(xù)操作。

最后一個UPIU就是REJECT UPIU。當設備收到一個無效的UPIU時,它會發(fā)REJECT UPIU拒絕無效的UPIU。

UPIU匯總

偷個懶,我就直接把UFS spec這張表貼這里。數(shù)了數(shù),一共12個UPIU。經(jīng)過我之前的解釋,讀者現(xiàn)在應該清楚每個UPIU的作用了。

讀寫命令中UPIU交互例子

前面我們都是單個來看UPIU,現(xiàn)在我們以讀寫命令為例,看看他們是如何組合完成命令處理的。

首先是一個“主機往設備讀取96KB數(shù)據(jù)”的例子。

首先,主機發(fā)送讀96KB數(shù)據(jù)的命令給設備,然后設備執(zhí)行命令,分了三批把數(shù)據(jù)返回給主機,最后返回命令執(zhí)行狀態(tài)給主機。

然后是一個“主機往設備寫64KB數(shù)據(jù)”的例子。

主機發(fā)送寫64KB數(shù)據(jù)的命令給設備,然后在那里等設備響應。很快,設備說,你可以傳24KB數(shù)據(jù)下來了,于是主機寫24KB數(shù)據(jù)給設備;接著,設備又來通知說可以繼續(xù)傳32KB數(shù)據(jù),主機照做。最后,設備通知說可以把最后8KB數(shù)據(jù)也傳過來,主機于是寫最后8KB數(shù)據(jù)。最后,主機收到設備命令執(zhí)行完成的響應。

我們看到,主機必須等收到RTT后才能啟動數(shù)據(jù)傳輸!

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

    關注

    0

    文章

    246

    瀏覽量

    18540
  • 數(shù)據(jù)包

    關注

    0

    文章

    262

    瀏覽量

    24407
  • UFS
    UFS
    +關注

    關注

    6

    文章

    104

    瀏覽量

    24072

原文標題:蛋蛋讀UFS之三:UFS數(shù)據(jù)包UPIU

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

收藏 人收藏

    評論

    相關推薦

    Linuxxargs命令的使用方法

    xargs命令從標準輸入另一個命令的輸出讀取文本行,并將其轉(zhuǎn)換為命令執(zhí)行
    發(fā)表于 11-25 15:14 ?7090次閱讀
    Linux<b class='flag-5'>中</b>xargs<b class='flag-5'>命令</b>的使用方法

    請問Z-Stack Home中發(fā)送端的命令請求是如何對應接收端的回調(diào)函數(shù)的?

    本帖最后由 一只耳朵怪 于 2018-5-24 14:26 編輯 我在學習Z-Stack Home1.2.1協(xié)議棧時,有如下兩個問題,望各位指教,謝謝!1. 不太明白發(fā)送端的命令請求是
    發(fā)表于 05-22 07:59

    UFS Card是什么?

    SD UHS-II Card在高階手機的應用, CPU 大都已支援 UFS Interface, 可以直接接 eUFS 顆粒. 另外 UFS Card的介面可以透過 USB 的介面實現(xiàn), 隨然受限於
    發(fā)表于 09-17 09:05

    掃描請求是否在中央(TX)外圍(RX)模塊上產(chǎn)生任何事件?

    掃描請求是否在中央(TX)外圍(RX)模塊上產(chǎn)生任何事件?有人能告訴我更多關于掃描請求格式的信息嗎?除了“它存在”以外,我一直在尋找更多的信息。
    發(fā)表于 09-23 09:19

    UFS電源管理的相關資料推薦

    轉(zhuǎn)載:蛋蛋讀UFS之十:UFS電源管理 FS是手機存儲設備,因此對功耗要求很高。我們看看UFS的電源管理。三個供電電壓,VCC,VCCQ和
    發(fā)表于 11-12 06:16

    手機研發(fā)必須了解的UFS相關知識

    。  再形象一點,我們以搬運貨物的例子來比較一下eMMC和UFS命令執(zhí)行方式:  現(xiàn)在的手機,應用非常豐富,你要一邊斗地主,一邊聽歌,還要聊微信,多線程操作。由于全雙工和
    發(fā)表于 03-29 11:08

    USB主機如何識別USB設備及請求命令

    標準的USB設備請求命令是用在控制傳輸的“初始設置步驟”里的數(shù)據(jù)包階段(即DATA0,由八個字節(jié)構(gòu)成),請看回問答四的內(nèi)容。標準USB設備請求命令
    發(fā)表于 07-16 10:36 ?7756次閱讀

    什么是UFS?為什么說UFS是手機存儲的未來?

    UFS支持命令隊列,就是主機一下可以發(fā)很多個命令下去,然后UFS設備支持并行和亂序執(zhí)行,誰先完成誰先返回狀態(tài)。這種
    的頭像 發(fā)表于 06-04 15:38 ?6.4w次閱讀

    看看UFS的電源管理

    除此之外,M-PHY還有一種更加省電的狀態(tài),那就是HIBERN8 (Hibernate,休眠狀態(tài)),這種狀態(tài)下,M-PHY極為省電。UFS主機和UFS設備不可能一直交互數(shù)據(jù),總有閑下來的時候。當
    的頭像 發(fā)表于 07-05 16:53 ?9372次閱讀
    來<b class='flag-5'>看看</b><b class='flag-5'>UFS</b>的電源管理

    UFS系列十:UFS電源管理

    轉(zhuǎn)載:蛋蛋讀UFS之十:UFS電源管理 FS是手機存儲設備,因此對功耗要求很高。我們看看UFS的電源管理。三個供電電壓,VCC,VCCQ和
    發(fā)表于 11-07 09:06 ?22次下載
    <b class='flag-5'>UFS</b>系列十:<b class='flag-5'>UFS</b>電源管理

    LabVIEW執(zhí)行系統(tǒng)命令VI介紹

    LabVIEW自帶一個執(zhí)行系統(tǒng)命令VI(System Exec.vi),位于函數(shù)選板的“互連接口”>>“庫與可執(zhí)行程序”>>“執(zhí)行系統(tǒng)命令
    的頭像 發(fā)表于 04-25 11:47 ?9444次閱讀
    LabVIEW<b class='flag-5'>中</b><b class='flag-5'>執(zhí)行</b>系統(tǒng)<b class='flag-5'>命令</b>VI介紹

    為什么shell腳本執(zhí)行命令要加exec?這個exec有什么作用呢?

    正常情況下,如果我們想要在shell腳本執(zhí)行一個命令我們只用將該命令原樣寫到這個shell腳
    的頭像 發(fā)表于 08-21 09:10 ?3190次閱讀
    為什么shell腳本<b class='flag-5'>中</b><b class='flag-5'>執(zhí)行命令</b>要加exec?這個exec有什么作用呢?

    linuxsource命令的用法

    配置文件執(zhí)行腳本。 source命令的語法為: source filename . filename 其中,filename是腳本文件的路徑。 當source
    的頭像 發(fā)表于 11-08 14:35 ?2352次閱讀

    uboot命令執(zhí)行過程是什么

    U-boot是通過執(zhí)行u-boot提供的命令來加載Linux內(nèi)核的,其中 命令bootm的功能 即為從memory啟動Linux內(nèi)核映像文件。 在講解bootm加載內(nèi)核之前,先來看看u
    的頭像 發(fā)表于 12-04 17:31 ?826次閱讀

    bootm命令執(zhí)行流程

    Bootm命令用來從memory啟動內(nèi)核,bootm命令執(zhí)行流程如下圖所示。 在串口終端輸入bootm命令后,執(zhí)行do_bootm函數(shù)來完
    的頭像 發(fā)表于 12-04 17:33 ?1182次閱讀
    bootm<b class='flag-5'>命令</b>的<b class='flag-5'>執(zhí)行</b>流程
    主站蜘蛛池模板: 门事件快播| seyeye高清视频在线| 久久视频这里只精品99热在线| 24小时日本免费看| 亚洲AV久久无码高潮喷水 | 视频在线观看高清免费看| 久久精品一本到99热| 国产高清在线观看视频| 99re8久久热在线视频| 亚洲一卡二卡三卡四卡2021麻豆| 色欲av蜜臀av高清| 欧美大jiji| 两个人看的www免费高清直播 | 在线看片成人免费视频| 性夜影院爽黄A爽免费动漫| 日本高清二区| 女张腿男人桶羞羞漫画| 恋夜直播午夜秀场最新| 久草在在线免视频在线观看| 国产精品日本无码久久一老A| 北条麻妃のレズナンパ| 97视频国产| 在线观看a视频| 一边吃奶一边啪啪真舒服| 亚洲第一色网| 亚洲 欧洲 国产 日产 综合| 色久久综合视频本道88| 青娱乐国产精品视频| 欧美精品色婷婷五月综合| 米奇影视999| 美女露出撒尿的部位| 久久这里只精品热在线18| 久久re6热在线视频| 火影忍者高清无码黄漫| 国内精品七七久久影院| 国产线精品视频在线观看| 国产精品乱码一区二区三| 国产精品久久精品| 国产精品永久AV无码视频| 国产精品亚洲一区二区三区久久| 国产成人在线观看免费网站|