NVMe Keep Active Timeout

        在协议的Admin Command Set章节中,有一条keep active命令。该条命令的作用是为了保持device端和host端的应答机制。类似于soc的看门狗,即在某段时间的范围内,host需要向device发送keep alive命令,如通过长时间未发送该命令,就会触发keep alive超时。

        根据手册的描述,该特性属于可选特性,需要device和host同时支持。在keep alive的command中,Dword11用于重新配置timeout的值,该值得时间单位为ms,当该值配置为0时,keep alive的timer会关闭,如下图所示:

        对于device和host两端的timeout启动条件不同:

        1、在device端,当控制器完成了Set Features命令所对应的successful completion queue entry后,deviced端的timeout启动。

        2、在host端,当host成功发送了Set Features(送入admin submission queue),或者发送了Keep Alive命令后,host端的timeout启动。

        其中,Set Feature设置的是Feature Identifier为0Fh,即KATO为非0值。

        和该特性相关的还有一个重要特性,协议中称为TBKAS(Traffic Based Keep Alive),该特性的意义是,只要是发送了admin或者I/O commond之后,都会重启Keep Alive。当然,开启了此特性不会对Keep Alive命令有任何影响,只是当有命令往来时可以不用频繁的发送Keep Alive。TBKAS的值也是可以通过Set Feature设置的,当TBKAS为1代表该特性有效,为0代表该特性无效。

        当Keep Alive的timer溢出时,控制器会有两种行为,1)记录一个Error Information log Entry。2)将控制器的Fatal Status(CSTS.CFS)位设置为1,该位为寄存器属性,host可以随时查阅。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值