drm/fb-helper: don't disable everything in initial_config
authorDaniel Vetter <daniel.vetter@ffwll.ch>
Sun, 20 Jan 2013 22:12:54 +0000 (23:12 +0100)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Wed, 13 Feb 2013 23:07:53 +0000 (00:07 +0100)
This should be done in the drivers for two reasons:
- it gets in the way of fastboot efforts
- it links the fb helpers with the crtc helpers instead of going
  through the real interface vfuncs, forcing i915 to fake all the
  ->disable callbacks used by the crtc helper to avoid ugly Oopsen

v2: Resolve conflicts since drivers still call
drm_fb_helper_single_add_all_connectors.

Reviewed-by: Rob Clark <robdclark@gmail.com>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
12 files changed:
drivers/gpu/drm/ast/ast_fb.c
drivers/gpu/drm/cirrus/cirrus_fbdev.c
drivers/gpu/drm/drm_fb_cma_helper.c
drivers/gpu/drm/drm_fb_helper.c
drivers/gpu/drm/exynos/exynos_drm_fbdev.c
drivers/gpu/drm/gma500/framebuffer.c
drivers/gpu/drm/i915/intel_fb.c
drivers/gpu/drm/mgag200/mgag200_fb.c
drivers/gpu/drm/nouveau/nouveau_fbcon.c
drivers/gpu/drm/radeon/radeon_fb.c
drivers/gpu/drm/udl/udl_fb.c
drivers/staging/omapdrm/omap_fbdev.c

index 3e6584b940dcf179b6fb678e047fcaebcf8d0bc5..81763cad9940bcd5335943dcbe341e51219c8df2 100644 (file)
@@ -40,6 +40,7 @@
 #include <drm/drmP.h>
 #include <drm/drm_crtc.h>
 #include <drm/drm_fb_helper.h>
+#include <drm/drm_crtc_helper.h>
 #include "ast_drv.h"
 
 static void ast_dirty_update(struct ast_fbdev *afbdev,
@@ -314,6 +315,10 @@ int ast_fbdev_init(struct drm_device *dev)
        }
 
        drm_fb_helper_single_add_all_connectors(&afbdev->helper);
+
+       /* disable all the possible outputs/crtcs before entering KMS mode */
+       drm_helper_disable_unused_functions(dev);
+
        drm_fb_helper_initial_config(&afbdev->helper, 32);
        return 0;
 }
index 3daea0f638c3ddd7bb6a58a2eb668b54344a5d32..b96605c6e1b6674f238e3114c02bcefaf872e35b 100644 (file)
@@ -11,6 +11,7 @@
 #include <linux/module.h>
 #include <drm/drmP.h>
 #include <drm/drm_fb_helper.h>
+#include <drm/drm_crtc_helper.h>
 
 #include <linux/fb.h>
 
@@ -291,6 +292,9 @@ int cirrus_fbdev_init(struct cirrus_device *cdev)
                return ret;
        }
        drm_fb_helper_single_add_all_connectors(&gfbdev->helper);
+
+       /* disable all the possible outputs/crtcs before entering KMS mode */
+       drm_helper_disable_unused_functions(cdev->dev);
        drm_fb_helper_initial_config(&gfbdev->helper, bpp_sel);
 
        return 0;
index 1b6ba2d4d60c02e9c7c58874d5f0ae2db5faf374..ef3d33a8a7e2d747acb71689691ca6b177976c80 100644 (file)
@@ -333,6 +333,9 @@ struct drm_fbdev_cma *drm_fbdev_cma_init(struct drm_device *dev,
 
        }
 
+       /* disable all the possible outputs/crtcs before entering KMS mode */
+       drm_helper_disable_unused_functions(dev);
+
        ret = drm_fb_helper_initial_config(helper, preferred_bpp);
        if (ret < 0) {
                dev_err(dev->dev, "Failed to set inital hw configuration.\n");
index f5d362680f2bdcd84246cd3ce1ef4fe47628af23..d841b68aaa3ef2fe65a3d2918e1c9dfb3d8267f5 100644 (file)
@@ -1360,9 +1360,6 @@ bool drm_fb_helper_initial_config(struct drm_fb_helper *fb_helper, int bpp_sel)
        struct drm_device *dev = fb_helper->dev;
        int count = 0;
 
-       /* disable all the possible outputs/crtcs before entering KMS mode */
-       drm_helper_disable_unused_functions(fb_helper->dev);
-
        drm_fb_helper_parse_command_line(fb_helper);
 
        count = drm_fb_helper_probe_connector_modes(fb_helper,
index 086d0f79785f1af4c7a5168989806fd1c08a69bf..fe2a0f068af705a32f6a1ae956f13597e29b06a7 100644 (file)
@@ -295,6 +295,9 @@ int exynos_drm_fbdev_init(struct drm_device *dev)
 
        }
 
+       /* disable all the possible outputs/crtcs before entering KMS mode */
+       drm_helper_disable_unused_functions(dev);
+
        ret = drm_fb_helper_initial_config(helper, PREFERRED_BPP);
        if (ret < 0) {
                DRM_ERROR("failed to set up hw configuration.\n");
index c1ef37e2efdf35d8ff11fbc0ff6ac4bdfa4565d5..fee3bf85af4aa32bd14512cef7576d2cffa775a9 100644 (file)
@@ -616,6 +616,10 @@ int psb_fbdev_init(struct drm_device *dev)
                                                        INTELFB_CONN_LIMIT);
 
        drm_fb_helper_single_add_all_connectors(&fbdev->psb_fb_helper);
+
+       /* disable all the possible outputs/crtcs before entering KMS mode */
+       drm_helper_disable_unused_functions(dev);
+
        drm_fb_helper_initial_config(&fbdev->psb_fb_helper, 32);
        return 0;
 }
