From: Keith Busch Date: Thu, 9 May 2013 20:01:38 +0000 (-0600) Subject: NVMe: Use user defined admin ioctl timeout X-Git-Tag: firefly_0821_release~3680^2~503^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=94f370cab6e5ac514b658c6b2b3aa308cefc5c7a;p=firefly-linux-kernel-4.4.55.git NVMe: Use user defined admin ioctl timeout Signed-off-by: Keith Busch Signed-off-by: Matthew Wilcox --- diff --git a/drivers/block/nvme-core.c b/drivers/block/nvme-core.c index 310d573b9e8d..8efdfaa44a59 100644 --- a/drivers/block/nvme-core.c +++ b/drivers/block/nvme-core.c @@ -1392,6 +1392,7 @@ static int nvme_user_admin_cmd(struct nvme_dev *dev, struct nvme_command c; int status, length; struct nvme_iod *uninitialized_var(iod); + unsigned timeout; if (!capable(CAP_SYS_ADMIN)) return -EACCES; @@ -1421,10 +1422,13 @@ static int nvme_user_admin_cmd(struct nvme_dev *dev, GFP_KERNEL); } + timeout = cmd.timeout_ms ? msecs_to_jiffies(cmd.timeout_ms) : + ADMIN_TIMEOUT; if (length != cmd.data_len) status = -ENOMEM; else - status = nvme_submit_admin_cmd(dev, &c, &cmd.result); + status = nvme_submit_sync_cmd(dev->queues[0], &c, &cmd.result, + timeout); if (cmd.data_len) { nvme_unmap_user_pages(dev, cmd.opcode & 1, iod);