On Thu, May 10, 2018 at 04:43:57PM -0600, Keith Busch wrote: > On Fri, May 11, 2018 at 06:03:59AM +0800, Ming Lei wrote: > > Sorry, forget to mention, it isn't enough to simply sync timeout inside reset(). > > > > Another tricky thing is about freeze & unfreeze, now freeze is done in > > nvme_dev_disable(), and unfreeze is done in nvme_reset_work. That means > > we have to make sure both are paired, otherwise queues may be kept as > > freeze for ever. > > > > This issue is covered by my V4 & V5 too. > > That it isn't an issue in my patch either. When blk_sync_queue() is used in your patch for draining timeout, several nvme_timeout() instances may be drained, that means there may be more than one nvme_start_freeze() called from all these nvme_timeout() instances, but finally only one nvme_reset_work() is run, then queues are kept as freeze forever even though reset is done successfully. So you patch won't fix this issue. All these problems are mentioned in the commit log of V4, and I am proposing this approach to try to address them all. Thanks, Ming