Commit 5dff371a authored by Aric Cyr's avatar Aric Cyr Committed by Alex Deucher

drm/amd/display: FreeSync not active near lower bound of non-LFC monitor range

[Why]
On narrow range monitors without LFC, a margin prevents good utilization
of the available range.

[How]
Decrease the margin for exiting fixed mode and fix the frame counter to
reset if a non-consecutive render is found.
Signed-off-by: default avatarAric Cyr <aric.cyr@amd.com>
Reviewed-by: default avatarAnthony Koo <Anthony.Koo@amd.com>
Acked-by: default avatarEryk Brol <eryk.brol@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 9b42868c
...@@ -42,10 +42,10 @@ ...@@ -42,10 +42,10 @@
/* Threshold to change BTR multiplier (to avoid frequent changes) */ /* Threshold to change BTR multiplier (to avoid frequent changes) */
#define BTR_DRIFT_MARGIN 2000 #define BTR_DRIFT_MARGIN 2000
/* Threshold to exit fixed refresh rate */ /* Threshold to exit fixed refresh rate */
#define FIXED_REFRESH_EXIT_MARGIN_IN_HZ 4 #define FIXED_REFRESH_EXIT_MARGIN_IN_HZ 1
/* Number of consecutive frames to check before entering/exiting fixed refresh */ /* Number of consecutive frames to check before entering/exiting fixed refresh */
#define FIXED_REFRESH_ENTER_FRAME_COUNT 5 #define FIXED_REFRESH_ENTER_FRAME_COUNT 5
#define FIXED_REFRESH_EXIT_FRAME_COUNT 5 #define FIXED_REFRESH_EXIT_FRAME_COUNT 10
struct core_freesync { struct core_freesync {
struct mod_freesync public; struct mod_freesync public;
...@@ -420,7 +420,8 @@ static void apply_fixed_refresh(struct core_freesync *core_freesync, ...@@ -420,7 +420,8 @@ static void apply_fixed_refresh(struct core_freesync *core_freesync,
in_out_vrr->fixed.target_refresh_in_uhz = 0; in_out_vrr->fixed.target_refresh_in_uhz = 0;
update = true; update = true;
} }
} } else
in_out_vrr->fixed.frame_counter = 0;
} else if (last_render_time_in_us > max_render_time_in_us) { } else if (last_render_time_in_us > max_render_time_in_us) {
/* Enter Fixed Refresh mode */ /* Enter Fixed Refresh mode */
if (!in_out_vrr->fixed.fixed_active) { if (!in_out_vrr->fixed.fixed_active) {
...@@ -434,7 +435,8 @@ static void apply_fixed_refresh(struct core_freesync *core_freesync, ...@@ -434,7 +435,8 @@ static void apply_fixed_refresh(struct core_freesync *core_freesync,
in_out_vrr->max_refresh_in_uhz; in_out_vrr->max_refresh_in_uhz;
update = true; update = true;
} }
} } else
in_out_vrr->fixed.frame_counter = 0;
} }
if (update) { if (update) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment