Received: by 10.223.164.221 with SMTP id h29csp1618610wrb; Wed, 1 Nov 2017 20:57:19 -0700 (PDT) X-Google-Smtp-Source: ABhQp+TMrf4WDzJJejOkMCsIMmZGE+ZDTl12RyNpq3hmAbfksDKOl3zGd6ls8Bh5n7HiWF/fjM0v X-Received: by 10.84.140.235 with SMTP id 98mr1859585plt.428.1509595039233; Wed, 01 Nov 2017 20:57:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1509595039; cv=none; d=google.com; s=arc-20160816; b=hyOK/JvfjXjb5Ce5o4oIkvdHLP2GiD4iHl+PPY6CfKJ7zUaXV+Xs/x9w9B+EU/IRdA lzlv+1zUIh0ep2slrifLaKHUiMTd8/lXM3lRI6c2ZnBvCcM70CV6lVuXzLRLzR3Ce37B 7ruPHyQmf54Y2j1AwXD6rRemWZJrPkCmdP6pQHL1FwWzrS1MaXeAqMRaRoQpTZWgMx3g BDybrPlOuklUoZdOsrVEIa5Vo9aShmaG6sxU1ULdsk9TzZIxZsxXsh1C3pLsuRb3AULm +DrVVwNjbJEgCuTBivIBeE6Gdt303LuCVUPpWMY2PNo7I7V5GNi0hGQrTeJvblLD3r2H WePA== 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 :arc-authentication-results; bh=Ybr8Bsy4VPF1QZ7fCRW/oB6/8k+TS6RF/VVkeCSzjns=; b=x02LUydiU9JJnP57SwT+scTKhXyiDQG+FbmDbO2oxF21MjBikH7KHzsaNv7Kww/BlO T00qhaFh7dRm3VHK3tk0rCYNxGI+kLbljMAPow81fRm9MChDRHhhoE6mo8wCQ2GWwX99 uvC8vmhG0Yh41UKm9nTLX47uznrYRWy3LeaHKKYNECbm8P/V1HCitirG2vYTAwxtWmSi TFJdLQN49/CIbN0G3jPgEdpv3Lr+0e7ksufh9YGSBwp78SOl4s/SAlGJqu9Qs8f7XKrt AHu2rMyTZQV7dQ1Nrd8Z9E78syIEQPEkwyfG5/QXep93WWXZnjImE4SoMaeuYuPLftzo 4mkQ== ARC-Authentication-Results: i=1; mx.google.com; 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 b3si2410653pgn.773.2017.11.01.20.57.04; Wed, 01 Nov 2017 20:57:19 -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; 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 S934345AbdKBD4M (ORCPT + 99 others); Wed, 1 Nov 2017 23:56:12 -0400 Received: from mga14.intel.com ([192.55.52.115]:26843 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S934073AbdKBD4J (ORCPT ); Wed, 1 Nov 2017 23:56:09 -0400 Received: from orsmga004.jf.intel.com ([10.7.209.38]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 01 Nov 2017 20:56:09 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.44,331,1505804400"; d="scan'208";a="144940675" Received: from gvt-dell.bj.intel.com (HELO gvt-dell-host.bj.intel.com) ([10.238.154.59]) by orsmga004.jf.intel.com with ESMTP; 01 Nov 2017 20:56:06 -0700 From: changbin.du@intel.com To: bhelgaas@google.com Cc: tglx@linutronix.de, mingo@redhat.com, x86@kernel.org, linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, Changbin Du Subject: [PATCH] PCI: Fail pci_map_rom if the PCI ROM is invalid Date: Thu, 2 Nov 2017 11:48:42 +0800 Message-Id: <1509594522-6841-1-git-send-email-changbin.du@intel.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: Changbin Du If we detected a invalid PCI ROM (e.g. Invalid PCI ROM header signature), we should unmap it immediately and fail. It doesn't make any sense that return a mapped area with size of 0. I have seen this case on Intel GVTg vGPU, which have no vbios. It will not cause a real problem, but we should skip it as early as possible. Signed-off-by: Changbin Du --- drivers/pci/rom.c | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/drivers/pci/rom.c b/drivers/pci/rom.c index b6edb18..1f5e6af 100644 --- a/drivers/pci/rom.c +++ b/drivers/pci/rom.c @@ -147,12 +147,8 @@ void __iomem *pci_map_rom(struct pci_dev *pdev, size_t *size) return NULL; rom = ioremap(start, *size); - if (!rom) { - /* restore enable if ioremap fails */ - if (!(res->flags & IORESOURCE_ROM_ENABLE)) - pci_disable_rom(pdev); - return NULL; - } + if (!rom) + goto err_ioremap; /* * Try to find the true size of the ROM since sometimes the PCI window @@ -160,7 +156,18 @@ void __iomem *pci_map_rom(struct pci_dev *pdev, size_t *size) * True size is important if the ROM is going to be copied. */ *size = pci_get_rom_size(pdev, rom, *size); + if (!*size) + goto invalid_rom; + return rom; + +invalid_rom: + iounmap(rom); +err_ioremap: + /* restore enable if ioremap fails */ + if (!(res->flags & IORESOURCE_ROM_ENABLE)) + pci_disable_rom(pdev); + return NULL; } EXPORT_SYMBOL(pci_map_rom); -- 2.7.4 From 1585871917887489012@xxx Mon Dec 04 16:35:17 +0000 2017 X-GM-THRID: 1585870169426285968 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread