drm/amd/display: Disable integerscaling for downscale and MPO
authorAidan Yang <Aidan.Yang@amd.com>
Wed, 20 Nov 2019 16:05:36 +0000 (11:05 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 18 Dec 2019 21:09:07 +0000 (16:09 -0500)
[Why]
Integer scaling is applied to MPO planes when downscaling,
MPO planes use variable taps and integer scaling sets taps=1

[How]
Disable integer scaling on MPO planes,
Disable integer scaling for downscaling planes

Signed-off-by: Aidan Yang <Aidan.Yang@amd.com>
Reviewed-by: Aric Cyr <Aric.Cyr@amd.com>
Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/core/dc_resource.c

index 6c6f5640234cae6065f4b6134799129e251702dc..39cc71bedf691c5b6d393ec365c7611cdc1b33e8 100644 (file)
@@ -940,11 +940,27 @@ static void calculate_inits_and_adj_vp(struct pipe_ctx *pipe_ctx)
 
 }
 
+static bool is_downscaled(const struct rect *src_rect, const struct rect *dst_rect)
+{
+        if (src_rect->width > dst_rect->width || src_rect->height > dst_rect->height)
+               return true;
+       return false;
+}
+
+static bool is_mpo(int layer_index)
+{
+       if (layer_index > 0)
+               return true;
+       return false;
+}
+
 static void calculate_integer_scaling(struct pipe_ctx *pipe_ctx)
 {
        unsigned int integer_multiple = 1;
 
-       if (pipe_ctx->plane_state->scaling_quality.integer_scaling) {
+       if (pipe_ctx->plane_state->scaling_quality.integer_scaling &&
+           !is_downscaled(&pipe_ctx->plane_state->src_rect, &pipe_ctx->plane_state->dst_rect) &&
+           !is_mpo(pipe_ctx->plane_state->layer_index)) {
                // calculate maximum # of replication of src onto addressable
                integer_multiple = min(
                                pipe_ctx->stream->timing.h_addressable / pipe_ctx->stream->src.width,