Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp7153846ybi; Mon, 8 Jul 2019 15:44:21 -0700 (PDT) X-Google-Smtp-Source: APXvYqzg+QBQRqnlYamLivQyVEfpHTRDYWwusT81VjlB4GfZnnGOEpCkrTuqyDC+rEI9on9O8Fy1 X-Received: by 2002:a17:902:4501:: with SMTP id m1mr27996918pld.111.1562625861493; Mon, 08 Jul 2019 15:44:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562625861; cv=none; d=google.com; s=arc-20160816; b=a9PVMNH/lmjVlM3ntiq/GRMeuh87u8Kmz6WQDMnMBdVAaPGsUZhI2frpm/cZsrN/sz JLCA5/kOo+KGtQzIMj84iI4vdC+khk6X5xfH17m3EG0KZyOkzKL/nwy1FMI1nDxm/dlT 4Ug7J3v+6JpFZwKl3xSVo78ZY/FN/OwTcjImlGABo7ATgDpnOrZYEVOAa8i5wx3J6WHR B5dnLBUA2gt70GbQSHkCfQVFqgKRpBkHS2Ngxw544s3UZe7TLJRXaxtE+Dn4lfosLXND 7uXa2r4JDzNSrzZx9FnpMsSH7yUNh+0oiNP8VGvGTjD9heKMsmwBL1ZsYPOxbYxKsmHs gUTA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=CqXD+N8dzmqJ4IWQJGnOizgxv0vvjYnPypNtlkBzoqM=; b=vcHXzi95XycA1cdfhpHt2wb+AhLIiuudrzcI0YMF7ApAg81ylt9k53AmF+ziI9PIsh MCR/bVqxX9UyfCuO+q2pqKmOy+fKTuYi1FT4M1a7yHxUlfY5FhM/EkcogWfzllhRzmsM b728hP6T53Sbn7Gt3gYcaYLMZhKkea/uhu3N596HWKVAvfa5AVFSWan2p9cNVRt96Zza afD+k0k2qLRha7l+X5+svXxkGFzcFUvBdinR0KYgy0jSUSUAFkxYBpVeFLfU6ZtMat4v plwJ0xhoYC5h4XTGlzaxIvcn+X5D8PYx8Tyn65zBUN85wfEAN4Cri8gsiYog68YV4atL 6vfw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@sifive.com header.s=google header.b=Gf61OpwO; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h18si723466pjt.9.2019.07.08.15.44.07; Mon, 08 Jul 2019 15:44:21 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@sifive.com header.s=google header.b=Gf61OpwO; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732168AbfGHRY1 (ORCPT + 99 others); Mon, 8 Jul 2019 13:24:27 -0400 Received: from mail-pl1-f193.google.com ([209.85.214.193]:42445 "EHLO mail-pl1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728744AbfGHRY0 (ORCPT ); Mon, 8 Jul 2019 13:24:26 -0400 Received: by mail-pl1-f193.google.com with SMTP id ay6so8610581plb.9 for ; Mon, 08 Jul 2019 10:24:26 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sifive.com; s=google; h=from:to:cc:subject:date:message-id; bh=CqXD+N8dzmqJ4IWQJGnOizgxv0vvjYnPypNtlkBzoqM=; b=Gf61OpwO48cpWHTX4LkTJEBGeQIQgSi9UcozAjDh4tDWAj+i66n7KDrBKf/qvlQQYN ASYH3dl2t8+u/9tCEE+Ncxeu2RfPAxTL5EwZHqB0Bf4pZx++FhY9xCISoGnsC0BH5WDf ZBUgrVo8nqOk9ONdNgZ0Sb+aysrK2g9jr57AabDv/DgXF6dUkMxkQMrpx9y5l9LKj+ua UiLY8C6He34Ew6QlfFnGxu+bNvYaFpO78HznTdHvuiInQX1ECBDYM5VqvHlONReWOGaE VF7VPAqfCQ8oiy/f0kCwawTVE5hGh+fKhpsa5tFhBspqcaYVKTNUNxbVp1nfOS0vBVNE UPpw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=CqXD+N8dzmqJ4IWQJGnOizgxv0vvjYnPypNtlkBzoqM=; b=qVxFHav3p5wUlyaVrt+h7cHzCSJ1X6I7Nx0D9fk6UsKJ9DSp2y2Ja80p9XyXjYO6pD LdjaIGlUM6wVcKSsmTsqkF4NdiDof+j5GdB6v39ilawbTg60N2ljD4H/ex/kirnL5KMb Hc/xPm/gvdgdaTZkE6NHWK7/JavalefCyJpH3qYBgmEr0Sj7uanoQ+aeu3nWgPidNtcV TM3e4DIAH6cIGYAG14HXqGptF9kIj+3B/L+LiU1lLkFWY6AZ0zhkTdQ+Lqa2fWXwfpMo JJNuXNPa+rKHE7Smbub4xlAtiab7uoPeqYgbLU8K4ubZ99U5Sw9pJU9Zyl+Rs4fHHloC lqyg== X-Gm-Message-State: APjAAAWg4jKicpujP2RKntqBDLZX7mWpdMCsWb696s3eUFmvft4Zezeh Z36Xo9aR01EhJLH0LXX0BhbkIA== X-Received: by 2002:a17:902:7612:: with SMTP id k18mr18691349pll.48.1562606666267; Mon, 08 Jul 2019 10:24:26 -0700 (PDT) Received: from nuc7.sifive.com ([12.206.222.5]) by smtp.gmail.com with ESMTPSA id h21sm15951262pgg.75.2019.07.08.10.24.25 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Mon, 08 Jul 2019 10:24:25 -0700 (PDT) From: Alan Mikhak X-Google-Original-From: Alan Mikhak < alan.mikhak@sifive.com > To: linux-nvme@lists.infradead.org, linux-kernel@vger.kernel.org, kbusch@kernel.org, axboe@fb.com, hch@lst.de, sagi@grimberg.me, palmer@sifive.com, paul.walmsley@sifive.com Cc: Alan Mikhak Subject: [PATCH] nvme-pci: No IRQ map for read if no read queue allocated Date: Mon, 8 Jul 2019 10:24:12 -0700 Message-Id: <1562606652-7618-1-git-send-email-alan.mikhak@sifive.com> X-Mailer: git-send-email 2.7.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Alan Mikhak nvme_dev_add() assumes a read queue is always allocated. That may not be the case on single-interrupt systems for which pci_assign_irq() would report runtime IRQ mapping not provided by arch. This patch makes sure nvme_dev_add() only requests an IRQ mapping for read queues if at least one read queue is being allocted. nvme_pci_map_queues() will later on ignore the unnecessary mapping request should nvme_dev_add() request such an IRQ mapping even though no read queues are being allocated. However, nvme_dev_add() can avoid making the request by checking the number of read queues without assuming. This would bring it more in line with nvme_setup_irqs() and nvme_calc_irq_sets(). Signed-off-by: Alan Mikhak --- drivers/nvme/host/pci.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/nvme/host/pci.c b/drivers/nvme/host/pci.c index 524d6bd6d095..86262ebe6fff 100644 --- a/drivers/nvme/host/pci.c +++ b/drivers/nvme/host/pci.c @@ -2263,7 +2263,9 @@ static int nvme_dev_add(struct nvme_dev *dev) if (!dev->ctrl.tagset) { dev->tagset.ops = &nvme_mq_ops; dev->tagset.nr_hw_queues = dev->online_queues - 1; - dev->tagset.nr_maps = 2; /* default + read */ + dev->tagset.nr_maps = 1; /* default */ + if (dev->io_queues[HCTX_TYPE_READ]) + dev->tagset.nr_maps++; if (dev->io_queues[HCTX_TYPE_POLL]) dev->tagset.nr_maps++; dev->tagset.timeout = NVME_IO_TIMEOUT; -- 2.7.4