]> www.infradead.org Git - users/hch/block.git/commitdiff
nvme: allow revalidate to set a namespace read-only
authorChristoph Hellwig <hch@lst.de>
Sat, 5 Dec 2020 09:04:33 +0000 (10:04 +0100)
committerChristoph Hellwig <hch@lst.de>
Sat, 23 Jan 2021 17:38:22 +0000 (18:38 +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 200bdd672c281ffc54d7d5bc19be654ca2302d48..42d50c8243458b4081dd2f4100f9e6e2fdf20dd7 100644 (file)
@@ -2112,9 +2112,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)