]> git.baikalelectronics.ru Git - kernel.git/commit
nvme: Fix IOC_PR_CLEAR and IOC_PR_RELEASE ioctls for nvme devices
authorMichael Kelley <mikelley@microsoft.com>
Fri, 23 Sep 2022 04:49:09 +0000 (21:49 -0700)
committerChristoph Hellwig <hch@lst.de>
Tue, 27 Sep 2022 07:20:29 +0000 (09:20 +0200)
commit5c037b8ecd7341c1c3561786c0cd3004b0c3f419
tree299f0901115dc602e4e6043bc9d4cd0ad85d33bf
parent86b48c01ec99a4a3535ccde6630c1fdeb3b66f23
nvme: Fix IOC_PR_CLEAR and IOC_PR_RELEASE ioctls for nvme devices

The IOC_PR_CLEAR and IOC_PR_RELEASE ioctls are
non-functional on NVMe devices because the nvme_pr_clear()
and nvme_pr_release() functions set the IEKEY field incorrectly.
The IEKEY field should be set only when the key is zero (i.e,
not specified).  The current code does it backwards.

Furthermore, the NVMe spec describes the persistent
reservation "clear" function as an option on the reservation
release command. The current implementation of nvme_pr_clear()
erroneously uses the reservation register command.

Fix these errors. Note that NVMe version 1.3 and later specify
that setting the IEKEY field will return an error of Invalid
Field in Command.  The fix will set IEKEY when the key is zero,
which is appropriate as these ioctls consider a zero key to
be "unspecified", and the intention of the spec change is
to require a valid key.

Tested on a version 1.4 PCI NVMe device in an Azure VM.

Fixes: 6a147b690aff ("nvme: move block_device_operations and ns/ctrl freeing to common code")
Fixes: 60d4da9ad7bb ("NVMe: Add persistent reservation ops")
Signed-off-by: Michael Kelley <mikelley@microsoft.com>
Signed-off-by: Christoph Hellwig <hch@lst.de>
drivers/nvme/host/core.c