drm/rockchip: remove existing generic drivers to take over the device
authorJavier Martinez Canillas <javierm@redhat.com>
Sun, 16 May 2021 07:48:33 +0000 (09:48 +0200)
committerThomas Zimmermann <tzimmermann@suse.de>
Fri, 28 May 2021 13:57:19 +0000 (15:57 +0200)
There are drivers that register framebuffer devices very early in the boot
process and make use of the existing framebuffer as setup by the firmware.

If one of those drivers has registered a fbdev, then the fallback fbdev of
the DRM driver won't be bound to the framebuffer console. To avoid that,
remove any existing generic driver and take over the graphics device.

By doing that, the fb mapped to the console is switched correctly from the
early fbdev to the one registered by the rockchip DRM driver:

    [   40.752420] fb0: switching to rockchip-drm-fb from EFI VGA

Signed-off-by: Javier Martinez Canillas <javierm@redhat.com>
Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de>
Tested-by: Peter Robinson <pbrobinson@gmail.com>
Acked-by: Thomas Zimmermann <tzimmermann@suse.de>
Acked-by: Heiko Stuebner <heiko@sntech.de>
Link: https://patchwork.freedesktop.org/patch/msgid/20210516074833.451643-1-javierm@redhat.com
drivers/gpu/drm/rockchip/rockchip_drm_drv.c

index 212bd87..b730b8d 100644 (file)
@@ -16,6 +16,7 @@
 #include <linux/console.h>
 #include <linux/iommu.h>
 
+#include <drm/drm_aperture.h>
 #include <drm/drm_drv.h>
 #include <drm/drm_fb_helper.h>
 #include <drm/drm_gem_cma_helper.h>
@@ -114,6 +115,15 @@ static int rockchip_drm_bind(struct device *dev)
        struct rockchip_drm_private *private;
        int ret;
 
+       /* Remove existing drivers that may own the framebuffer memory. */
+       ret = drm_aperture_remove_framebuffers(false, "rockchip-drm-fb");
+       if (ret) {
+               DRM_DEV_ERROR(dev,
+                             "Failed to remove existing framebuffers - %d.\n",
+                             ret);
+               return ret;
+       }
+
        drm_dev = drm_dev_alloc(&rockchip_drm_driver, dev);
        if (IS_ERR(drm_dev))
                return PTR_ERR(drm_dev);