【USB3.0协议学习】Topic3三种Reset Events分析

news/2024/9/19 16:00:37/文章来源:https://www.cnblogs.com/linhaostudy/p/18416034

USB3.0中的三种Reset Events

1. PowerOn Reset

PowerOn Reset被用来代指上电复位,当一个device接入到root hub或者外置hub的时候,该device检测到Vbus信号从无效变为有效,会自动执行复位。(注意,self powered device不通过Vbus供电,但是Vbus发生转变的时候它同样会执行复位)

1.1 软件设置PowerOn Reset

那么是否一定要通过物理的attach和remove来触发PowerOn Reset呢?

当然不是,PowerOn Reset是可以通过软件控制触发的,如下图所示:

该图中右边Device直接连接到roothub,左边Device则是先连接到外置hub,外置hub再连接到roothub上。

先看右边,软件可以通过写xhci寄存器PORTSC的第9bit-PP字段,从而直接关闭掉roothub连接该设备的端口的port power,再打开port power,从而触发PowerOn Reset。这种方式相当于直接控制Vbus,将Vbus拉低再拉高。

再看左边,由于device是通过外置hub连接到roothub的,roothub不能直接关闭掉端口的power,因为这将导致外置hub也复位。此时采取的方式是通过USB协议中规定的default control endpoint(EP0)以及Control Transfer来传输hub-class request从而间接关掉或者开启该外置hub的port power。如下图所示:

通过SetFeature这个标准请求,可以在Index字段中选择Port number,从而关闭或者开启外置hub的port power。注意Control Transfer分为Setup stage\Data stage\Status stage三个阶段,图中的SetFeature请求作为Setup Stage中的Data进行传输。

1.2 PowerOn Reset后的效果

  1. USB interface回到初始状态,memory,register均回到默认值
  2. Link layer的Tx和Rx的header packet buffer, counters, timers均清零
  3. PowerOn Reset完成后,如果检测到正确的R**RXD**C
  4. 阻则可以获取150mA的电流,否则只能获得100mA的电流

特别注意,对于self powered device而言,Vbus被设置为无效后,该device的receiver termination必须对外显示为高阻抗的状态,即ZRX*−HIG**H*−IMP*−*DC*−POS*>25K

2. Warm Reset

Warm Reset是被称之为"inband reset"的一种复位方式,是一种功能复位(inband我个人理解其实就是链路双方均在线上),效果和PowerOn Reset相似。Warm Reset的流程一般是软件命令roothub的某一port执行warm reset,该Downstream port的LTSSM状态机响应并发出warm reset LFPS握手信号,Device的Upstream port检测warm reset LFPS。完成后,链路双方都会执行复位操作并且各自的LTSSM跳转到Rx.Detect状态1 。

2.1 软件设置Warm Reset

软件可以通过写xhci的寄存器PORTSC的PR和WPR字段,将这两个bit同时设置为1从而命令硬件执行Warm Reset,如下图所示:

注意:
1.如果device连接的外置hub,那么host仍然需要通过Control Transfer传输USB的标准requset给外置hub,由外置hub的Downstream port发起warm reset

2.warm reset LFPS只能由Downstream port发起

2.2 Warm Reset后的效果

  1. USB device address回到0,先前的配置信息全部清除
  2. Link layer的Tx和Rx的header packet buffer, counters, timers均清零
  3. Warm Reset完成后,如果检测到正确的R**RXD**C电阻则可以获取150mA的电流,否则只能获得100mA的电流
  4. LTSSM回到Rx.Detect状态,链路将重新训练

3. Hot Reset

Hot Reset也是"inband reset"的一种复位方式,也属于功能复位。LTSSM专门设置了一个Hot Reset的状态来对应完成Hot Reset。
Hot Reset在链路上使用的握手信号不再是LFPS,而是TS2 ordered set,也就是说LTSSM只能在U0或者Polling.Idle的状态下才能响应软件命令的hot reset。

3.1 软件设置Hot Reset

xhci里的PORTSC寄存器PR字段对应Hot Reset,当host仅设置PR而不设置WPR时,链路将执行Hot Reset。

  1. USB device address 回到0
  2. 如果成功了LTSSM回到U0状态,如果失败了回到Rx.Detect,或者SS.Inactive或者SS.Disable
  3. Port configuration values得到了保留,包括Tx和Rx header buffer的数量、链路速度等
  4. Recevier的equalization参数得到了保留
  5. Link layer的Tx和Rx的header packet buffer, counters, timers均清零
  6. USB specified register和memory回到默认值(这一条的specified register具体包括哪些?存疑)

注意:Hot Reset的过程中链路双方要保持RRX*−D**C*满足18-30欧姆的条件

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/797995.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

02策略模式

定义一系列算法,将每一个算法封装起来,并让它们可以相互替换。策略模式让算法可以独立于使用它的客户而变化1. 案例:营业员根据客户所购买商品的单价和数量,根据不同活动向客户收费**- 正常原价收费 - 八折收费 - 满300返100 2. 策略模式结构- 抽象策略类(Stategy):声明算法…

三、浅层神经网络

1、神经网络概览什么是神经网络?如下图:神经网络的结构与逻辑回归类似,只是神经网络的层数比逻辑回归多一层,多出来的中间那层称为隐藏层或中间层。从计算上来看,神经网络的正向传播和反向传播比logistic回归多了一次重复的计算。引入新的标签:方括号上标[i]表示当前所处…

windows安装rabbitmq后出现:Error::plugins_dir_does not_exist

安装的路径正常,没有空格中文字符啥的。 环境变量也配置了。原因是:安装otp_win64_24.1.7时没有选择以管理员身份运行。重新卸载安装即可

Zero-Shot,One-Shot,Few-Shot,In-Context Learning

Zero-Shot,One-Shot,Few-Shot,In-Context Learning https://blog.csdn.net/weixin_44212848/article/details/139902394In-Context Learning定义:In-context learning是一种在不显式微调模型权重的情况下,通过给模型提供相关的上下文信息(例如提示或样本)来实现模型性能…

GoLand 相关设置

GoLand 相关设置 自动导包设置

AutoCAD C# 判断多边形与点的位置关系

书上说,射线法和叉乘法感觉都不完整 下面我分享我写的基于AutoCAD BREP算法var ed = acApp.Application.DocumentManager.MdiActiveDocument.Editor;var peo = new PromptEntityOptions("Select a PolyLine : ");peo.SetRejectMessage("Only PolyLine");…

Nginx使用篇:实现负载均衡、限流与动静分离

Nginx实用篇:实现负载均衡、限流与动静分离| 原创作者/编辑:凯哥Java | 分类:Nginx学习系列教程nginx的logo Nginx 作为一款高性能的 HTTP 服务器及反向代理解决方案,在互联网架构中扮演着至关重要的角色。它不仅支持负载均衡、流量控制等功能…

[ACTF2020 新生赛]Upload

启动靶机,发现有前端验证先绕过前端验证,在burp中尝试发现验证在文件名后缀,且会重命名文件名 发现.ini能上传但是会被重命名,既然不像前端显示只有三种格式能上传,这里我们寻找能绕过的后缀尝试发现phtml能上传成功 //PHTML 扩展名是 PHP 的一个模块,它允许在 HTML 文件…

上海登陆最强台风 台风路径追踪 All In One

上海登陆最强台风 & 台风路径追踪 All In One 上海最强台风路径追踪 中央气象台、市气象服务中心介绍,今年第13号台风“贝碧嘉”(强台风级)的中心已于今天(2024年09月16日)7点30分前后在上海浦东临港新城登陆,登陆时中心附近最大风力14级(42米/秒),中心最低气压为…

再vue中使用Vuetify 创建app项目

vue:2 Vuetify :2与vue创建普通项目相同:https://www.cnblogs.com/yansans/p/18342267vscode打开项目,在项目终端中运行vue add vuetify@2之后会出现,选择默认即可(回车) 几个选项的解释: 1. Vuetify 2 - Configure Vue CLI (advanced)解释:这是一个高级选项,允许你对…

广东产业转移工业园

广东产业转移工业园

南沙C++信奥老师解一本通题 1228:书架

​【题目描述】John最近买了一个书架用来存放奶牛养殖书籍,但书架很快被存满了,只剩最顶层有空余。 John共有NN头奶牛(1≤N≤20,000),每头奶牛有自己的高度Hi(1≤Hi≤10,000),N头奶牛的总高度为S。书架高度为B(1≤B≤S<2,000,000,007)。 为了到达书架顶层,奶牛可以踩着…