|
|
@@ -813,12 +813,28 @@ static int intel_dual_link_lvds_callback(const struct dmi_system_id *id)
|
|
|
static const struct dmi_system_id intel_dual_link_lvds[] = {
|
|
|
{
|
|
|
.callback = intel_dual_link_lvds_callback,
|
|
|
- .ident = "Apple MacBook Pro (Core i5/i7 Series)",
|
|
|
+ .ident = "Apple MacBook Pro 15\" (2010)",
|
|
|
+ .matches = {
|
|
|
+ DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."),
|
|
|
+ DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro6,2"),
|
|
|
+ },
|
|
|
+ },
|
|
|
+ {
|
|
|
+ .callback = intel_dual_link_lvds_callback,
|
|
|
+ .ident = "Apple MacBook Pro 15\" (2011)",
|
|
|
.matches = {
|
|
|
DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."),
|
|
|
DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro8,2"),
|
|
|
},
|
|
|
},
|
|
|
+ {
|
|
|
+ .callback = intel_dual_link_lvds_callback,
|
|
|
+ .ident = "Apple MacBook Pro 15\" (2012)",
|
|
|
+ .matches = {
|
|
|
+ DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."),
|
|
|
+ DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro9,1"),
|
|
|
+ },
|
|
|
+ },
|
|
|
{ } /* terminating entry */
|
|
|
};
|
|
|
|
|
|
@@ -848,6 +864,11 @@ static bool compute_is_dual_link_lvds(struct intel_lvds_encoder *lvds_encoder)
|
|
|
if (i915.lvds_channel_mode > 0)
|
|
|
return i915.lvds_channel_mode == 2;
|
|
|
|
|
|
+ /* single channel LVDS is limited to 112 MHz */
|
|
|
+ if (lvds_encoder->attached_connector->base.panel.fixed_mode->clock
|
|
|
+ > 112999)
|
|
|
+ return true;
|
|
|
+
|
|
|
if (dmi_check_system(intel_dual_link_lvds))
|
|
|
return true;
|
|
|
|
|
|
@@ -1111,6 +1132,8 @@ void intel_lvds_init(struct drm_device *dev)
|
|
|
out:
|
|
|
mutex_unlock(&dev->mode_config.mutex);
|
|
|
|
|
|
+ intel_panel_init(&intel_connector->panel, fixed_mode, downclock_mode);
|
|
|
+
|
|
|
lvds_encoder->is_dual_link = compute_is_dual_link_lvds(lvds_encoder);
|
|
|
DRM_DEBUG_KMS("detected %s-link lvds configuration\n",
|
|
|
lvds_encoder->is_dual_link ? "dual" : "single");
|
|
|
@@ -1125,7 +1148,6 @@ out:
|
|
|
}
|
|
|
drm_connector_register(connector);
|
|
|
|
|
|
- intel_panel_init(&intel_connector->panel, fixed_mode, downclock_mode);
|
|
|
intel_panel_setup_backlight(connector, INVALID_PIPE);
|
|
|
|
|
|
return;
|