index 1c510da04d16446de1c8a514be03793c4eeff74b..e67061249934fe35780a3c59c13c5b9e26d6303f 100644 (file)
@@ -258,6 +258,9 @@ void intel_fbdev_initial_config(struct drm_device *dev)
 {
        drm_i915_private_t *dev_priv = dev->dev_private;
 
+       /* disable all the possible outputs/crtcs before entering KMS mode */
+       drm_helper_disable_unused_functions(dev);
+
        /* Due to peculiar init order wrt to hpd handling this is separate. */
        drm_fb_helper_initial_config(&dev_priv->fbdev->helper, 32);
 }
index 5c69b432f99aced839d9df2b3f60ce005728d838..5bded5b74eafcc6e7e6a410a83f53a508031001b 100644 (file)
@@ -13,6 +13,7 @@
 #include <linux/module.h>
 #include <drm/drmP.h>
 #include <drm/drm_fb_helper.h>
+#include <drm/drm_crtc_helper.h>
 
 #include <linux/fb.h>
 
@@ -278,6 +279,10 @@ int mgag200_fbdev_init(struct mga_device *mdev)
                return ret;
        }
        drm_fb_helper_single_add_all_connectors(&mfbdev->helper);
+
+       /* disable all the possible outputs/crtcs before entering KMS mode */
+       drm_helper_disable_unused_functions(mdev->dev);
+
        drm_fb_helper_initial_config(&mfbdev->helper, 32);
 
        return 0;
index d4ecb4deb4848693a56a00e355955e26102b9cf8..b1ebfe30f91263df859b744ea0c26630fcc7b300 100644 (file)
@@ -491,6 +491,9 @@ nouveau_fbcon_init(struct drm_device *dev)
        else
                preferred_bpp = 32;
 
+       /* disable all the possible outputs/crtcs before entering KMS mode */
+       drm_helper_disable_unused_functions(dev);
+
        drm_fb_helper_initial_config(&fbcon->helper, preferred_bpp);
        return 0;
 }
index 515e5ee1f9eea9870ae39e78d420e6c8ffd60dee..b48d1c8cf9eb1afcf7055839478e3d33ac5774e8 100644 (file)
@@ -379,6 +379,10 @@ int radeon_fbdev_init(struct radeon_device *rdev)
        }
 
        drm_fb_helper_single_add_all_connectors(&rfbdev->helper);
+
+       /* disable all the possible outputs/crtcs before entering KMS mode */
+       drm_helper_disable_unused_functions(rdev->ddev);
+
        drm_fb_helper_initial_config(&rfbdev->helper, bpp_sel);
        return 0;
 }
index b9feec9d08d3dad033b1b5940fd56c815c6f853d..cf5d05a0d955fcb17d80393ae1b7cdf4ade3111e 100644 (file)
@@ -619,6 +619,10 @@ int udl_fbdev_init(struct drm_device *dev)
        }
 
        drm_fb_helper_single_add_all_connectors(&ufbdev->helper);
+
+       /* disable all the possible outputs/crtcs before entering KMS mode */
+       drm_helper_disable_unused_functions(dev);
+
        drm_fb_helper_initial_config(&ufbdev->helper, bpp_sel);
        return 0;
 }
index 2728e37e02bea7af9e709808fe9dbc75a8811963..7e66eb138315425cd7843518cdb064137e51a0a2 100644 (file)
@@ -369,6 +369,10 @@ struct drm_fb_helper *omap_fbdev_init(struct drm_device *dev)
        }
 
        drm_fb_helper_single_add_all_connectors(helper);
+
+       /* disable all the possible outputs/crtcs before entering KMS mode */
+       drm_helper_disable_unused_functions(dev);
+
        drm_fb_helper_initial_config(helper, 32);
 
        priv->fbdev = helper;