]> git.ipfire.org Git - thirdparty/kernel/linux.git/commit
drm/amd/display: fix wrong color value mapping on MCM shaper LUT
authorMelissa Wen <mwen@igalia.com>
Thu, 22 Jan 2026 15:20:29 +0000 (12:20 -0300)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 3 Feb 2026 22:21:43 +0000 (17:21 -0500)
commit8f959d37c1f2efec6dac55915ee82302e98101fb
tree6ad934c07c68c34a2d69ad8d8ad856e288266451
parent243b467dea1735fed904c2e54d248a46fa417a2d
drm/amd/display: fix wrong color value mapping on MCM shaper LUT

Some shimmer/colorful points appears when using the steamOS color
pipeline for HDR on gaming with DCN32. These points look like black
values being wrongly mapped to red/blue/green values. It was caused
because the number of hw points in regular LUTs and in a shaper LUT was
treated as the same.

DCN3+ regular LUTs have 257 bases and implicit deltas (i.e. HW
calculates them), but shaper LUT is a special case: it has 256 bases and
256 deltas, as in DCN1-2 regular LUTs, and outputs 14-bit values.

Fix that by setting by decreasing in 1 the number of HW points computed
in the LUT segmentation so that shaper LUT (i.e. fixpoint == true) keeps
the same DCN10 CM logic and regular LUTs go with `hw_points + 1`.

CC: Krunoslav Kovac <Krunoslav.Kovac@amd.com>
Fixes: 4d5fd3d08ea9 ("drm/amd/display: PQ tail accuracy")
Signed-off-by: Melissa Wen <mwen@igalia.com>
Reviewed-by: Alex Hung <alex.hung@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
(cherry picked from commit 5006505b19a2119e71c008044d59f6d753c858b9)
drivers/gpu/drm/amd/display/dc/dcn30/dcn30_cm_common.c