]> www.infradead.org Git - users/hch/block.git/commitdiff
multipath stacking limits nvme-limits
authorChristoph Hellwig <hch@lst.de>
Thu, 29 Feb 2024 15:11:34 +0000 (07:11 -0800)
committerChristoph Hellwig <hch@lst.de>
Fri, 1 Mar 2024 12:59:34 +0000 (05:59 -0700)
drivers/nvme/host/core.c

index a6ffa947d2e0624bc1e871510a215afdfd1e625a..77641fffe3044659fc718a60a09b9a30bcc680fb 100644 (file)
@@ -2188,6 +2188,8 @@ static int nvme_update_ns_info(struct nvme_ns *ns, struct nvme_ns_info *info)
        }
 
        if (!ret && nvme_ns_head_multipath(ns->head)) {
+               struct queue_limits lim;
+
                blk_mq_freeze_queue(ns->head->disk->queue);
                if (unsupported)
                        ns->head->disk->flags |= GENHD_FL_HIDDEN;
@@ -2196,10 +2198,11 @@ static int nvme_update_ns_info(struct nvme_ns *ns, struct nvme_ns_info *info)
                set_capacity_and_notify(ns->head->disk, get_capacity(ns->disk));
                set_disk_ro(ns->head->disk, nvme_ns_is_readonly(ns, info));
                nvme_mpath_revalidate_paths(ns);
-               blk_stack_limits(&ns->head->disk->queue->limits,
-                                &ns->queue->limits, 0);
 
-               disk_update_readahead(ns->head->disk);
+               lim = queue_limits_start_update(ns->head->disk->queue);
+               queue_limits_stack_bdev(&lim, ns->disk->part0, 0,
+                                       ns->head->disk->disk_name);
+               ret = queue_limits_commit_update(ns->head->disk->queue, &lim);
                blk_mq_unfreeze_queue(ns->head->disk->queue);
        }