forked from Minki/linux
nvme: introduce nvme_sync_io_queues
Introduce sync io queues for some scenarios which just only need sync io queues not sync all queues. Signed-off-by: Chao Leng <lengchao@huawei.com> Reviewed-by: Sagi Grimberg <sagi@grimberg.me> Signed-off-by: Christoph Hellwig <hch@lst.de>
This commit is contained in:
parent
38210800bf
commit
04800fbff4
@ -4582,8 +4582,7 @@ void nvme_start_queues(struct nvme_ctrl *ctrl)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(nvme_start_queues);
|
EXPORT_SYMBOL_GPL(nvme_start_queues);
|
||||||
|
|
||||||
|
void nvme_sync_io_queues(struct nvme_ctrl *ctrl)
|
||||||
void nvme_sync_queues(struct nvme_ctrl *ctrl)
|
|
||||||
{
|
{
|
||||||
struct nvme_ns *ns;
|
struct nvme_ns *ns;
|
||||||
|
|
||||||
@ -4591,7 +4590,12 @@ void nvme_sync_queues(struct nvme_ctrl *ctrl)
|
|||||||
list_for_each_entry(ns, &ctrl->namespaces, list)
|
list_for_each_entry(ns, &ctrl->namespaces, list)
|
||||||
blk_sync_queue(ns->queue);
|
blk_sync_queue(ns->queue);
|
||||||
up_read(&ctrl->namespaces_rwsem);
|
up_read(&ctrl->namespaces_rwsem);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(nvme_sync_io_queues);
|
||||||
|
|
||||||
|
void nvme_sync_queues(struct nvme_ctrl *ctrl)
|
||||||
|
{
|
||||||
|
nvme_sync_io_queues(ctrl);
|
||||||
if (ctrl->admin_q)
|
if (ctrl->admin_q)
|
||||||
blk_sync_queue(ctrl->admin_q);
|
blk_sync_queue(ctrl->admin_q);
|
||||||
}
|
}
|
||||||
|
@ -602,6 +602,7 @@ void nvme_stop_queues(struct nvme_ctrl *ctrl);
|
|||||||
void nvme_start_queues(struct nvme_ctrl *ctrl);
|
void nvme_start_queues(struct nvme_ctrl *ctrl);
|
||||||
void nvme_kill_queues(struct nvme_ctrl *ctrl);
|
void nvme_kill_queues(struct nvme_ctrl *ctrl);
|
||||||
void nvme_sync_queues(struct nvme_ctrl *ctrl);
|
void nvme_sync_queues(struct nvme_ctrl *ctrl);
|
||||||
|
void nvme_sync_io_queues(struct nvme_ctrl *ctrl);
|
||||||
void nvme_unfreeze(struct nvme_ctrl *ctrl);
|
void nvme_unfreeze(struct nvme_ctrl *ctrl);
|
||||||
void nvme_wait_freeze(struct nvme_ctrl *ctrl);
|
void nvme_wait_freeze(struct nvme_ctrl *ctrl);
|
||||||
int nvme_wait_freeze_timeout(struct nvme_ctrl *ctrl, long timeout);
|
int nvme_wait_freeze_timeout(struct nvme_ctrl *ctrl, long timeout);
|
||||||
|
Loading…
Reference in New Issue
Block a user