aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_drv.h
diff options
context:
space:
mode:
authorDaniel Vetter <daniel.vetter@ffwll.ch>2012-06-05 06:14:54 -0400
committerDaniel Vetter <daniel.vetter@ffwll.ch>2012-06-12 13:27:58 -0400
commit24ded204429fa0f5501d37c63ee35c555c0b75ee (patch)
tree0fcebac4835709b28ed26b30d02b64a88c0e158a /drivers/gpu/drm/i915/intel_drv.h
parent7cf4160148136deb31ee5f2802857dd935a38529 (diff)
drm/i915: properly enable the blc controller on the right pipe
On gen4+ we have a bitfield to specify from which pipe the backlight controller should take it's clock. For PCH split platforms we've already set these up, but only at initialization time. And without taking into account the 3rd pipe added with ivb. For gen4, we've completely ignored these. Although we do restrict lvds to the 2nd pipe, so this is only a problem on machines where we boot up with the lvds on the first pipe. So restructure the code to enable the backlight on the right pipe at modeset time. v2: For odd reasons panel_enable_backlight gets called twice in a modeset, so we can't WARN_ON in there if the backlight controller is switched on already. v3: backlight enable can also be called through dpms on, so the check in there is legit. Update the comment to reflect that. Tested-By: Kamal Mostafa <kamal@canonical.com> Bugzilla: https://bugs.launchpad.net/bugs/954661 Cc: Carsten Emde <C.Emde@osadl.org> Reviewed-by: Eugeni Dodonov <eugeni.dodonov@intel.com> Signed-Off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_drv.h')
-rw-r--r--drivers/gpu/drm/i915/intel_drv.h3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/gpu/drm/i915/intel_drv.h b/drivers/gpu/drm/i915/intel_drv.h
index c35edd7ca84d..1a1fdb088dda 100644
--- a/drivers/gpu/drm/i915/intel_drv.h
+++ b/drivers/gpu/drm/i915/intel_drv.h
@@ -379,7 +379,8 @@ extern u32 intel_panel_get_max_backlight(struct drm_device *dev);
379extern u32 intel_panel_get_backlight(struct drm_device *dev); 379extern u32 intel_panel_get_backlight(struct drm_device *dev);
380extern void intel_panel_set_backlight(struct drm_device *dev, u32 level); 380extern void intel_panel_set_backlight(struct drm_device *dev, u32 level);
381extern int intel_panel_setup_backlight(struct drm_device *dev); 381extern int intel_panel_setup_backlight(struct drm_device *dev);
382extern void intel_panel_enable_backlight(struct drm_device *dev); 382extern void intel_panel_enable_backlight(struct drm_device *dev,
383 enum pipe pipe);
383extern void intel_panel_disable_backlight(struct drm_device *dev); 384extern void intel_panel_disable_backlight(struct drm_device *dev);
384extern void intel_panel_destroy_backlight(struct drm_device *dev); 385extern void intel_panel_destroy_backlight(struct drm_device *dev);
385extern enum drm_connector_status intel_panel_detect(struct drm_device *dev); 386extern enum drm_connector_status intel_panel_detect(struct drm_device *dev);