]> www.infradead.org Git - users/hch/block.git/commitdiff
nvme: allow revalidate to set a namespace read-only block-hard-ro
authorChristoph Hellwig <hch@lst.de>
Sat, 5 Dec 2020 09:04:33 +0000 (10:04 +0100)
committerChristoph Hellwig <hch@lst.de>
Sat, 9 Jan 2021 09:13:11 +0000 (10:13 +0100)
Unconditionally call set_disk_ro now that it only updates the hardware
state.  This allows to properly set up the Linux devices read-only when
the controller turns a previously writable namespace read-only.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Keith Busch <kbusch@kernel.org>
Reviewed-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/nvme/host/core.c

index ce1b6151944131b3af00c0047ba8f69c858d96f6..3a0557ccc9fc5d61b7d1146b4029aed1784969b9 100644 (file)
@@ -2114,9 +2114,8 @@ static void nvme_update_disk_info(struct gendisk *disk,
        nvme_config_discard(disk, ns);
        nvme_config_write_zeroes(disk, ns);
 
-       if ((id->nsattr & NVME_NS_ATTR_RO) ||
-           test_bit(NVME_NS_FORCE_RO, &ns->flags))
-               set_disk_ro(disk, true);
+       set_disk_ro(disk, (id->nsattr & NVME_NS_ATTR_RO) ||
+               test_bit(NVME_NS_FORCE_RO, &ns->flags));
 }
 
 static inline bool nvme_first_scan(struct gendisk *disk)