Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp2898849imc; Wed, 13 Mar 2019 04:11:02 -0700 (PDT) X-Google-Smtp-Source: APXvYqzZ2zMO8C37tu/EIK6u9PMlcv6Alp8InG1hfiHflwuVEpQ7Dsjk2OuTyXpFTbopF/q+tjgK X-Received: by 2002:a17:902:6a4:: with SMTP id 33mr45240115plh.140.1552475462676; Wed, 13 Mar 2019 04:11:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552475462; cv=none; d=google.com; s=arc-20160816; b=mUMfVZ+ResDrN4P3JZp8V25h/9gEdWCiyIl0f0jbEtwzEZdHeo6uqb6+4IbsyUulfn TT+lpGsrfUHVkK4RYXSYAKHmRGdVrUaWlB4BJt2xBphVUno5wMtwxi7HoY2jGRpTkTUB lkM/2fiGArLi2oYfd8CjRVhqvQLRmd+DTfARpo0NEEwDNnioGkfbIq5+GrCbQkLNenRu imWac+0zMYkVaQUbaQSR+Xog5Jkp6CV10pkVIGoHEJIxY+CSOO6HyFsEvINwIyv0FInr uga/bwH4qzM98H/5zy9VyRLGPJWMvU93zbNJClJmJcFSw93O5r2HtApMyiAu3c6fxQUi Skhw== 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=iY4jfya4uxiMlWx2Oq8jHObmZ0x+Le2kxJS5HUulz7Q=; b=ZgbFB1l+sPkpDX5Dy44quWD+RfmqjRJMkMa5QkSEqF7h2RZehyPOEaZZ7H3mtuOGzx OBIB/m5g1oyx0CWzO+3fLiCcD48lBeCSD/kCIl2Vr7b20Ws7O4802yZNg+UABcTLueOH 6T5q8Qd/PwzftksHUKHsQxEw+Q4wpU1eH0ymPNqhElGaB3bG4J9BrqhQZcsL6cZNxcPD 99fUKal9naJbVwNj5tLXKkAaRTJpA+neMHEo6ZNznda36q2Mg564R4PM3/8kv9AT5wen NbFQIId6E3pdtnr+Dp3N5Nd3dtdcLDXV+OzTB9s18FVaNBodm++qQWMaJgVC7JJ6HH/Z LJ0A== 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 d2si9688222pgb.137.2019.03.13.04.10.45; Wed, 13 Mar 2019 04:11:02 -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 S1726125AbfCMLIY (ORCPT + 99 others); Wed, 13 Mar 2019 07:08:24 -0400 Received: from mx1.redhat.com ([209.132.183.28]:54556 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725832AbfCMLIX (ORCPT ); Wed, 13 Mar 2019 07:08:23 -0400 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 923D43082B6E; Wed, 13 Mar 2019 11:08:23 +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 2CDBC60165; Wed, 13 Mar 2019 11:08:21 +0000 (UTC) Received: by sirius.home.kraxel.org (Postfix, from userid 1000) id 4182711A86; Wed, 13 Mar 2019 12:08:20 +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: [RfC PATCH] fbdev: list all memory bars as conflicting apertures Date: Wed, 13 Mar 2019 12:07:41 +0100 Message-Id: <20190313110741.6541-1-kraxel@redhat.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.45]); Wed, 13 Mar 2019 11:08:23 +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(). That allows to drop the res_id parameter. TODO: actually remove the res_id parameter. Signed-off-by: Gerd Hoffmann --- drivers/video/fbdev/core/fbmem.c | 22 ++++++++++++++++++---- 1 file changed, 18 insertions(+), 4 deletions(-) diff --git a/drivers/video/fbdev/core/fbmem.c b/drivers/video/fbdev/core/fbmem.c index cb43a2258c51..e8223c231de2 100644 --- a/drivers/video/fbdev/core/fbmem.c +++ b/drivers/video/fbdev/core/fbmem.c @@ -1879,14 +1879,28 @@ 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, cnt, bar; - ap = alloc_apertures(1); + for (cnt = 0, bar = 0; bar < PCI_ROM_RESOURCE; bar++) { + if (!(pci_resource_flags(pdev, bar) & IORESOURCE_MEM)) + continue; + cnt++; + } + + ap = alloc_apertures(cnt); 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++; + } #ifdef CONFIG_X86 primary = pdev->resource[PCI_ROM_RESOURCE].flags & IORESOURCE_ROM_SHADOW; -- 2.18.1