aboutsummaryrefslogtreecommitdiffstats
path: root/common/recipes-kernel/linux/linux-yocto-4.14.71/0652-drm-amd-display-add-idle-wait-for-passive-surface-up.patch
diff options
context:
space:
mode:
Diffstat (limited to 'common/recipes-kernel/linux/linux-yocto-4.14.71/0652-drm-amd-display-add-idle-wait-for-passive-surface-up.patch')
-rw-r--r--common/recipes-kernel/linux/linux-yocto-4.14.71/0652-drm-amd-display-add-idle-wait-for-passive-surface-up.patch176
1 files changed, 0 insertions, 176 deletions
diff --git a/common/recipes-kernel/linux/linux-yocto-4.14.71/0652-drm-amd-display-add-idle-wait-for-passive-surface-up.patch b/common/recipes-kernel/linux/linux-yocto-4.14.71/0652-drm-amd-display-add-idle-wait-for-passive-surface-up.patch
deleted file mode 100644
index 50a6ccf3..00000000
--- a/common/recipes-kernel/linux/linux-yocto-4.14.71/0652-drm-amd-display-add-idle-wait-for-passive-surface-up.patch
+++ /dev/null
@@ -1,176 +0,0 @@
-From a8c196f204a50222398ac6c17b7c4107b41eacd4 Mon Sep 17 00:00:00 2001
-From: Eric Yang <Eric.Yang2@amd.com>
-Date: Sun, 23 Jul 2017 15:18:57 -0400
-Subject: [PATCH 0652/4131] drm/amd/display: add idle wait for passive surface
- update and modeset
-
-Signed-off-by: Eric Yang <Eric.Yang2@amd.com>
-Reviewed-by: Tony Cheng <Tony.Cheng@amd.com>
-Acked-by: Harry Wentland <Harry.Wentland@amd.com>
-Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
----
- drivers/gpu/drm/amd/display/dc/core/dc.c | 19 +++++++++++++++++++
- .../gpu/drm/amd/display/dc/dcn10/dcn10_hw_sequencer.c | 18 +++++++++++++++++-
- drivers/gpu/drm/amd/display/dc/dcn10/dcn10_opp.c | 4 ++++
- drivers/gpu/drm/amd/display/dc/inc/core_types.h | 2 --
- drivers/gpu/drm/amd/display/dc/inc/hw/hw_shared.h | 3 +++
- drivers/gpu/drm/amd/display/dc/inc/hw/opp.h | 1 +
- drivers/gpu/drm/amd/display/dc/inc/hw_sequencer.h | 2 ++
- 7 files changed, 46 insertions(+), 3 deletions(-)
-
-diff --git a/drivers/gpu/drm/amd/display/dc/core/dc.c b/drivers/gpu/drm/amd/display/dc/core/dc.c
-index de05ad0..9ef6717 100644
---- a/drivers/gpu/drm/amd/display/dc/core/dc.c
-+++ b/drivers/gpu/drm/amd/display/dc/core/dc.c
-@@ -934,6 +934,10 @@ static bool dc_commit_context_no_check(struct dc *dc, struct validate_context *c
- if (!dcb->funcs->is_accelerated_mode(dcb))
- core_dc->hwss.enable_accelerated_mode(core_dc);
-
-+ for (i = 0; i < core_dc->res_pool->pipe_count; i++) {
-+ pipe = &context->res_ctx.pipe_ctx[i];
-+ core_dc->hwss.wait_for_mpcc_disconnect(core_dc->res_pool, pipe);
-+ }
- result = core_dc->hwss.apply_ctx_to_hw(core_dc, context);
-
- program_timing_sync(core_dc, context);
-@@ -1537,6 +1541,21 @@ void dc_update_surfaces_and_stream(struct dc *dc,
- }
- }
-
-+ if (update_type > UPDATE_TYPE_FAST) {
-+ for (i = 0; i < surface_count; i++) {
-+ struct core_surface *surface = DC_SURFACE_TO_CORE(srf_updates[i].surface);
-+
-+ for (j = 0; j < core_dc->res_pool->pipe_count; j++) {
-+ struct pipe_ctx *pipe_ctx = &context->res_ctx.pipe_ctx[j];
-+
-+ if (pipe_ctx->surface != surface)
-+ continue;
-+
-+ core_dc->hwss.wait_for_mpcc_disconnect(core_dc->res_pool, pipe_ctx);
-+ }
-+ }
-+ }
-+
- if (surface_count == 0)
- core_dc->hwss.apply_ctx_for_surface(core_dc, NULL, context);
-
-diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hw_sequencer.c b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hw_sequencer.c
-index 64f2fd0..633d858 100644
---- a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hw_sequencer.c
-+++ b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hw_sequencer.c
-@@ -1739,6 +1739,7 @@ static void dcn10_apply_ctx_for_surface(
- mpcc_cfg.bot_mpcc_id = 0xf;
- mpcc_cfg.top_of_tree = !old_pipe_ctx->top_pipe;
- old_pipe_ctx->mpcc->funcs->set(old_pipe_ctx->mpcc, &mpcc_cfg);
-+ old_pipe_ctx->top_pipe->opp->mpcc_disconnect_pending[old_pipe_ctx->mpcc->inst] = true;
-
- if (dc->public.debug.sanity_checks)
- verify_allow_pstate_change_high(dc->hwseq);
-@@ -2012,6 +2013,20 @@ static void dcn10_log_hw_state(struct core_dc *dc)
- */
- }
-
-+static void dcn10_wait_for_mpcc_disconnect(struct resource_pool *res_pool, struct pipe_ctx *pipe_ctx)
-+{
-+ int i;
-+ for (i = 0; i < MAX_PIPES; i++) {
-+ if (!pipe_ctx->opp || !pipe_ctx->mpcc)
-+ continue;
-+
-+ if (pipe_ctx->opp->mpcc_disconnect_pending[i]) {
-+ pipe_ctx->mpcc->funcs->wait_for_idle(res_pool->mpcc[i]);
-+ pipe_ctx->opp->mpcc_disconnect_pending[i] = false;
-+ }
-+ }
-+}
-+
- static bool dcn10_dummy_display_power_gating(
- struct core_dc *dc,
- uint8_t controller_id,
-@@ -2085,7 +2100,8 @@ static const struct hw_sequencer_funcs dcn10_funcs = {
- .set_static_screen_control = set_static_screen_control,
- .setup_stereo = dcn10_setup_stereo,
- .set_avmute = dce110_set_avmute,
-- .log_hw_state = dcn10_log_hw_state
-+ .log_hw_state = dcn10_log_hw_state,
-+ .wait_for_mpcc_disconnect = dcn10_wait_for_mpcc_disconnect
- };
-
-
-diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_opp.c b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_opp.c
-index 669ac4b..c2aa69d 100644
---- a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_opp.c
-+++ b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_opp.c
-@@ -907,10 +907,14 @@ void dcn10_opp_construct(struct dcn10_opp *oppn10,
- const struct dcn10_opp_shift *opp_shift,
- const struct dcn10_opp_mask *opp_mask)
- {
-+ int i;
- oppn10->base.ctx = ctx;
- oppn10->base.inst = inst;
- oppn10->base.funcs = &dcn10_opp_funcs;
-
-+ for (i = 0; i < MAX_PIPES; i++)
-+ oppn10->base.mpcc_disconnect_pending[i] = false;
-+
- oppn10->regs = regs;
- oppn10->opp_shift = opp_shift;
- oppn10->opp_mask = opp_mask;
-diff --git a/drivers/gpu/drm/amd/display/dc/inc/core_types.h b/drivers/gpu/drm/amd/display/dc/inc/core_types.h
-index 30177f8..cc65cfd 100644
---- a/drivers/gpu/drm/amd/display/dc/inc/core_types.h
-+++ b/drivers/gpu/drm/amd/display/dc/inc/core_types.h
-@@ -38,10 +38,8 @@
-
- struct core_stream;
-
--#define MAX_PIPES 6
- #define MAX_CLOCK_SOURCES 7
-
--
- /********* core_surface **********/
- #define DC_SURFACE_TO_CORE(dc_surface) \
- container_of(dc_surface, struct core_surface, public)
-diff --git a/drivers/gpu/drm/amd/display/dc/inc/hw/hw_shared.h b/drivers/gpu/drm/amd/display/dc/inc/hw/hw_shared.h
-index 907e0a9..0212618 100644
---- a/drivers/gpu/drm/amd/display/dc/inc/hw/hw_shared.h
-+++ b/drivers/gpu/drm/amd/display/dc/inc/hw/hw_shared.h
-@@ -32,6 +32,9 @@
- /******************************************************************************
- * Data types shared between different Virtual HW blocks
- ******************************************************************************/
-+
-+#define MAX_PIPES 6
-+
- struct gamma_curve {
- uint32_t offset;
- uint32_t segments_num;
-diff --git a/drivers/gpu/drm/amd/display/dc/inc/hw/opp.h b/drivers/gpu/drm/amd/display/dc/inc/hw/opp.h
-index 4b0c28e..57bdd6c 100644
---- a/drivers/gpu/drm/amd/display/dc/inc/hw/opp.h
-+++ b/drivers/gpu/drm/amd/display/dc/inc/hw/opp.h
-@@ -207,6 +207,7 @@ struct output_pixel_processor {
- struct dc_context *ctx;
- uint32_t inst;
- struct pwl_params regamma_params;
-+ bool mpcc_disconnect_pending[MAX_PIPES];
- const struct opp_funcs *funcs;
- };
-
-diff --git a/drivers/gpu/drm/amd/display/dc/inc/hw_sequencer.h b/drivers/gpu/drm/amd/display/dc/inc/hw_sequencer.h
-index 4c027a9..22aca5a 100644
---- a/drivers/gpu/drm/amd/display/dc/inc/hw_sequencer.h
-+++ b/drivers/gpu/drm/amd/display/dc/inc/hw_sequencer.h
-@@ -156,6 +156,8 @@ struct hw_sequencer_funcs {
- void (*set_avmute)(struct pipe_ctx *pipe_ctx, bool enable);
-
- void (*log_hw_state)(struct core_dc *dc);
-+
-+ void (*wait_for_mpcc_disconnect)(struct resource_pool *res_pool, struct pipe_ctx *pipe_ctx);
- };
-
- void color_space_to_black_color(
---
-2.7.4
-