This is a note to let you know that I've just added the patch titled drm/amd/display: Use freesync when `DRM_EDID_FEATURE_CONTINUOUS_FREQ` found to the 6.8-stable tree which can be found at: http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary The filename of the patch is: drm-amd-display-use-freesync-when-drm_edid_feature_continuous_freq-found.patch and it can be found in the queue-6.8 subdirectory. If you, or anyone else, feels it should not be added to the stable tree, please let <stable@xxxxxxxxxxxxxxx> know about it. >From 2f14c0c8cae8e9e3b603a3f91909baba66540027 Mon Sep 17 00:00:00 2001 From: Mario Limonciello <mario.limonciello@xxxxxxx> Date: Tue, 5 Mar 2024 14:34:24 -0600 Subject: drm/amd/display: Use freesync when `DRM_EDID_FEATURE_CONTINUOUS_FREQ` found From: Mario Limonciello <mario.limonciello@xxxxxxx> commit 2f14c0c8cae8e9e3b603a3f91909baba66540027 upstream. The monitor shipped with the Framework 16 supports VRR [1], but it's not being advertised. This is because the detailed timing block doesn't contain `EDID_DETAIL_MONITOR_RANGE` which amdgpu looks for to find min and max frequencies. This check however is superfluous for this case because update_display_info() calls drm_get_monitor_range() to get these ranges already. So if the `DRM_EDID_FEATURE_CONTINUOUS_FREQ` EDID feature is found then turn on freesync without extra checks. v2: squash in fix from Harry Closes: https://www.reddit.com/r/framework/comments/1b4y2i5/no_variable_refresh_rate_on_the_framework_16_on/ Closes: https://www.reddit.com/r/framework/comments/1b6vzcy/framework_16_variable_refresh_rate/ Closes: https://community.frame.work/t/resolved-no-vrr-freesync-with-amd-version/42338 Link: https://gist.github.com/superm1/e8fbacfa4d0f53150231d3a3e0a13faf Signed-off-by: Mario Limonciello <mario.limonciello@xxxxxxx> Reviewed-by: Harry Wentland <harry.wentland@xxxxxxx> Signed-off-by: Alex Deucher <alexander.deucher@xxxxxxx> Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx> --- drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) --- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c +++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c @@ -11140,18 +11140,24 @@ void amdgpu_dm_update_freesync_caps(stru if (!adev->dm.freesync_module) goto update; - if (sink->sink_signal == SIGNAL_TYPE_DISPLAY_PORT - || sink->sink_signal == SIGNAL_TYPE_EDP) { + if (edid && (sink->sink_signal == SIGNAL_TYPE_DISPLAY_PORT || + sink->sink_signal == SIGNAL_TYPE_EDP)) { bool edid_check_required = false; - if (edid) { - edid_check_required = is_dp_capable_without_timing_msa( - adev->dm.dc, - amdgpu_dm_connector); + if (is_dp_capable_without_timing_msa(adev->dm.dc, + amdgpu_dm_connector)) { + if (edid->features & DRM_EDID_FEATURE_CONTINUOUS_FREQ) { + freesync_capable = true; + amdgpu_dm_connector->min_vfreq = connector->display_info.monitor_range.min_vfreq; + amdgpu_dm_connector->max_vfreq = connector->display_info.monitor_range.max_vfreq; + } else { + edid_check_required = edid->version > 1 || + (edid->version == 1 && + edid->revision > 1); + } } - if (edid_check_required == true && (edid->version > 1 || - (edid->version == 1 && edid->revision > 1))) { + if (edid_check_required) { for (i = 0; i < 4; i++) { timing = &edid->detailed_timings[i]; Patches currently in stable-queue which might be from mario.limonciello@xxxxxxx are queue-6.8/drm-amd-display-lock-all-enabled-otg-pipes-even-with.patch queue-6.8/drm-amd-display-add-a-dc_state-null-check-in-dc_stat.patch queue-6.8/drm-amd-display-amend-coasting-vtotal-for-replay-low.patch queue-6.8/cpufreq-amd-pstate-fix-min_perf-assignment-in-amd_ps.patch queue-6.8/drm-amd-display-implement-wait_for_odm_update_pendin.patch queue-6.8/drm-amd-display-use-freesync-when-drm_edid_feature_continuous_freq-found.patch queue-6.8/drm-amd-display-change-default-size-for-dummy-plane-.patch queue-6.8/drm-amd-display-update-odm-when-odm-combine-is-chang.patch queue-6.8/drm-amd-display-revert-remove-pixle-rate-limit-for-s.patch queue-6.8/drm-amd-display-return-the-correct-hdcp-error-code.patch queue-6.8/drm-amd-display-fix-idle-check-for-shared-firmware-s.patch queue-6.8/drm-amd-display-fix-noise-issue-on-hdmi-av-mute.patch queue-6.8/drm-amd-display-allow-dirty-rects-to-be-sent-to-dmub.patch queue-6.8/drm-amd-display-override-min-required-dcfclk-in-dml1.patch queue-6.8/drm-amdgpu-display-address-kdoc-for-is_psr_su-in-fil.patch queue-6.8/drm-amd-display-init-dppclk-from-smu-on-dcn32.patch