mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-02 10:43:57 +08:00
nvme-multipath: drop optimization for static ANA group IDs
Bit 6 in the ANACAP field is used to indicate that the ANA group ID doesn't change while the namespace is attached to the controller. There is an optimisation in the code to only allocate space for the ANA group header, as the namespace list won't change and hence would not need to be refreshed. However, this optimisation was never carried over to the actual workflow, which always assumes that the buffer is large enough to hold the ANA header _and_ the namespace list. So drop this optimisation and always allocate enough space. Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Hannes Reinecke <hare@suse.com> Signed-off-by: Sagi Grimberg <sagi@grimberg.me> Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
5cbab6303b
commit
78a61cd42a
@ -545,8 +545,7 @@ int nvme_mpath_init(struct nvme_ctrl *ctrl, struct nvme_id_ctrl *id)
|
|||||||
timer_setup(&ctrl->anatt_timer, nvme_anatt_timeout, 0);
|
timer_setup(&ctrl->anatt_timer, nvme_anatt_timeout, 0);
|
||||||
ctrl->ana_log_size = sizeof(struct nvme_ana_rsp_hdr) +
|
ctrl->ana_log_size = sizeof(struct nvme_ana_rsp_hdr) +
|
||||||
ctrl->nanagrpid * sizeof(struct nvme_ana_group_desc);
|
ctrl->nanagrpid * sizeof(struct nvme_ana_group_desc);
|
||||||
if (!(ctrl->anacap & (1 << 6)))
|
ctrl->ana_log_size += ctrl->max_namespaces * sizeof(__le32);
|
||||||
ctrl->ana_log_size += ctrl->max_namespaces * sizeof(__le32);
|
|
||||||
|
|
||||||
if (ctrl->ana_log_size > ctrl->max_hw_sectors << SECTOR_SHIFT) {
|
if (ctrl->ana_log_size > ctrl->max_hw_sectors << SECTOR_SHIFT) {
|
||||||
dev_err(ctrl->device,
|
dev_err(ctrl->device,
|
||||||
|
Loading…
Reference in New Issue
Block a user