Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3412548imu; Mon, 10 Dec 2018 01:33:46 -0800 (PST) X-Google-Smtp-Source: AFSGD/UxKG1xXw1WKyInv22t5lKrI/zURTWTjOlX1A1tEEUtYD7kAT+WzAesTgJgcuxDS6sM9dWP X-Received: by 2002:a65:610d:: with SMTP id z13mr10349783pgu.427.1544434426830; Mon, 10 Dec 2018 01:33:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544434426; cv=none; d=google.com; s=arc-20160816; b=jMuyWE9jDr9TUCA0c6H8fK3GvisUruK3wn/XimpGd13MbbtZ9HoLL1UzYyzCHVqZhp XPCKMlaTrWcpaZCJ88uZRaPnGIvnJtCEYqEPbQMR5T3b4vimFBpb1IbJlkOIV59kM6DA YOlegQ5mmwzJEd12hteHJZfFps4IQvfU0l/n6jJeTV4ZHhR4Bg3zIKl1ieNKXOQrwvU5 Y9/TrRjaW9u+YVsSqFnB7QK4DFo4tsx/qvL2DbkV+S9DmZtSCeuQVFd8gUQk1iEyqnwY vFwaU/yTeORt+LGl5BO16r1K6X/xr5uF3vlSyKpU4OjToeLOsCuAkuQkXSTMVic7EHaV y8NA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=DLy0SwLSlaGwBkl+R1noWL7/C+Z5I/Uca6dIaJcbB2c=; b=dL4h5yJTukHquYwkfwpzAKCZFdBdQ+ilmF01OmV2K+ay65shJyrxt8TCEoHxlySHZB 8R1AuR84CH/bpmiMzRd6Pr9z/Z/zz9jiH1GBXvQaCzPyotSnfRYJoV2UD1LsnEwYtFTf F4MLIRzX2qJ1l51aFvL0MRVk3aLk6G2tIbNsdF0EkEoARVRKlLMi/e0eVyqVSG8BmvON U968WCH5bgNSci/3O8Cu7yYXX5U5+Nq1RHzb/Hc2S45RVWAPbAIADcDObRDfNM2BAicY q9G5UupD2LdQ5xZ6KdgWSHPb8q9wVyu2SZU96aSf/mZjYVNwMzp39CeLJ9Ctv7q9QCcB 8TrQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=xJIdGNeK; 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 l30si9713413plg.113.2018.12.10.01.33.31; Mon, 10 Dec 2018 01:33:46 -0800 (PST) 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=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=xJIdGNeK; 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 S1727097AbeLJJ3H (ORCPT + 99 others); Mon, 10 Dec 2018 04:29:07 -0500 Received: from mail-wm1-f66.google.com ([209.85.128.66]:34711 "EHLO mail-wm1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726693AbeLJJ3H (ORCPT ); Mon, 10 Dec 2018 04:29:07 -0500 Received: by mail-wm1-f66.google.com with SMTP id y185so6140641wmd.1 for ; Mon, 10 Dec 2018 01:29:05 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=DLy0SwLSlaGwBkl+R1noWL7/C+Z5I/Uca6dIaJcbB2c=; b=xJIdGNeKegPSOtQ+PEIf8lJnRNSP/2by2POqN0ozS4xMRjCrs94QlI6MkjbzxGo7/D 6e5CdfuwmScOkQF6kKxVmeSJ4vz1n3rWiWiq9CYIZ0vUsuxp4PKEwfEOuK6AyQBlFYab 0ccIrshx8NSYw7fgS0ncO1jXA7LZWkzHgbIpt9UqHvRPll+ObfbJB26dZB5nvstK2QRs xH0wPQLL9QWMirhhn0UoiMDBGRzmjxdZ54ab+H9zsvG9Dj1MoM/mFIpe6JgViqCctD6S YhDFtzARuwDxlTlOovCqYR40J/qyd+xWOCaPM61nwYAoIInyOq/2oGpz9623gTzcL2ry 4QyQ== 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:mime-version :content-transfer-encoding; bh=DLy0SwLSlaGwBkl+R1noWL7/C+Z5I/Uca6dIaJcbB2c=; b=mJ09K05PLq63T9Fcm/DyOyg72yKaJ+2Yte1goahygXcuBwxoTw6R12jkK9MOCLKSX1 UEIHAkPZAL+voZr7D8InoNuT5sJB+MKfZqdXUWcj4frKhF4CWUFcqnD9yW+fKafhY+MI IpcrUjidobGBk5E2yP2jq2KIUopjz1OjzHa3uMsOjLoKOaTmhMqLb5rwSDDUJmEU5liF pRhedlGui10D8g+nz2EwHGn9IGWgzxGDsafQWto5+olHXE8uHXU45D81EomL5m7pXqWf 4I7noW5Y43v80ECLn4f2cL/KaobBvcWEa9g2qqwtR+YsJ5WudoEpOaLMHbdCvULZsO/O euWA== X-Gm-Message-State: AA+aEWbnaaDOEU2oegBr5yfVE+JrrD3G/7q1swC1a1WSMEFwpk1xgGuZ LWxLEoIdN38X6hrsvS8s566vKA== X-Received: by 2002:a1c:91d1:: with SMTP id t200mr9737373wmd.111.1544434145308; Mon, 10 Dec 2018 01:29:05 -0800 (PST) Received: from localhost.localdomain (abo-99-183-68.mtp.modulonet.fr. [85.68.183.99]) by smtp.gmail.com with ESMTPSA id k128sm16348976wmd.37.2018.12.10.01.29.04 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 10 Dec 2018 01:29:04 -0800 (PST) From: Maxime Jourdan To: Neil Armstrong Cc: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-amlogic@lists.infradead.org, dri-devel@lists.freedesktop.org Subject: [PATCH RESEND] drm/meson: remove firmware framebuffers Date: Mon, 10 Dec 2018 10:28:53 +0100 Message-Id: <20181210092853.13050-1-mjourdan@baylibre.com> X-Mailer: git-send-email 2.19.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In case we are using simplefb or another conflicting framebuffer, make the call to drm_fb_helper_remove_conflicting_framebuffers() Signed-off-by: Maxime Jourdan --- drivers/gpu/drm/meson/meson_drv.c | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/drivers/gpu/drm/meson/meson_drv.c b/drivers/gpu/drm/meson/meson_drv.c index d3443125e661..afbb3d707d15 100644 --- a/drivers/gpu/drm/meson/meson_drv.c +++ b/drivers/gpu/drm/meson/meson_drv.c @@ -159,6 +159,23 @@ static void meson_vpu_init(struct meson_drm *priv) writel_relaxed(0x20000, priv->io_base + _REG(VPU_WRARB_MODE_L2C1)); } +static void meson_remove_framebuffers(void) +{ + struct apertures_struct *ap; + + ap = alloc_apertures(1); + if (!ap) + return; + + /* The framebuffer can be located anywhere in RAM */ + ap->ranges[0].base = 0; + ap->ranges[0].size = ~0; + + drm_fb_helper_remove_conflicting_framebuffers(ap, "meson-drm-fb", + false); + kfree(ap); +} + static int meson_drv_bind_master(struct device *dev, bool has_components) { struct platform_device *pdev = to_platform_device(dev); @@ -242,6 +259,9 @@ static int meson_drv_bind_master(struct device *dev, bool has_components) if (ret) goto free_drm; + /* Remove early framebuffers (ie. simplefb) */ + meson_remove_framebuffers(); + drm_mode_config_init(drm); drm->mode_config.max_width = 3840; drm->mode_config.max_height = 2160; -- 2.19.2