]> git.karo-electronics.de Git - karo-tx-linux.git/blobdiff - drivers/gpu/drm/sti/sti_drv.c
Merge tag 'drm-misc-next-2017-01-23' of git://anongit.freedesktop.org/git/drm-misc...
[karo-tx-linux.git] / drivers / gpu / drm / sti / sti_drv.c
index ff71e25ab5bf30cb288c607fd5e03391172e0d8a..278a63f10d9fddb3971526e33f1b1a38f0b14fe4 100644 (file)
@@ -252,19 +252,7 @@ static void sti_output_poll_changed(struct drm_device *ddev)
 {
        struct sti_private *private = ddev->dev_private;
 
-       if (!ddev->mode_config.num_connector)
-               return;
-
-       if (private->fbdev) {
-               drm_fbdev_cma_hotplug_event(private->fbdev);
-               return;
-       }
-
-       private->fbdev = drm_fbdev_cma_init(ddev, 32,
-                                           ddev->mode_config.num_crtc,
-                                           ddev->mode_config.num_connector);
-       if (IS_ERR(private->fbdev))
-               private->fbdev = NULL;
+       drm_fbdev_cma_hotplug_event(private->fbdev);
 }
 
 static const struct drm_mode_config_funcs sti_mode_config_funcs = {
@@ -382,6 +370,8 @@ static void sti_cleanup(struct drm_device *ddev)
 static int sti_bind(struct device *dev)
 {
        struct drm_device *ddev;
+       struct sti_private *private;
+       struct drm_fbdev_cma *fbdev;
        int ret;
 
        ddev = drm_dev_alloc(&sti_driver, dev);
@@ -404,6 +394,17 @@ static int sti_bind(struct device *dev)
 
        drm_mode_config_reset(ddev);
 
+       private = ddev->dev_private;
+       if (ddev->mode_config.num_connector) {
+               fbdev = drm_fbdev_cma_init(ddev, 32, ddev->mode_config.num_crtc,
+                                          ddev->mode_config.num_connector);
+               if (IS_ERR(fbdev)) {
+                       DRM_DEBUG_DRIVER("Warning: fails to create fbdev\n");
+                       fbdev = NULL;
+               }
+               private->fbdev = fbdev;
+       }
+
        return 0;
 
 err_register:
@@ -476,7 +477,6 @@ static struct platform_driver sti_platform_driver = {
 
 static struct platform_driver * const drivers[] = {
        &sti_tvout_driver,
-       &sti_vtac_driver,
        &sti_hqvdp_driver,
        &sti_hdmi_driver,
        &sti_hda_driver,