Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp1540180pxu; Tue, 24 Nov 2020 02:56:06 -0800 (PST) X-Google-Smtp-Source: ABdhPJzFFNkmqeE4EtgqE8bmFm8C91luJDosacKp85CHXJpqLkmZ9iLDbtvGSXkIeu2q9AJ27ihk X-Received: by 2002:a17:906:5684:: with SMTP id am4mr3526435ejc.289.1606215365942; Tue, 24 Nov 2020 02:56:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606215365; cv=none; d=google.com; s=arc-20160816; b=Ed6sVzGvblqIzxVv9e/aSS/lPKs6S9MrsyO2dgvVOCO6Tw7mon79F+sRmiWRNoy7Sn UP4waFL8zoN2eGhWDFxmmaHDkoHHHoXWyOm4REhotkTKYIlHU16W4WzgRxUaJQ7HN8aK vA/g59bXttSQdrPG93jzFyPQGGE+iBpMjGgHqSjZhlV2/6e1ARLQXvtelNYFRdpzWRSv Oc5Hw6FUL2QcZn04raZowBujvEjGlWRAjr45vj9xFNd4LYcgraBE03WRoDne+PpprloS l4c3mYHmkYERqJlOj2YtJA0+t+CaIv2tkxuEcu7yZiW8AF2/HJbcNy2jyyi6US1cK4Of 4KDw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:dkim-signature:mime-version:references :in-reply-to:message-id:date:subject:cc:to:from; bh=3JBsQO4wFUzjO27TheH1pFiQ6ly/QM6C3KH95EJK6Eg=; b=MCRjCil0Th+cY4XUETsj5eICfvVy6wn6zaoXcOwdynZfnP9nbt4rJ809q3WkHtI+iM gbsD2Wg/nW1KT+X0+IZ5EyXFP1x6oGcnKdKCtRfr34D152dggpUJ3FD1ZFYG/tHfgjqN GaUXjlYgJn5PxZ3uMUfhOjRb92qBQuMny9SKwEpwBezpv1jHEQAQjSx9Ii53ncaLDGwp zFs9VXlhDxaKVRLl5dDFA/lqUVwnk0wWiqv/kcw1yyzcwWXPjiCHKBhzBzgvOK7977D1 yE733Khpf2VgSPIR18YGj4BzwSTlVOV89TyP9PikUE8/KCrUTHAqHtXmfnXuUq7fMAke HzIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=C56xgmlY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u11si8514592edj.59.2020.11.24.02.55.42; Tue, 24 Nov 2020 02:56:05 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=C56xgmlY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730434AbgKXKuo (ORCPT + 99 others); Tue, 24 Nov 2020 05:50:44 -0500 Received: from hqnvemgate26.nvidia.com ([216.228.121.65]:7772 "EHLO hqnvemgate26.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727781AbgKXKuo (ORCPT ); Tue, 24 Nov 2020 05:50:44 -0500 Received: from hqmail.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate26.nvidia.com (using TLS: TLSv1.2, AES256-SHA) id ; Tue, 24 Nov 2020 02:50:46 -0800 Received: from HQMAIL101.nvidia.com (172.20.187.10) by HQMAIL107.nvidia.com (172.20.187.13) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Tue, 24 Nov 2020 10:50:41 +0000 Received: from vidyas-desktop.nvidia.com (10.124.1.5) by mail.nvidia.com (172.20.187.10) with Microsoft SMTP Server id 15.0.1473.3 via Frontend Transport; Tue, 24 Nov 2020 10:50:38 +0000 From: Vidya Sagar To: , , , CC: , , , , , Subject: [PATCH V2] PCI/MSI: Set device flag indicating only 32-bit MSI support Date: Tue, 24 Nov 2020 16:20:35 +0530 Message-ID: <20201124105035.24573-1-vidyas@nvidia.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20201117145728.4516-1-vidyas@nvidia.com> References: <20201117145728.4516-1-vidyas@nvidia.com> X-NVConfidentiality: public MIME-Version: 1.0 Content-Type: text/plain DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1606215046; bh=3JBsQO4wFUzjO27TheH1pFiQ6ly/QM6C3KH95EJK6Eg=; h=From:To:CC:Subject:Date:Message-ID:X-Mailer:In-Reply-To: References:X-NVConfidentiality:MIME-Version:Content-Type; b=C56xgmlYh26LbnSdnf3nF/F3dfpAv2FsKvR19HHYd1r3UjHOJbtc2QsPTW20RruQ6 JySyFKQCQ/rucKxME9Z9YZ987L0o1FlLZ65M+5vFTDixXIlaBF27FCkA7mjnUA1zSZ l/5JmMk+X8BFdniJrFavfXxoXRz7Al6y7ua9OP6DuA8KXaaUCO2DTfPdx0uBZFAkVb cI3XsT8GWAcxIRU5geI8iMxN2yF91jZ4IN7jZdvDpvqaIfguA0Vap+vaUmxuxDIrgA atjlIjWyJtKH4dSDtwmRf19KvuCy3dCFdq7IvR3JM+P/+kBd3Pt197GkeS3+cgLEbp Uex0+7N+J0m1Q== Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org There are devices (Ex:- Marvell SATA controller) that don't support 64-bit MSIs and the same is advertised through their MSI capability register. Set no_64bit_msi flag explicitly for such devices in the MSI setup code so that the msi_verify_entries() API would catch if the MSI arch code tries to use 64-bit MSI. Signed-off-by: Vidya Sagar --- V2: * Addressed Bjorn's comment and changed the error message drivers/pci/msi.c | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/drivers/pci/msi.c b/drivers/pci/msi.c index d52d118979a6..8de5ba6b4a59 100644 --- a/drivers/pci/msi.c +++ b/drivers/pci/msi.c @@ -581,10 +581,12 @@ msi_setup_entry(struct pci_dev *dev, int nvec, struct irq_affinity *affd) entry->msi_attrib.multi_cap = (control & PCI_MSI_FLAGS_QMASK) >> 1; entry->msi_attrib.multiple = ilog2(__roundup_pow_of_two(nvec)); - if (control & PCI_MSI_FLAGS_64BIT) + if (control & PCI_MSI_FLAGS_64BIT) { entry->mask_pos = dev->msi_cap + PCI_MSI_MASK_64; - else + } else { entry->mask_pos = dev->msi_cap + PCI_MSI_MASK_32; + dev->no_64bit_msi = 1; + } /* Save the initial mask status */ if (entry->msi_attrib.maskbit) @@ -602,8 +604,9 @@ static int msi_verify_entries(struct pci_dev *dev) for_each_pci_msi_entry(entry, dev) { if (!dev->no_64bit_msi || !entry->msg.address_hi) continue; - pci_err(dev, "Device has broken 64-bit MSI but arch" - " tried to assign one above 4G\n"); + pci_err(dev, "Device has either broken 64-bit MSI or " + "only 32-bit MSI support but " + "arch tried to assign one above 4G\n"); return -EIO; } return 0; -- 2.17.1