diff options
author | Jesse Barnes <jbarnes@virtuousgeek.org> | 2014-02-12 15:26:25 -0500 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2014-02-12 17:42:17 -0500 |
commit | eb1bfe807cb7b62a326fa20df5e3118a32c6f923 (patch) | |
tree | 97bf9ad3b0eaf19cfe582b59ce4aa334d3bc582a /drivers/gpu/drm/i915/intel_display.c | |
parent | 2f1046f304b1ab14ea611a01b85f3486f2b9ce5b (diff) |
drm/i915: allow re-use BIOS connector config for initial fbdev config v3
The BIOS or boot loader will generally create an initial display
configuration for us that includes some set of active pipes and
displays. This routine tries to figure out which pipes and connectors
are active and stuffs them into the crtcs and modes array given to us by
the drm_fb_helper code.
The overall sequence is:
intel_fbdev_init - from driver load
intel_fbdev_init_bios - initialize the intel_fbdev using BIOS data
drm_fb_helper_init - build fb helper structs
drm_fb_helper_single_add_all_connectors - more fb helper structs
intel_fbdev_initial_config - apply the config
drm_fb_helper_initial_config - call ->probe then register_framebuffer()
drm_setup_crtcs - build crtc config for fbdev
intel_fb_initial_config - find active connectors etc
drm_fb_helper_single_fb_probe - set up fbdev
intelfb_create - re-use or alloc fb, build out fbdev structs
v2: use BIOS connector config unconditionally if possible (Daniel)
check for crtc cloning and reject (Daniel)
fix up comments (Daniel)
v3: use command line args and preferred modes first (Ville)
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Tested-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
[danvet: Re-add the WARN_ON for a missing encoder crtc - the state
sanitizer should take care of this. And spell-ocd the comments.]
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_display.c')
-rw-r--r-- | drivers/gpu/drm/i915/intel_display.c | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index 2cc18e516a2a..ede87aa3b24b 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
@@ -51,7 +51,10 @@ static void ironlake_pch_clock_get(struct intel_crtc *crtc, | |||
51 | 51 | ||
52 | static int intel_set_mode(struct drm_crtc *crtc, struct drm_display_mode *mode, | 52 | static int intel_set_mode(struct drm_crtc *crtc, struct drm_display_mode *mode, |
53 | int x, int y, struct drm_framebuffer *old_fb); | 53 | int x, int y, struct drm_framebuffer *old_fb); |
54 | 54 | static int intel_framebuffer_init(struct drm_device *dev, | |
55 | struct intel_framebuffer *ifb, | ||
56 | struct drm_mode_fb_cmd2 *mode_cmd, | ||
57 | struct drm_i915_gem_object *obj); | ||
55 | 58 | ||
56 | typedef struct { | 59 | typedef struct { |
57 | int min, max; | 60 | int min, max; |
@@ -7692,11 +7695,6 @@ static struct drm_display_mode load_detect_mode = { | |||
7692 | 704, 832, 0, 480, 489, 491, 520, 0, DRM_MODE_FLAG_NHSYNC | DRM_MODE_FLAG_NVSYNC), | 7695 | 704, 832, 0, 480, 489, 491, 520, 0, DRM_MODE_FLAG_NHSYNC | DRM_MODE_FLAG_NVSYNC), |
7693 | }; | 7696 | }; |
7694 | 7697 | ||
7695 | static int intel_framebuffer_init(struct drm_device *dev, | ||
7696 | struct intel_framebuffer *ifb, | ||
7697 | struct drm_mode_fb_cmd2 *mode_cmd, | ||
7698 | struct drm_i915_gem_object *obj); | ||
7699 | |||
7700 | struct drm_framebuffer * | 7698 | struct drm_framebuffer * |
7701 | __intel_framebuffer_create(struct drm_device *dev, | 7699 | __intel_framebuffer_create(struct drm_device *dev, |
7702 | struct drm_mode_fb_cmd2 *mode_cmd, | 7700 | struct drm_mode_fb_cmd2 *mode_cmd, |