Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp3758859imc; Thu, 14 Mar 2019 04:47:24 -0700 (PDT) X-Google-Smtp-Source: APXvYqzSjSTS5ERzibapJdyQdZnxrwnSAiDkLca8psEXI7TX3lf1rYFshaQ+TjyBgLXGO+imVbOG X-Received: by 2002:a63:e447:: with SMTP id i7mr44521409pgk.70.1552564044106; Thu, 14 Mar 2019 04:47:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552564044; cv=none; d=google.com; s=arc-20160816; b=tYMeid4MZm3Z/oXlbQTn8muKcdmqqItDqSKLXJNWGwaHl7y88jF8wIMwryRcaIKSaG lzlN9/tLMrv+kWj0RHR33gmspVE51ZHhZIHJ3S0Inq2/NqUkeu4787e7YD+hG74ji5ft 2NUIb5w71686BEmVGCbO3ItksN4Q8HoD8oFd+/QJzCZy0q73fYz8pQuzjtMVz3njygdd rsutle/XvJBxO+2lLD4ZtM+yqDLljMXwCzCzSpUYb7GFdnZK70fR3O6NTOO3VgbjxvHw Z5L4y37AsHfGcm7cjM8eaHyLQjaidrhjazvnXD3xDk5Y/sUfiHCMda4hjHrwV3MN+xxg SmgQ== 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; bh=8e82G2/Q/RVZ5qKHHLeHJCLowlKYQzqsrGgIrYrHBqs=; b=XsC0Sn7IwirY/i+qphjn2xk/wILaegF6xXGGe+rUj0TDSHwd8OUX+AhJYXq7llqes3 zDs7x/eIETEtEan90Xntr18Ic2+poodSo8ZRf4nsuO5hYQlF+j8bD8uWi9aBLpRkKDe/ C+yU2Q+s+w8wu6Cs2QhzHIyt/VzyZDFHtOOPxHhD/pKinyQLCoKkzZabL/s/eaO5sOW+ 1whD/rBJOt/pGWfD1WVFJhu1ppgnCVWwkPTuqFaJ/2aAGU3SpA6D9n86e9LgPcGtDtFO 6ZcP3SW/oGbZX36y/AW+KMlMM7TBcR0oCDg6Cd/MM+VRSaetPZtBmTgSdGckLaajH8e5 ExAw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t11si11945471pgp.229.2019.03.14.04.47.08; Thu, 14 Mar 2019 04:47:24 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727484AbfCNLpI (ORCPT + 99 others); Thu, 14 Mar 2019 07:45:08 -0400 Received: from mx1.redhat.com ([209.132.183.28]:39226 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727436AbfCNLpH (ORCPT ); Thu, 14 Mar 2019 07:45:07 -0400 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.phx2.redhat.com [10.5.11.13]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 198E07A178; Thu, 14 Mar 2019 11:45:07 +0000 (UTC) Received: from sirius.home.kraxel.org (ovpn-116-24.ams2.redhat.com [10.36.116.24]) by smtp.corp.redhat.com (Postfix) with ESMTP id 694AE18258; Thu, 14 Mar 2019 11:45:03 +0000 (UTC) Received: by sirius.home.kraxel.org (Postfix, from userid 1000) id 68D1711A86; Thu, 14 Mar 2019 12:45:02 +0100 (CET) From: Gerd Hoffmann To: dri-devel@lists.freedesktop.org Cc: Daniel Vetter , Gerd Hoffmann , Bartlomiej Zolnierkiewicz , linux-fbdev@vger.kernel.org (open list:FRAMEBUFFER LAYER), linux-kernel@vger.kernel.org (open list) Subject: [PATCH] fbdev: list all pci memory bars as conflicting apertures Date: Thu, 14 Mar 2019 12:45:00 +0100 Message-Id: <20190314114500.8336-1-kraxel@redhat.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.13 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.28]); Thu, 14 Mar 2019 11:45:07 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Simply add all pci memory bars to struct apertures_struct in remove_conflicting_pci_framebuffers(), without depending on the res_id parameter. The plan is to drop the res_id parameter later on. For now keep the parameter, use it for sanity-checking and warn on inconsistencies. Signed-off-by: Gerd Hoffmann Reviewed-by: Daniel Vetter --- drivers/video/fbdev/core/fbmem.c | 29 +++++++++++++++++++++++++---- 1 file changed, 25 insertions(+), 4 deletions(-) diff --git a/drivers/video/fbdev/core/fbmem.c b/drivers/video/fbdev/core/fbmem.c index cb43a2258c51..e4e5c129a0f5 100644 --- a/drivers/video/fbdev/core/fbmem.c +++ b/drivers/video/fbdev/core/fbmem.c @@ -1879,14 +1879,35 @@ int remove_conflicting_pci_framebuffers(struct pci_dev *pdev, int res_id, const { struct apertures_struct *ap; bool primary = false; - int err; + int err, idx, bar; + bool res_id_found = false; - ap = alloc_apertures(1); + for (idx = 0, bar = 0; bar < PCI_ROM_RESOURCE; bar++) { + if (!(pci_resource_flags(pdev, bar) & IORESOURCE_MEM)) + continue; + idx++; + } + + ap = alloc_apertures(idx); if (!ap) return -ENOMEM; - ap->ranges[0].base = pci_resource_start(pdev, res_id); - ap->ranges[0].size = pci_resource_len(pdev, res_id); + for (idx = 0, bar = 0; bar < PCI_ROM_RESOURCE; bar++) { + if (!(pci_resource_flags(pdev, bar) & IORESOURCE_MEM)) + continue; + ap->ranges[idx].base = pci_resource_start(pdev, bar); + ap->ranges[idx].size = pci_resource_len(pdev, bar); + pci_info(pdev, "%s: bar %d: 0x%lx -> 0x%lx\n", __func__, bar, + (unsigned long)pci_resource_start(pdev, bar), + (unsigned long)pci_resource_end(pdev, bar)); + idx++; + if (res_id == bar) + res_id_found = true; + } + if (!res_id_found) + pci_warn(pdev, "%s: passed res_id (%d) is not a memory bar\n", + __func__, res_id); + #ifdef CONFIG_X86 primary = pdev->resource[PCI_ROM_RESOURCE].flags & IORESOURCE_ROM_SHADOW; -- 2.18.1