mirror of
https://github.com/torvalds/linux.git
synced 2025-11-04 18:49:34 +02:00
drm/i915/backlight: Use drm helper to initialize edp backlight
Now that drm_edp_backlight init has been modified to take into account the setup of lumininace based brightness manipulation we can just use that. --v2 -Fix commit message [Arun] Signed-off-by: Suraj Kandpal <suraj.kandpal@intel.com> Reviewed-by: Arun R Murthy <arun.r.murthy@intel.com> Link: https://lore.kernel.org/r/20250620063445.3603086-12-suraj.kandpal@intel.com
This commit is contained in:
parent
ba02bf8e86
commit
e13af5166a
1 changed files with 49 additions and 51 deletions
|
|
@ -584,20 +584,6 @@ static int intel_dp_aux_vesa_setup_backlight(struct intel_connector *connector,
|
||||||
u8 current_mode;
|
u8 current_mode;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (panel->backlight.edp.vesa.luminance_control_support) {
|
|
||||||
if (luminance_range->max_luminance) {
|
|
||||||
panel->backlight.max = luminance_range->max_luminance;
|
|
||||||
panel->backlight.min = luminance_range->min_luminance;
|
|
||||||
} else {
|
|
||||||
panel->backlight.max = 512;
|
|
||||||
panel->backlight.min = 0;
|
|
||||||
}
|
|
||||||
panel->backlight.level = intel_dp_aux_vesa_get_backlight(connector, 0);
|
|
||||||
panel->backlight.enabled = panel->backlight.level != 0;
|
|
||||||
drm_dbg_kms(display->drm,
|
|
||||||
"[CONNECTOR:%d:%s] AUX VESA Nits backlight level is controlled through DPCD\n",
|
|
||||||
connector->base.base.id, connector->base.name);
|
|
||||||
} else {
|
|
||||||
ret = drm_edp_backlight_init(&intel_dp->aux, &panel->backlight.edp.vesa.info,
|
ret = drm_edp_backlight_init(&intel_dp->aux, &panel->backlight.edp.vesa.info,
|
||||||
luminance_range->max_luminance,
|
luminance_range->max_luminance,
|
||||||
panel->vbt.backlight.pwm_freq_hz,
|
panel->vbt.backlight.pwm_freq_hz,
|
||||||
|
|
@ -626,7 +612,20 @@ static int intel_dp_aux_vesa_setup_backlight(struct intel_connector *connector,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (panel->backlight.edp.vesa.info.aux_set) {
|
if (panel->backlight.edp.vesa.info.luminance_set) {
|
||||||
|
if (luminance_range->max_luminance) {
|
||||||
|
panel->backlight.max = panel->backlight.edp.vesa.info.max;
|
||||||
|
panel->backlight.min = luminance_range->min_luminance;
|
||||||
|
} else {
|
||||||
|
panel->backlight.max = 512;
|
||||||
|
panel->backlight.min = 0;
|
||||||
|
}
|
||||||
|
panel->backlight.level = intel_dp_aux_vesa_get_backlight(connector, 0);
|
||||||
|
panel->backlight.enabled = panel->backlight.level != 0;
|
||||||
|
drm_dbg_kms(display->drm,
|
||||||
|
"[CONNECTOR:%d:%s] AUX VESA Nits backlight level is controlled through DPCD\n",
|
||||||
|
connector->base.base.id, connector->base.name);
|
||||||
|
} else if (panel->backlight.edp.vesa.info.aux_set) {
|
||||||
panel->backlight.max = panel->backlight.edp.vesa.info.max;
|
panel->backlight.max = panel->backlight.edp.vesa.info.max;
|
||||||
panel->backlight.min = 0;
|
panel->backlight.min = 0;
|
||||||
if (current_mode == DP_EDP_BACKLIGHT_CONTROL_MODE_DPCD) {
|
if (current_mode == DP_EDP_BACKLIGHT_CONTROL_MODE_DPCD) {
|
||||||
|
|
@ -648,7 +647,6 @@ static int intel_dp_aux_vesa_setup_backlight(struct intel_connector *connector,
|
||||||
panel->backlight.enabled = false;
|
panel->backlight.enabled = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
drm_dbg_kms(display->drm,
|
drm_dbg_kms(display->drm,
|
||||||
"[CONNECTOR:%d:%s] Using AUX VESA interface for backlight control\n",
|
"[CONNECTOR:%d:%s] Using AUX VESA interface for backlight control\n",
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue