Skip to content

Commit ad067e4

Browse files
Matt Redfearngregkh
authored andcommitted
drm/bridge: adv7511: Fix low refresh rate selection
[ Upstream commit 67793bd ] The driver currently sets register 0xfb (Low Refresh Rate) based on the value of mode->vrefresh. Firstly, this field is specified to be in Hz, but the magic numbers used by the code are Hz * 1000. This essentially leads to the low refresh rate always being set to 0x01, since the vrefresh value will always be less than 24000. Fix the magic numbers to be in Hz. Secondly, according to the comment in drm_modes.h, the field is not supposed to be used in a functional way anyway. Instead, use the helper function drm_mode_vrefresh(). Fixes: 9c8af88 ("drm: Add adv7511 encoder driver") Reviewed-by: Laurent Pinchart <[email protected]> Signed-off-by: Matt Redfearn <[email protected]> Signed-off-by: Sean Paul <[email protected]> Link: https://patchwork.freedesktop.org/patch/msgid/[email protected] Signed-off-by: Sasha Levin <[email protected]>
1 parent 35dd88b commit ad067e4

File tree

1 file changed

+3
-3
lines changed

1 file changed

+3
-3
lines changed

drivers/gpu/drm/bridge/adv7511/adv7511_drv.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -735,11 +735,11 @@ static void adv7511_mode_set(struct adv7511 *adv7511,
735735
vsync_polarity = 1;
736736
}
737737

738-
if (mode->vrefresh <= 24000)
738+
if (drm_mode_vrefresh(mode) <= 24)
739739
low_refresh_rate = ADV7511_LOW_REFRESH_RATE_24HZ;
740-
else if (mode->vrefresh <= 25000)
740+
else if (drm_mode_vrefresh(mode) <= 25)
741741
low_refresh_rate = ADV7511_LOW_REFRESH_RATE_25HZ;
742-
else if (mode->vrefresh <= 30000)
742+
else if (drm_mode_vrefresh(mode) <= 30)
743743
low_refresh_rate = ADV7511_LOW_REFRESH_RATE_30HZ;
744744
else
745745
low_refresh_rate = ADV7511_LOW_REFRESH_RATE_NONE;

0 commit comments

Comments
 (0)