UFS深入浅出 第三章 UFS状态图解 第二节 UFS数据突发状态转移图解
yuyutoo 2024-11-03 17:32 2 浏览 0 评论
Section 2 UFS Data Burst State Diagram
第二节UFS数据突发状态转移图解
In the first section of this chapter, we focus on the power state transition diagram from UFS UTP layer point of view. Now we go deeper to UniPro and M-PHY for data burst and PMC (power mode change) diagram. In this diagram, we have M-PHY Line Status, symbols and UniPro packets. No need to know the detail of these now, knowing their names is enough for this chapter. We will illustrate them in the following chapters.
在这一章的第一节,我们聚焦在从UFS UTP层的角度来看的电源状态转移图。现在我们深入一点到UniPro和M-PHY来看一下data burst数据突发和PMC(电源模式转化)图解。在这个图解里面我们有M-PHY的线路状态,字符以及UniPro包。现在没必要知道这些细节,这一章里只需要知道它们的名字就够了。我们将会在随后的章节里面解释它们。
We start from LSS (Link Start Sequence), to simplify the diagram, we only list M-PHY line state Activate and Line-Reset here, Activate is defined as Diff_n (Negative Differential signals) before Line -Reset, which is a Diff_p (Positive differential signal) pulse with specific minimum pulse width requirement. Line-Reset is not only used in the LSS sequence, but also could be used in error recovery process.
我们从LSS(链接开始序列)开始,为了简化这个图解,我们这里只列出了M-PHY的线路状态Activate激活和Line-Reset线路复位,Activate这里定义的是一个在线路复位之前的负差分信号,而Line-Reset是一个有特定最低脉宽要求的正差分信号脉冲信号。Line-Reset不仅用在LSS里,也可以用在错误恢复的流程里。
TRG_UPR (UniPro Trigger) packet for LSS are not stated here and will be explained in the UniPro Chapter. LSS is for Handshaking process between UFS Host and UFS Device, which could only be initialized from UFS Host. Before UFS4.0 specification, LSS could only be done in Low Speed PWM mode, this is for easy interconnecting between UFS Host and UFS Device when power up. However, in order to save LSS time, in latest UFS4.0 specification define the high Speed LSS as well.
LSS的TRG_UPR(UniPro触发)包在这里不表述,会在Unipro里面细讲。LSS是UFS主机和UFS器件之间的握手流程,只能由UFS主机发起。在UFS4.0协议之前,LSS只能在低速模式PWM里,因为这样比较容易在上电的时候UFS主机和UFS器件之间的互联。然而,为了节省LSS的时间,在最新的UFS4.0协议里面也定义了高速的LSS。
Next, we have options to Change Power Mode by PMC (Power Mode Change) packet, either to Low-Speed specific Gear or High-Speed specific Gear. Please note we could still stay in the original Gear for Data Burst transmission, either in High-Speed or in Low-Speed. In order to start Data Burst, we need first go Diff_n. This negative Differential signal is called sleep for Low-Speed or Stall for High-Speed. Then it is followed by a Diff_p pulse called Prepare.
接下来,我们可以通过PMC(电源模式改变)包来选择性的改变电源模式到低速特定档位或者高速特定档位。请注意我们仍然可以待在原来的低速或者高速档位进行数据突发传输。为了开始数据数据突发传输,我们首先要来一个Diff_n。这个负差分信号在高速叫做STALL,在低速叫做SLEEP。之后再跟一个叫做Prepare的Diff-p的脉冲信号。
In order to secure high-speed data sampling synchronization at peer receiver, termination is used on the transmission line for the High-Speed signal. Meanwhile and a series of special symbols stream called SYNC will be transmitted right before data burst. Low-Speed Data Burst transmission do not need these two.
为了保证对面接受端的正高速信号采样同步,高速信号需要Termination。同时就在数据突发之前,还需要传输叫做SYNC的一系列特殊的字符流。低速数据突发传输不需要这两个。
Then we finally start Data Burst transmission。MK0 (Marker0) is a M-PHY symbol used to indicate the HOB (Head of Burst), now we can transmit different kinds of controlled symbols MKn, FLR (filler symbol) or the packet composed by data symbols and controlled symbols. TOB (Tail of Burst) is used to indicate the end of Burst.
最后我们终于开了数据突发传输。MK0(标记0)是一个用来指示HOB(突发头)的M-PHY控制字符,现在我们可以开始传输各种不同控制字符MKn,FLR(填充字符)或者由数据字符以及控制字符组成的包。TOB(突发尾)用来标识突发结束。
Another PMC packet requested by UFS Host after Data Bust will let UFS device goes into Hibernate. Hibernate is short as HIBERN8, as EIGHT share the same pronunciation as the last syllable with Hibernate. Hibernate is short as H8 sometimes. Hibernate is an important power state for Differential Signals Zero from M-PHY point of view, which could be connected with UFS UTP Layer UFS Sleep and UFS DeepSleep Power State which are explained in the Section 1 of this Chapter.
在数据突发之后,另外一个PMC包用来让UFS器件进入休眠模式。休眠被简写成HIBERN8,因为Eight的发音和Hibernate的最后一个音节发音相同。有时候Hibernate也被简写成H8。从M-PHY的角度来看,Hibernate是一个差分0电平的重要电源状态,这个可以和这一章上一节解释过的UFS睡眠和UFS深度睡眠联系起来。
From HS-G4 (High-Speed Gear 4), a new feature Adapt is introduced for extreme High-Speed data transmission. Adapt is optional, not mandatory. Which means if the system design is with high confidence level of Signal Integrity, there is no need to use Adapt. Adapt could be treated as a special Data Burst with specific Data Pattern to train the peer receiver sampling. There are two types of Adapt, one is longer one once initialization LSS and power mode change to HS-G4 done while right before HS-G4 Data Burst. The other is short one after Hibernate to minimize the temperature or other negative impact to the signal transmission with a period Hibernation time. Again, both these two types of Adapt are optional, decided by UFS Host design.
从HS-G4(高速档位4)开始,为了极高速度的数据传输,一个新的特性Adapt被引入。Adapt是可选的,并不强制。这个也意味着如果对于信号完整性自信比较高的系统设计,没必要使用Adapt。Adapt可以认为是一个特殊的包含特定数据样式的数据突发,用来训练对方接收器的采样。用两种类型的Adapt,一个长一点,是在初始化 LSS和数据模式切换到HS-G4完成,而正在HS-G4数据突发之前。另外一个是在Hibernate之后短的,为了尽量减小一段时间的休眠时间内温度或者其他负面影响。
相关推荐
- jQuery VS AngularJS 你更钟爱哪个?
-
在这一次的Web开发教程中,我会尽力解答有关于jQuery和AngularJS的两个非常常见的问题,即jQuery和AngularJS之间的区别是什么?也就是说jQueryVSAngularJS?...
- Jquery实时校验,指定长度的「负小数」,小数位未满末尾补0
-
在可以输入【负小数】的输入框获取到焦点时,移除千位分隔符,在输入数据时,实时校验输入内容是否正确,失去焦点后,添加千位分隔符格式化数字。同时小数位未满时末尾补0。HTML代码...
- 如何在pbootCMS前台调用自定义表单?pbootCMS自定义调用代码示例
-
要在pbootCMS前台调用自定义表单,您需要在后台创建表单并为其添加字段,然后在前台模板文件中添加相关代码,如提交按钮和表单验证代码。您还可以自定义表单数据的存储位置、添加文件上传字段、日期选择器、...
- 编程技巧:Jquery实时验证,指定长度的「负小数」
-
为了保障【负小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【负小数】的方法。HTML代码<inputtype="text"class="forc...
- 一篇文章带你用jquery mobile设计颜色拾取器
-
【一、项目背景】现实生活中,我们经常会遇到配色的问题,这个时候去百度一下RGB表。而RGB表只提供相对于的颜色的RGB值而没有可以验证的模块。我们可以通过jquerymobile去设计颜色的拾取器...
- 编程技巧:Jquery实时验证,指定长度的「正小数」
-
为了保障【正小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【正小数】的方法。HTML做成方法<inputtype="text"class="fo...
- jquery.validate检查数组全部验证
-
问题:html中有多个name[],每个参数都要进行验证是否为空,这个时候直接用required:true话,不能全部验证,只要这个数组中有一个有值就可以通过的。解决方法使用addmethod...
- Vue进阶(幺叁肆):npm查看包版本信息
-
第一种方式npmviewjqueryversions这种方式可以查看npm服务器上所有的...
- layui中使用lay-verify进行条件校验
-
一、layui的校验很简单,主要有以下步骤:1.在form表单内加上class="layui-form"2.在提交按钮上加上lay-submit3.在想要校验的标签,加上lay-...
- jQuery是什么?如何使用? jquery是什么功能组件
-
jQuery于2006年1月由JohnResig在BarCampNYC首次发布。它目前由TimmyWilson领导,并由一组开发人员维护。jQuery是一个JavaScript库,它简化了客户...
- django框架的表单form的理解和用法-9
-
表单呈现...
- jquery对上传文件的检测判断 jquery实现文件上传
-
总体思路:在前端使用jquery对上传文件做部分初步的判断,验证通过的文件利用ajaxFileUpload上传到服务器端,并将文件的存储路径保存到数据库。<asp:FileUploadI...
- Nodejs之MEAN栈开发(四)-- form验证及图片上传
-
这一节增加推荐图书的提交和删除功能,来学习node的form提交以及node的图片上传功能。开始之前需要源码同学可以先在git上fork:https://github.com/stoneniqiu/R...
- 大数据开发基础之JAVA jquery 大数据java实战
-
上一篇我们讲解了JAVAscript的基础知识、特点及基本语法以及组成及基本用途,本期就给大家带来了JAVAweb的第二个知识点jquery,大数据开发基础之JAVAjquery,这是本篇文章的主要...
- 推荐四个开源的jQuery可视化表单设计器
-
jquery开源在线表单拖拉设计器formBuilder(推荐)jQueryformBuilder是一个开源的WEB在线html表单设计器,开发人员可以通过拖拉实现一个可视化的表单。支持表单常用控件...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)