mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-10-28 15:20:41 +00:00
drm/i915: Put fixed modes directly onto the panel's fixed_modes list
Rather than having the connector init get the fixed mode back from intel_panel and then feed it straight back into intel_panel_init() let's just make the fixed mode lookup put the mode directly onto the panel's fixed_modes list. Avoids the pointless round trip and opens the door for further enhancements to the fixed mode handling. v2: Make the debug message correct by using intel_panel_drrs_type() (Jani) Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20220331112822.11462-3-ville.syrjala@linux.intel.com Reviewed-by: Jani Nikula <jani.nikula@intel.com>
This commit is contained in:
parent
1c05183a37
commit
db10c14a25
10 changed files with 83 additions and 119 deletions
|
@ -1993,7 +1993,6 @@ void icl_dsi_init(struct drm_i915_private *dev_priv)
|
||||||
struct intel_encoder *encoder;
|
struct intel_encoder *encoder;
|
||||||
struct intel_connector *intel_connector;
|
struct intel_connector *intel_connector;
|
||||||
struct drm_connector *connector;
|
struct drm_connector *connector;
|
||||||
struct drm_display_mode *fixed_mode;
|
|
||||||
enum port port;
|
enum port port;
|
||||||
|
|
||||||
if (!intel_bios_is_dsi_present(dev_priv, &port))
|
if (!intel_bios_is_dsi_present(dev_priv, &port))
|
||||||
|
@ -2050,15 +2049,16 @@ void icl_dsi_init(struct drm_i915_private *dev_priv)
|
||||||
intel_connector_attach_encoder(intel_connector, encoder);
|
intel_connector_attach_encoder(intel_connector, encoder);
|
||||||
|
|
||||||
mutex_lock(&dev->mode_config.mutex);
|
mutex_lock(&dev->mode_config.mutex);
|
||||||
fixed_mode = intel_panel_vbt_lfp_fixed_mode(intel_connector);
|
intel_panel_add_vbt_lfp_fixed_mode(intel_connector);
|
||||||
mutex_unlock(&dev->mode_config.mutex);
|
mutex_unlock(&dev->mode_config.mutex);
|
||||||
|
|
||||||
if (!fixed_mode) {
|
if (!intel_panel_preferred_fixed_mode(intel_connector)) {
|
||||||
drm_err(&dev_priv->drm, "DSI fixed mode info missing\n");
|
drm_err(&dev_priv->drm, "DSI fixed mode info missing\n");
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
intel_panel_init(intel_connector, fixed_mode, NULL);
|
intel_panel_init(intel_connector);
|
||||||
|
|
||||||
intel_backlight_setup(intel_connector, INVALID_PIPE);
|
intel_backlight_setup(intel_connector, INVALID_PIPE);
|
||||||
|
|
||||||
if (dev_priv->vbt.dsi.config->dual_link)
|
if (dev_priv->vbt.dsi.config->dual_link)
|
||||||
|
|
|
@ -5015,8 +5015,7 @@ static bool intel_edp_init_connector(struct intel_dp *intel_dp,
|
||||||
struct drm_i915_private *dev_priv = dp_to_i915(intel_dp);
|
struct drm_i915_private *dev_priv = dp_to_i915(intel_dp);
|
||||||
struct drm_device *dev = &dev_priv->drm;
|
struct drm_device *dev = &dev_priv->drm;
|
||||||
struct drm_connector *connector = &intel_connector->base;
|
struct drm_connector *connector = &intel_connector->base;
|
||||||
struct drm_display_mode *fixed_mode = NULL;
|
struct drm_display_mode *fixed_mode;
|
||||||
struct drm_display_mode *downclock_mode = NULL;
|
|
||||||
bool has_dpcd;
|
bool has_dpcd;
|
||||||
enum pipe pipe = INVALID_PIPE;
|
enum pipe pipe = INVALID_PIPE;
|
||||||
struct edid *edid;
|
struct edid *edid;
|
||||||
|
@ -5073,20 +5072,22 @@ static bool intel_edp_init_connector(struct intel_dp *intel_dp,
|
||||||
}
|
}
|
||||||
intel_connector->edid = edid;
|
intel_connector->edid = edid;
|
||||||
|
|
||||||
fixed_mode = intel_panel_edid_fixed_mode(intel_connector);
|
intel_panel_add_edid_fixed_mode(intel_connector);
|
||||||
if (fixed_mode && intel_edp_has_drrs(intel_dp))
|
if (intel_panel_preferred_fixed_mode(intel_connector) &&
|
||||||
downclock_mode = intel_drrs_init(intel_connector, fixed_mode);
|
intel_edp_has_drrs(intel_dp))
|
||||||
|
intel_drrs_init(intel_connector);
|
||||||
|
|
||||||
/* MSO requires information from the EDID */
|
/* MSO requires information from the EDID */
|
||||||
intel_edp_mso_init(intel_dp);
|
intel_edp_mso_init(intel_dp);
|
||||||
|
|
||||||
/* multiply the mode clock and horizontal timings for MSO */
|
/* multiply the mode clock and horizontal timings for MSO */
|
||||||
|
list_for_each_entry(fixed_mode, &intel_connector->panel.fixed_modes, head)
|
||||||
intel_edp_mso_mode_fixup(intel_connector, fixed_mode);
|
intel_edp_mso_mode_fixup(intel_connector, fixed_mode);
|
||||||
intel_edp_mso_mode_fixup(intel_connector, downclock_mode);
|
|
||||||
|
|
||||||
/* fallback to VBT if available for eDP */
|
/* fallback to VBT if available for eDP */
|
||||||
if (!fixed_mode)
|
if (!intel_panel_preferred_fixed_mode(intel_connector))
|
||||||
fixed_mode = intel_panel_vbt_lfp_fixed_mode(intel_connector);
|
intel_panel_add_vbt_lfp_fixed_mode(intel_connector);
|
||||||
|
|
||||||
mutex_unlock(&dev->mode_config.mutex);
|
mutex_unlock(&dev->mode_config.mutex);
|
||||||
|
|
||||||
if (IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv)) {
|
if (IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv)) {
|
||||||
|
@ -5108,7 +5109,8 @@ static bool intel_edp_init_connector(struct intel_dp *intel_dp,
|
||||||
pipe_name(pipe));
|
pipe_name(pipe));
|
||||||
}
|
}
|
||||||
|
|
||||||
intel_panel_init(intel_connector, fixed_mode, downclock_mode);
|
intel_panel_init(intel_connector);
|
||||||
|
|
||||||
if (!(dev_priv->quirks & QUIRK_NO_PPS_BACKLIGHT_POWER_HOOK))
|
if (!(dev_priv->quirks & QUIRK_NO_PPS_BACKLIGHT_POWER_HOOK))
|
||||||
intel_connector->panel.backlight.power = intel_pps_backlight_power;
|
intel_connector->panel.backlight.power = intel_pps_backlight_power;
|
||||||
intel_backlight_setup(intel_connector, pipe);
|
intel_backlight_setup(intel_connector, pipe);
|
||||||
|
|
|
@ -358,7 +358,6 @@ void intel_crtc_drrs_init(struct intel_crtc *crtc)
|
||||||
/**
|
/**
|
||||||
* intel_drrs_init - Init DRRS for eDP connector
|
* intel_drrs_init - Init DRRS for eDP connector
|
||||||
* @connector: eDP connector
|
* @connector: eDP connector
|
||||||
* @fixed_mode: preferred mode of panel
|
|
||||||
*
|
*
|
||||||
* This function is called only once at driver load to initialize
|
* This function is called only once at driver load to initialize
|
||||||
* DRRS support for the connector.
|
* DRRS support for the connector.
|
||||||
|
@ -368,25 +367,14 @@ void intel_crtc_drrs_init(struct intel_crtc *crtc)
|
||||||
* DRRS support is determined by the presence of downclock mode (apart
|
* DRRS support is determined by the presence of downclock mode (apart
|
||||||
* from VBT setting).
|
* from VBT setting).
|
||||||
*/
|
*/
|
||||||
struct drm_display_mode *
|
void intel_drrs_init(struct intel_connector *connector)
|
||||||
intel_drrs_init(struct intel_connector *connector,
|
|
||||||
const struct drm_display_mode *fixed_mode)
|
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
|
struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
|
||||||
struct drm_display_mode *downclock_mode;
|
|
||||||
|
|
||||||
downclock_mode = intel_panel_edid_downclock_mode(connector, fixed_mode);
|
intel_panel_add_edid_downclock_mode(connector);
|
||||||
if (!downclock_mode) {
|
|
||||||
drm_dbg_kms(&dev_priv->drm,
|
|
||||||
"[CONNECTOR:%d:%s] DRRS not supported due to lack of downclock mode\n",
|
|
||||||
connector->base.base.id, connector->base.name);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
drm_dbg_kms(&dev_priv->drm,
|
drm_dbg_kms(&dev_priv->drm,
|
||||||
"[CONNECTOR:%d:%s] %s DRRS supported\n",
|
"[CONNECTOR:%d:%s] DRRS type: %s\n",
|
||||||
connector->base.base.id, connector->base.name,
|
connector->base.base.id, connector->base.name,
|
||||||
intel_drrs_type_str(dev_priv->vbt.drrs_type));
|
intel_drrs_type_str(intel_panel_drrs_type(connector)));
|
||||||
|
|
||||||
return downclock_mode;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,7 +27,6 @@ void intel_drrs_compute_config(struct intel_connector *connector,
|
||||||
struct intel_crtc_state *pipe_config,
|
struct intel_crtc_state *pipe_config,
|
||||||
int output_bpp, bool constant_n);
|
int output_bpp, bool constant_n);
|
||||||
void intel_crtc_drrs_init(struct intel_crtc *crtc);
|
void intel_crtc_drrs_init(struct intel_crtc *crtc);
|
||||||
struct drm_display_mode *intel_drrs_init(struct intel_connector *connector,
|
void intel_drrs_init(struct intel_connector *connector);
|
||||||
const struct drm_display_mode *fixed_mode);
|
|
||||||
|
|
||||||
#endif /* __INTEL_DRRS_H__ */
|
#endif /* __INTEL_DRRS_H__ */
|
||||||
|
|
|
@ -520,8 +520,6 @@ void intel_dvo_init(struct drm_i915_private *dev_priv)
|
||||||
|
|
||||||
intel_connector_attach_encoder(intel_connector, intel_encoder);
|
intel_connector_attach_encoder(intel_connector, intel_encoder);
|
||||||
if (dvo->type == INTEL_DVO_CHIP_LVDS) {
|
if (dvo->type == INTEL_DVO_CHIP_LVDS) {
|
||||||
struct drm_display_mode *fixed_mode;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* For our LVDS chipsets, we should hopefully be able
|
* For our LVDS chipsets, we should hopefully be able
|
||||||
* to dig the fixed panel mode out of the BIOS data.
|
* to dig the fixed panel mode out of the BIOS data.
|
||||||
|
@ -530,10 +528,11 @@ void intel_dvo_init(struct drm_i915_private *dev_priv)
|
||||||
* headers, likely), so for now, just get the current
|
* headers, likely), so for now, just get the current
|
||||||
* mode being output through DVO.
|
* mode being output through DVO.
|
||||||
*/
|
*/
|
||||||
fixed_mode = intel_panel_encoder_fixed_mode(intel_connector,
|
intel_panel_add_encoder_fixed_mode(intel_connector,
|
||||||
intel_encoder);
|
intel_encoder);
|
||||||
|
|
||||||
intel_panel_init(intel_connector, fixed_mode, NULL);
|
intel_panel_init(intel_connector);
|
||||||
|
|
||||||
intel_dvo->panel_wants_dither = true;
|
intel_dvo->panel_wants_dither = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -829,8 +829,6 @@ void intel_lvds_init(struct drm_i915_private *dev_priv)
|
||||||
struct intel_connector *intel_connector;
|
struct intel_connector *intel_connector;
|
||||||
struct drm_connector *connector;
|
struct drm_connector *connector;
|
||||||
struct drm_encoder *encoder;
|
struct drm_encoder *encoder;
|
||||||
struct drm_display_mode *fixed_mode = NULL;
|
|
||||||
struct drm_display_mode *downclock_mode = NULL;
|
|
||||||
struct edid *edid;
|
struct edid *edid;
|
||||||
i915_reg_t lvds_reg;
|
i915_reg_t lvds_reg;
|
||||||
u32 lvds;
|
u32 lvds;
|
||||||
|
@ -969,30 +967,29 @@ void intel_lvds_init(struct drm_i915_private *dev_priv)
|
||||||
}
|
}
|
||||||
intel_connector->edid = edid;
|
intel_connector->edid = edid;
|
||||||
|
|
||||||
fixed_mode = intel_panel_edid_fixed_mode(intel_connector);
|
/* Try EDID first */
|
||||||
if (fixed_mode)
|
intel_panel_add_edid_fixed_mode(intel_connector);
|
||||||
goto out;
|
|
||||||
|
|
||||||
/* Failed to get EDID, what about VBT? */
|
/* Failed to get EDID, what about VBT? */
|
||||||
fixed_mode = intel_panel_vbt_lfp_fixed_mode(intel_connector);
|
if (!intel_panel_preferred_fixed_mode(intel_connector))
|
||||||
if (fixed_mode)
|
intel_panel_add_vbt_lfp_fixed_mode(intel_connector);
|
||||||
goto out;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If we didn't get EDID, try checking if the panel is already turned
|
* If we didn't get a fixed mode from EDID or VBT, try checking
|
||||||
* on. If so, assume that whatever is currently programmed is the
|
* if the panel is already turned on. If so, assume that
|
||||||
* correct mode.
|
* whatever is currently programmed is the correct mode.
|
||||||
*/
|
*/
|
||||||
fixed_mode = intel_panel_encoder_fixed_mode(intel_connector, intel_encoder);
|
if (!intel_panel_preferred_fixed_mode(intel_connector))
|
||||||
|
intel_panel_add_encoder_fixed_mode(intel_connector, intel_encoder);
|
||||||
|
|
||||||
/* If we still don't have a mode after all that, give up. */
|
|
||||||
if (!fixed_mode)
|
|
||||||
goto failed;
|
|
||||||
|
|
||||||
out:
|
|
||||||
mutex_unlock(&dev->mode_config.mutex);
|
mutex_unlock(&dev->mode_config.mutex);
|
||||||
|
|
||||||
intel_panel_init(intel_connector, fixed_mode, downclock_mode);
|
/* If we still don't have a mode after all that, give up. */
|
||||||
|
if (!intel_panel_preferred_fixed_mode(intel_connector))
|
||||||
|
goto failed;
|
||||||
|
|
||||||
|
intel_panel_init(intel_connector);
|
||||||
|
|
||||||
intel_backlight_setup(intel_connector, INVALID_PIPE);
|
intel_backlight_setup(intel_connector, INVALID_PIPE);
|
||||||
|
|
||||||
lvds_encoder->is_dual_link = compute_is_dual_link_lvds(lvds_encoder);
|
lvds_encoder->is_dual_link = compute_is_dual_link_lvds(lvds_encoder);
|
||||||
|
@ -1004,8 +1001,6 @@ void intel_lvds_init(struct drm_i915_private *dev_priv)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
failed:
|
failed:
|
||||||
mutex_unlock(&dev->mode_config.mutex);
|
|
||||||
|
|
||||||
drm_dbg_kms(&dev_priv->drm, "No LVDS modes found, disabling.\n");
|
drm_dbg_kms(&dev_priv->drm, "No LVDS modes found, disabling.\n");
|
||||||
drm_connector_cleanup(connector);
|
drm_connector_cleanup(connector);
|
||||||
drm_encoder_cleanup(encoder);
|
drm_encoder_cleanup(encoder);
|
||||||
|
|
|
@ -158,11 +158,11 @@ static bool is_downclock_mode(const struct drm_display_mode *downclock_mode,
|
||||||
downclock_mode->clock < fixed_mode->clock;
|
downclock_mode->clock < fixed_mode->clock;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct drm_display_mode *
|
void intel_panel_add_edid_downclock_mode(struct intel_connector *connector)
|
||||||
intel_panel_edid_downclock_mode(struct intel_connector *connector,
|
|
||||||
const struct drm_display_mode *fixed_mode)
|
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
|
struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
|
||||||
|
const struct drm_display_mode *fixed_mode =
|
||||||
|
intel_panel_preferred_fixed_mode(connector);
|
||||||
const struct drm_display_mode *scan, *best_mode = NULL;
|
const struct drm_display_mode *scan, *best_mode = NULL;
|
||||||
struct drm_display_mode *downclock_mode;
|
struct drm_display_mode *downclock_mode;
|
||||||
int best_clock = fixed_mode->clock;
|
int best_clock = fixed_mode->clock;
|
||||||
|
@ -187,29 +187,28 @@ intel_panel_edid_downclock_mode(struct intel_connector *connector,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!best_mode)
|
if (!best_mode)
|
||||||
return NULL;
|
return;
|
||||||
|
|
||||||
downclock_mode = drm_mode_duplicate(&dev_priv->drm, best_mode);
|
downclock_mode = drm_mode_duplicate(&dev_priv->drm, best_mode);
|
||||||
if (!downclock_mode)
|
if (!downclock_mode)
|
||||||
return NULL;
|
return;
|
||||||
|
|
||||||
drm_dbg_kms(&dev_priv->drm,
|
drm_dbg_kms(&dev_priv->drm,
|
||||||
"[CONNECTOR:%d:%s] using downclock mode from EDID: " DRM_MODE_FMT "\n",
|
"[CONNECTOR:%d:%s] using downclock mode from EDID: " DRM_MODE_FMT "\n",
|
||||||
connector->base.base.id, connector->base.name,
|
connector->base.base.id, connector->base.name,
|
||||||
DRM_MODE_ARG(downclock_mode));
|
DRM_MODE_ARG(downclock_mode));
|
||||||
|
|
||||||
return downclock_mode;
|
list_add_tail(&downclock_mode->head, &connector->panel.fixed_modes);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct drm_display_mode *
|
void intel_panel_add_edid_fixed_mode(struct intel_connector *connector)
|
||||||
intel_panel_edid_fixed_mode(struct intel_connector *connector)
|
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
|
struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
|
||||||
const struct drm_display_mode *scan;
|
const struct drm_display_mode *scan;
|
||||||
struct drm_display_mode *fixed_mode;
|
struct drm_display_mode *fixed_mode;
|
||||||
|
|
||||||
if (list_empty(&connector->base.probed_modes))
|
if (list_empty(&connector->base.probed_modes))
|
||||||
return NULL;
|
return;
|
||||||
|
|
||||||
/* prefer fixed mode from EDID if available */
|
/* prefer fixed mode from EDID if available */
|
||||||
list_for_each_entry(scan, &connector->base.probed_modes, head) {
|
list_for_each_entry(scan, &connector->base.probed_modes, head) {
|
||||||
|
@ -218,47 +217,45 @@ intel_panel_edid_fixed_mode(struct intel_connector *connector)
|
||||||
|
|
||||||
fixed_mode = drm_mode_duplicate(&dev_priv->drm, scan);
|
fixed_mode = drm_mode_duplicate(&dev_priv->drm, scan);
|
||||||
if (!fixed_mode)
|
if (!fixed_mode)
|
||||||
return NULL;
|
return;
|
||||||
|
|
||||||
drm_dbg_kms(&dev_priv->drm,
|
drm_dbg_kms(&dev_priv->drm,
|
||||||
"[CONNECTOR:%d:%s] using preferred mode from EDID: " DRM_MODE_FMT "\n",
|
"[CONNECTOR:%d:%s] using preferred mode from EDID: " DRM_MODE_FMT "\n",
|
||||||
connector->base.base.id, connector->base.name,
|
connector->base.base.id, connector->base.name,
|
||||||
DRM_MODE_ARG(fixed_mode));
|
DRM_MODE_ARG(fixed_mode));
|
||||||
|
|
||||||
return fixed_mode;
|
list_add_tail(&fixed_mode->head, &connector->panel.fixed_modes);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
scan = list_first_entry(&connector->base.probed_modes,
|
scan = list_first_entry(&connector->base.probed_modes,
|
||||||
typeof(*scan), head);
|
typeof(*scan), head);
|
||||||
|
|
||||||
fixed_mode = drm_mode_duplicate(&dev_priv->drm, scan);
|
fixed_mode = drm_mode_duplicate(&dev_priv->drm, scan);
|
||||||
if (!fixed_mode)
|
if (!fixed_mode)
|
||||||
return NULL;
|
return;
|
||||||
|
|
||||||
fixed_mode->type |= DRM_MODE_TYPE_PREFERRED;
|
fixed_mode->type |= DRM_MODE_TYPE_PREFERRED;
|
||||||
|
|
||||||
drm_dbg_kms(&dev_priv->drm,
|
drm_dbg_kms(&dev_priv->drm,
|
||||||
"[CONNECTOR:%d:%s] using first mode from EDID: " DRM_MODE_FMT "\n",
|
"[CONNECTOR:%d:%s] using first mode from EDID: " DRM_MODE_FMT "\n",
|
||||||
connector->base.base.id, connector->base.name,
|
connector->base.base.id, connector->base.name,
|
||||||
DRM_MODE_ARG(fixed_mode));
|
DRM_MODE_ARG(fixed_mode));
|
||||||
|
|
||||||
return fixed_mode;
|
list_add_tail(&fixed_mode->head, &connector->panel.fixed_modes);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct drm_display_mode *
|
void intel_panel_add_vbt_lfp_fixed_mode(struct intel_connector *connector)
|
||||||
intel_panel_vbt_lfp_fixed_mode(struct intel_connector *connector)
|
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
|
struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
|
||||||
struct drm_display_info *info = &connector->base.display_info;
|
struct drm_display_info *info = &connector->base.display_info;
|
||||||
struct drm_display_mode *fixed_mode;
|
struct drm_display_mode *fixed_mode;
|
||||||
|
|
||||||
if (!dev_priv->vbt.lfp_lvds_vbt_mode)
|
if (!dev_priv->vbt.lfp_lvds_vbt_mode)
|
||||||
return NULL;
|
return;
|
||||||
|
|
||||||
fixed_mode = drm_mode_duplicate(&dev_priv->drm,
|
fixed_mode = drm_mode_duplicate(&dev_priv->drm,
|
||||||
dev_priv->vbt.lfp_lvds_vbt_mode);
|
dev_priv->vbt.lfp_lvds_vbt_mode);
|
||||||
if (!fixed_mode)
|
if (!fixed_mode)
|
||||||
return NULL;
|
return;
|
||||||
|
|
||||||
fixed_mode->type |= DRM_MODE_TYPE_PREFERRED;
|
fixed_mode->type |= DRM_MODE_TYPE_PREFERRED;
|
||||||
|
|
||||||
|
@ -269,31 +266,29 @@ intel_panel_vbt_lfp_fixed_mode(struct intel_connector *connector)
|
||||||
info->width_mm = fixed_mode->width_mm;
|
info->width_mm = fixed_mode->width_mm;
|
||||||
info->height_mm = fixed_mode->height_mm;
|
info->height_mm = fixed_mode->height_mm;
|
||||||
|
|
||||||
return fixed_mode;
|
list_add_tail(&fixed_mode->head, &connector->panel.fixed_modes);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct drm_display_mode *
|
void intel_panel_add_vbt_sdvo_fixed_mode(struct intel_connector *connector)
|
||||||
intel_panel_vbt_sdvo_fixed_mode(struct intel_connector *connector)
|
|
||||||
{
|
{
|
||||||
struct drm_i915_private *i915 = to_i915(connector->base.dev);
|
struct drm_i915_private *i915 = to_i915(connector->base.dev);
|
||||||
struct drm_display_mode *fixed_mode;
|
struct drm_display_mode *fixed_mode;
|
||||||
|
|
||||||
if (!i915->vbt.sdvo_lvds_vbt_mode)
|
if (!i915->vbt.sdvo_lvds_vbt_mode)
|
||||||
return NULL;
|
return;
|
||||||
|
|
||||||
fixed_mode = drm_mode_duplicate(&i915->drm,
|
fixed_mode = drm_mode_duplicate(&i915->drm,
|
||||||
i915->vbt.sdvo_lvds_vbt_mode);
|
i915->vbt.sdvo_lvds_vbt_mode);
|
||||||
if (!fixed_mode)
|
if (!fixed_mode)
|
||||||
return NULL;
|
return;
|
||||||
|
|
||||||
/* Guarantee the mode is preferred */
|
/* Guarantee the mode is preferred */
|
||||||
fixed_mode->type = DRM_MODE_TYPE_PREFERRED | DRM_MODE_TYPE_DRIVER;
|
fixed_mode->type = DRM_MODE_TYPE_PREFERRED | DRM_MODE_TYPE_DRIVER;
|
||||||
|
|
||||||
return fixed_mode;
|
list_add_tail(&fixed_mode->head, &connector->panel.fixed_modes);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct drm_display_mode *
|
void intel_panel_add_encoder_fixed_mode(struct intel_connector *connector,
|
||||||
intel_panel_encoder_fixed_mode(struct intel_connector *connector,
|
|
||||||
struct intel_encoder *encoder)
|
struct intel_encoder *encoder)
|
||||||
{
|
{
|
||||||
struct drm_i915_private *i915 = to_i915(connector->base.dev);
|
struct drm_i915_private *i915 = to_i915(connector->base.dev);
|
||||||
|
@ -301,7 +296,7 @@ intel_panel_encoder_fixed_mode(struct intel_connector *connector,
|
||||||
|
|
||||||
fixed_mode = intel_encoder_current_mode(encoder);
|
fixed_mode = intel_encoder_current_mode(encoder);
|
||||||
if (!fixed_mode)
|
if (!fixed_mode)
|
||||||
return NULL;
|
return;
|
||||||
|
|
||||||
drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] using current (BIOS) mode: " DRM_MODE_FMT "\n",
|
drm_dbg_kms(&i915->drm, "[CONNECTOR:%d:%s] using current (BIOS) mode: " DRM_MODE_FMT "\n",
|
||||||
connector->base.base.id, connector->base.name,
|
connector->base.base.id, connector->base.name,
|
||||||
|
@ -309,7 +304,7 @@ intel_panel_encoder_fixed_mode(struct intel_connector *connector,
|
||||||
|
|
||||||
fixed_mode->type |= DRM_MODE_TYPE_PREFERRED;
|
fixed_mode->type |= DRM_MODE_TYPE_PREFERRED;
|
||||||
|
|
||||||
return fixed_mode;
|
list_add_tail(&fixed_mode->head, &connector->panel.fixed_modes);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* adjusted_mode has been preset to be the panel's fixed mode */
|
/* adjusted_mode has been preset to be the panel's fixed mode */
|
||||||
|
@ -639,19 +634,12 @@ intel_panel_mode_valid(struct intel_connector *connector,
|
||||||
return MODE_OK;
|
return MODE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
int intel_panel_init(struct intel_connector *connector,
|
int intel_panel_init(struct intel_connector *connector)
|
||||||
struct drm_display_mode *fixed_mode,
|
|
||||||
struct drm_display_mode *downclock_mode)
|
|
||||||
{
|
{
|
||||||
struct intel_panel *panel = &connector->panel;
|
struct intel_panel *panel = &connector->panel;
|
||||||
|
|
||||||
intel_backlight_init_funcs(panel);
|
intel_backlight_init_funcs(panel);
|
||||||
|
|
||||||
if (fixed_mode)
|
|
||||||
list_add_tail(&fixed_mode->head, &panel->fixed_modes);
|
|
||||||
if (downclock_mode)
|
|
||||||
list_add_tail(&downclock_mode->head, &panel->fixed_modes);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,9 +18,7 @@ struct intel_connector;
|
||||||
struct intel_crtc_state;
|
struct intel_crtc_state;
|
||||||
struct intel_encoder;
|
struct intel_encoder;
|
||||||
|
|
||||||
int intel_panel_init(struct intel_connector *connector,
|
int intel_panel_init(struct intel_connector *connector);
|
||||||
struct drm_display_mode *fixed_mode,
|
|
||||||
struct drm_display_mode *downclock_mode);
|
|
||||||
void intel_panel_fini(struct intel_connector *connector);
|
void intel_panel_fini(struct intel_connector *connector);
|
||||||
enum drm_connector_status
|
enum drm_connector_status
|
||||||
intel_panel_detect(struct drm_connector *connector, bool force);
|
intel_panel_detect(struct drm_connector *connector, bool force);
|
||||||
|
@ -42,17 +40,11 @@ int intel_panel_fitting(struct intel_crtc_state *crtc_state,
|
||||||
const struct drm_connector_state *conn_state);
|
const struct drm_connector_state *conn_state);
|
||||||
int intel_panel_compute_config(struct intel_connector *connector,
|
int intel_panel_compute_config(struct intel_connector *connector,
|
||||||
struct drm_display_mode *adjusted_mode);
|
struct drm_display_mode *adjusted_mode);
|
||||||
struct drm_display_mode *
|
void intel_panel_add_edid_fixed_mode(struct intel_connector *connector);
|
||||||
intel_panel_edid_downclock_mode(struct intel_connector *connector,
|
void intel_panel_add_edid_downclock_mode(struct intel_connector *connector);
|
||||||
const struct drm_display_mode *fixed_mode);
|
void intel_panel_add_vbt_lfp_fixed_mode(struct intel_connector *connector);
|
||||||
struct drm_display_mode *
|
void intel_panel_add_vbt_sdvo_fixed_mode(struct intel_connector *connector);
|
||||||
intel_panel_edid_fixed_mode(struct intel_connector *connector);
|
void intel_panel_add_encoder_fixed_mode(struct intel_connector *connector,
|
||||||
struct drm_display_mode *
|
|
||||||
intel_panel_vbt_lfp_fixed_mode(struct intel_connector *connector);
|
|
||||||
struct drm_display_mode *
|
|
||||||
intel_panel_vbt_sdvo_fixed_mode(struct intel_connector *connector);
|
|
||||||
struct drm_display_mode *
|
|
||||||
intel_panel_encoder_fixed_mode(struct intel_connector *connector,
|
|
||||||
struct intel_encoder *encoder);
|
struct intel_encoder *encoder);
|
||||||
|
|
||||||
#endif /* __INTEL_PANEL_H__ */
|
#endif /* __INTEL_PANEL_H__ */
|
||||||
|
|
|
@ -2871,7 +2871,6 @@ intel_sdvo_lvds_init(struct intel_sdvo *intel_sdvo, int device)
|
||||||
struct drm_connector *connector;
|
struct drm_connector *connector;
|
||||||
struct intel_connector *intel_connector;
|
struct intel_connector *intel_connector;
|
||||||
struct intel_sdvo_connector *intel_sdvo_connector;
|
struct intel_sdvo_connector *intel_sdvo_connector;
|
||||||
struct drm_display_mode *fixed_mode;
|
|
||||||
|
|
||||||
DRM_DEBUG_KMS("initialising LVDS device %d\n", device);
|
DRM_DEBUG_KMS("initialising LVDS device %d\n", device);
|
||||||
|
|
||||||
|
@ -2904,13 +2903,14 @@ intel_sdvo_lvds_init(struct intel_sdvo *intel_sdvo, int device)
|
||||||
* Fetch modes from VBT. For SDVO prefer the VBT mode since some
|
* Fetch modes from VBT. For SDVO prefer the VBT mode since some
|
||||||
* SDVO->LVDS transcoders can't cope with the EDID mode.
|
* SDVO->LVDS transcoders can't cope with the EDID mode.
|
||||||
*/
|
*/
|
||||||
fixed_mode = intel_panel_vbt_sdvo_fixed_mode(intel_connector);
|
intel_panel_add_vbt_sdvo_fixed_mode(intel_connector);
|
||||||
if (!fixed_mode) {
|
|
||||||
|
if (!intel_panel_preferred_fixed_mode(intel_connector)) {
|
||||||
intel_ddc_get_modes(connector, &intel_sdvo->ddc);
|
intel_ddc_get_modes(connector, &intel_sdvo->ddc);
|
||||||
fixed_mode = intel_panel_edid_fixed_mode(intel_connector);
|
intel_panel_add_edid_fixed_mode(intel_connector);
|
||||||
}
|
}
|
||||||
|
|
||||||
intel_panel_init(intel_connector, fixed_mode, NULL);
|
intel_panel_init(intel_connector);
|
||||||
|
|
||||||
if (!intel_panel_preferred_fixed_mode(intel_connector))
|
if (!intel_panel_preferred_fixed_mode(intel_connector))
|
||||||
goto err;
|
goto err;
|
||||||
|
|
|
@ -1859,7 +1859,7 @@ void vlv_dsi_init(struct drm_i915_private *dev_priv)
|
||||||
struct drm_encoder *encoder;
|
struct drm_encoder *encoder;
|
||||||
struct intel_connector *intel_connector;
|
struct intel_connector *intel_connector;
|
||||||
struct drm_connector *connector;
|
struct drm_connector *connector;
|
||||||
struct drm_display_mode *current_mode, *fixed_mode;
|
struct drm_display_mode *current_mode;
|
||||||
enum port port;
|
enum port port;
|
||||||
enum pipe pipe;
|
enum pipe pipe;
|
||||||
|
|
||||||
|
@ -1980,15 +1980,16 @@ void vlv_dsi_init(struct drm_i915_private *dev_priv)
|
||||||
intel_connector_attach_encoder(intel_connector, intel_encoder);
|
intel_connector_attach_encoder(intel_connector, intel_encoder);
|
||||||
|
|
||||||
mutex_lock(&dev->mode_config.mutex);
|
mutex_lock(&dev->mode_config.mutex);
|
||||||
fixed_mode = intel_panel_vbt_lfp_fixed_mode(intel_connector);
|
intel_panel_add_vbt_lfp_fixed_mode(intel_connector);
|
||||||
mutex_unlock(&dev->mode_config.mutex);
|
mutex_unlock(&dev->mode_config.mutex);
|
||||||
|
|
||||||
if (!fixed_mode) {
|
if (!intel_panel_preferred_fixed_mode(intel_connector)) {
|
||||||
drm_dbg_kms(&dev_priv->drm, "no fixed mode\n");
|
drm_dbg_kms(&dev_priv->drm, "no fixed mode\n");
|
||||||
goto err_cleanup_connector;
|
goto err_cleanup_connector;
|
||||||
}
|
}
|
||||||
|
|
||||||
intel_panel_init(intel_connector, fixed_mode, NULL);
|
intel_panel_init(intel_connector);
|
||||||
|
|
||||||
intel_backlight_setup(intel_connector, INVALID_PIPE);
|
intel_backlight_setup(intel_connector, INVALID_PIPE);
|
||||||
|
|
||||||
vlv_dsi_add_properties(intel_connector);
|
vlv_dsi_add_properties(intel_connector);
|
||||||
|
|
Loading…
Reference in a new issue