drm/amd/display: update bw_calcs to take pipe sync into account (v3)
authorAlex Deucher <alexander.deucher@amd.com>
Fri, 23 Aug 2019 16:32:37 +0000 (11:32 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Fri, 23 Aug 2019 16:32:37 +0000 (11:32 -0500)
Properly set all_displays_in_sync so that when the data is
propagated to powerplay, it's set properly and we can enable
mclk switching when all monitors are in sync.

v2: fix logic, clean up
v3: check for blending chains, simplify logic

Acked-by: Evan Quan <evan.quan@amd.com>
Reviewed-by: Nicholas Kazlauskas <nicholas.kazlauskas@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/calcs/dce_calcs.c

index 9f12e21f8b9be773ed5d5ce8be3c01e33e7bef37..eca681d9d7f5ced14630508933f17d9e10b2852d 100644 (file)
@@ -25,6 +25,7 @@
 
 #include <linux/slab.h>
 
+#include "resource.h"
 #include "dm_services.h"
 #include "dce_calcs.h"
 #include "dc.h"
@@ -2977,6 +2978,32 @@ static void populate_initial_data(
        data->number_of_displays = num_displays;
 }
 
+static bool all_displays_in_sync(const struct pipe_ctx pipe[],
+                                int pipe_count)
+{
+       const struct pipe_ctx *active_pipes[MAX_PIPES];
+       int i, num_active_pipes = 0;
+
+       for (i = 0; i < pipe_count; i++) {
+               if (!pipe[i].stream || pipe[i].top_pipe)
+                       continue;
+
+               active_pipes[num_active_pipes++] = &pipe[i];
+       }
+
+       if (!num_active_pipes)
+               return false;
+
+       for (i = 1; i < num_active_pipes; ++i) {
+               if (!resource_are_streams_timing_synchronizable(
+                           active_pipes[0]->stream, active_pipes[i]->stream)) {
+                       return false;
+               }
+       }
+
+       return true;
+}
+
 /**
  * Return:
  *     true -  Display(s) configuration supported.
@@ -2998,8 +3025,7 @@ bool bw_calcs(struct dc_context *ctx,
 
        populate_initial_data(pipe, pipe_count, data);
 
-       /*TODO: this should be taken out calcs output and assigned during timing sync for pplib use*/
-       calcs_output->all_displays_in_sync = false;
+       calcs_output->all_displays_in_sync = all_displays_in_sync(pipe, pipe_count);
 
        if (data->number_of_displays != 0) {
                uint8_t yclk_lvl, sclk_lvl;