drm/i915: Preserve crtc_state->inherited during state clearing
authorVille Syrjälä <ville.syrjala@linux.intel.com>
Thu, 23 Feb 2023 15:20:48 +0000 (17:20 +0200)
committerJani Nikula <jani.nikula@intel.com>
Mon, 20 Mar 2023 09:00:05 +0000 (11:00 +0200)
commit3a84f2c6c9558c554a90ec26ad25df92fc5e05b7
treea4faadfa978205a793d3e31d53bf73334bd3b924
parented00eba03474adbf525ff03d69705d8c78b76456
drm/i915: Preserve crtc_state->inherited during state clearing

intel_crtc_prepare_cleared_state() is unintentionally losing
the "inherited" flag. This will happen if intel_initial_commit()
is forced to go through the full modeset calculations for
whatever reason.

Afterwards the first real commit from userspace will not get
forced to the full modeset path, and thus eg. audio state may
not get recomputed properly. So if the monitor was already
enabled during boot audio will not work until userspace itself
does an explicit full modeset.

Cc: stable@vger.kernel.org
Tested-by: Lee Shawn C <shawn.c.lee@intel.com>
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230223152048.20878-1-ville.syrjala@linux.intel.com
Reviewed-by: Uma Shankar <uma.shankar@intel.com>
(cherry picked from commit 2553bacaf953b48c59357f5a622282bc0c45adae)
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
drivers/gpu/drm/i915/display/intel_display.c