提交 f0828115 编写于 作者: C Charlene Liu 提交者: Alex Deucher

drm/amd/display: freesync pipe split :VTotal_Min_Mask for Hflip/lock.

Signed-off-by: NCharlene Liu <charlene.liu@amd.com>
Acked-by: NHarry Wentland <Harry.Wentland@amd.com>
Reviewed-by: NJordan Lazare <Jordan.Lazare@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
上级 e7738c8a
...@@ -1178,6 +1178,7 @@ void dc_update_surfaces_for_stream(struct dc *dc, ...@@ -1178,6 +1178,7 @@ void dc_update_surfaces_for_stream(struct dc *dc,
enum surface_update_type update_type; enum surface_update_type update_type;
const struct dc_stream_status *stream_status; const struct dc_stream_status *stream_status;
unsigned int lock_mask = 0;
stream_status = dc_stream_get_status(dc_stream); stream_status = dc_stream_get_status(dc_stream);
ASSERT(stream_status); ASSERT(stream_status);
...@@ -1313,6 +1314,23 @@ void dc_update_surfaces_for_stream(struct dc *dc, ...@@ -1313,6 +1314,23 @@ void dc_update_surfaces_for_stream(struct dc *dc,
for (i = 0; i < surface_count; i++) { for (i = 0; i < surface_count; i++) {
struct core_surface *surface = DC_SURFACE_TO_CORE(updates[i].surface); struct core_surface *surface = DC_SURFACE_TO_CORE(updates[i].surface);
for (j = 0; j < context->res_ctx.pool->pipe_count; j++) {
struct pipe_ctx *pipe_ctx = &context->res_ctx.pipe_ctx[j];
if (pipe_ctx->surface != surface)
continue;
/*lock all the MCPP if blnd is enable for DRR*/
if ((update_type == UPDATE_TYPE_FAST &&
(dc_stream->freesync_ctx.enabled == true &&
surface_count != context->res_ctx.pool->pipe_count)) &&
!pipe_ctx->tg->funcs->is_blanked(pipe_ctx->tg)) {
lock_mask = PIPE_LOCK_CONTROL_MPCC_ADDR;
core_dc->hwss.pipe_control_lock(
core_dc,
pipe_ctx,
lock_mask,
true);
}
}
for (j = 0; j < context->res_ctx.pool->pipe_count; j++) { for (j = 0; j < context->res_ctx.pool->pipe_count; j++) {
struct pipe_ctx *pipe_ctx = &context->res_ctx.pipe_ctx[j]; struct pipe_ctx *pipe_ctx = &context->res_ctx.pipe_ctx[j];
struct pipe_ctx *cur_pipe_ctx; struct pipe_ctx *cur_pipe_ctx;
...@@ -1320,16 +1338,16 @@ void dc_update_surfaces_for_stream(struct dc *dc, ...@@ -1320,16 +1338,16 @@ void dc_update_surfaces_for_stream(struct dc *dc,
if (pipe_ctx->surface != surface) if (pipe_ctx->surface != surface)
continue; continue;
if (update_type != UPDATE_TYPE_FAST && if (update_type != UPDATE_TYPE_FAST &&
!pipe_ctx->tg->funcs->is_blanked(pipe_ctx->tg)) { !pipe_ctx->tg->funcs->is_blanked(pipe_ctx->tg)) {
core_dc->hwss.pipe_control_lock( lock_mask = PIPE_LOCK_CONTROL_GRAPHICS |
core_dc->hwseq,
pipe_ctx->pipe_idx,
PIPE_LOCK_CONTROL_GRAPHICS |
PIPE_LOCK_CONTROL_SCL | PIPE_LOCK_CONTROL_SCL |
PIPE_LOCK_CONTROL_BLENDER | PIPE_LOCK_CONTROL_BLENDER |
PIPE_LOCK_CONTROL_MODE, PIPE_LOCK_CONTROL_MODE;
core_dc->hwss.pipe_control_lock(
core_dc,
pipe_ctx,
lock_mask,
true); true);
} }
...@@ -1371,7 +1389,7 @@ void dc_update_surfaces_for_stream(struct dc *dc, ...@@ -1371,7 +1389,7 @@ void dc_update_surfaces_for_stream(struct dc *dc,
} }
} }
if (update_type == UPDATE_TYPE_FAST) if (update_type == UPDATE_TYPE_FAST && (lock_mask == 0))
return; return;
for (i = context->res_ctx.pool->pipe_count - 1; i >= 0; i--) { for (i = context->res_ctx.pool->pipe_count - 1; i >= 0; i--) {
...@@ -1381,11 +1399,9 @@ void dc_update_surfaces_for_stream(struct dc *dc, ...@@ -1381,11 +1399,9 @@ void dc_update_surfaces_for_stream(struct dc *dc,
if (updates[j].surface == &pipe_ctx->surface->public) { if (updates[j].surface == &pipe_ctx->surface->public) {
if (!pipe_ctx->tg->funcs->is_blanked(pipe_ctx->tg)) { if (!pipe_ctx->tg->funcs->is_blanked(pipe_ctx->tg)) {
core_dc->hwss.pipe_control_lock( core_dc->hwss.pipe_control_lock(
core_dc->hwseq, core_dc,
pipe_ctx->pipe_idx, pipe_ctx,
PIPE_LOCK_CONTROL_GRAPHICS | lock_mask,
PIPE_LOCK_CONTROL_SCL |
PIPE_LOCK_CONTROL_BLENDER,
false); false);
} }
break; break;
......
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
#include "dce_hwseq.h" #include "dce_hwseq.h"
#include "reg_helper.h" #include "reg_helper.h"
#include "hw_sequencer.h" #include "hw_sequencer.h"
#include "core_dc.h"
#define CTX \ #define CTX \
hws->ctx hws->ctx
...@@ -43,15 +44,17 @@ void dce_enable_fe_clock(struct dce_hwseq *hws, ...@@ -43,15 +44,17 @@ void dce_enable_fe_clock(struct dce_hwseq *hws,
DCFE_CLOCK_ENABLE, enable); DCFE_CLOCK_ENABLE, enable);
} }
void dce_pipe_control_lock(struct dce_hwseq *hws, void dce_pipe_control_lock(struct core_dc *dc,
unsigned int blnd_inst, struct pipe_ctx *pipe,
enum pipe_lock_control control_mask, enum pipe_lock_control control_mask,
bool lock) bool lock)
{ {
uint32_t lock_val = lock ? 1 : 0; uint32_t lock_val = lock ? 1 : 0;
uint32_t dcp_grph, scl, blnd, update_lock_mode; uint32_t dcp_grph, scl, blnd, update_lock_mode, val;
struct dce_hwseq *hws = dc->hwseq;
uint32_t val = REG_GET_4(BLND_V_UPDATE_LOCK[blnd_inst], if (control_mask & PIPE_LOCK_CONTROL_MPCC_ADDR)
return;
val = REG_GET_4(BLND_V_UPDATE_LOCK[pipe->pipe_idx],
BLND_DCP_GRPH_V_UPDATE_LOCK, &dcp_grph, BLND_DCP_GRPH_V_UPDATE_LOCK, &dcp_grph,
BLND_SCL_V_UPDATE_LOCK, &scl, BLND_SCL_V_UPDATE_LOCK, &scl,
BLND_BLND_V_UPDATE_LOCK, &blnd, BLND_BLND_V_UPDATE_LOCK, &blnd,
...@@ -70,19 +73,19 @@ void dce_pipe_control_lock(struct dce_hwseq *hws, ...@@ -70,19 +73,19 @@ void dce_pipe_control_lock(struct dce_hwseq *hws,
update_lock_mode = lock_val; update_lock_mode = lock_val;
REG_SET_2(BLND_V_UPDATE_LOCK[blnd_inst], val, REG_SET_2(BLND_V_UPDATE_LOCK[pipe->pipe_idx], val,
BLND_DCP_GRPH_V_UPDATE_LOCK, dcp_grph, BLND_DCP_GRPH_V_UPDATE_LOCK, dcp_grph,
BLND_SCL_V_UPDATE_LOCK, scl); BLND_SCL_V_UPDATE_LOCK, scl);
if (hws->masks->BLND_BLND_V_UPDATE_LOCK != 0) if (hws->masks->BLND_BLND_V_UPDATE_LOCK != 0)
REG_SET_2(BLND_V_UPDATE_LOCK[blnd_inst], val, REG_SET_2(BLND_V_UPDATE_LOCK[pipe->pipe_idx], val,
BLND_BLND_V_UPDATE_LOCK, blnd, BLND_BLND_V_UPDATE_LOCK, blnd,
BLND_V_UPDATE_LOCK_MODE, update_lock_mode); BLND_V_UPDATE_LOCK_MODE, update_lock_mode);
if (hws->wa.blnd_crtc_trigger) { if (hws->wa.blnd_crtc_trigger) {
if (!lock && (control_mask & PIPE_LOCK_CONTROL_BLENDER)) { if (!lock && (control_mask & PIPE_LOCK_CONTROL_BLENDER)) {
uint32_t value = REG_READ(CRTC_H_BLANK_START_END[blnd_inst]); uint32_t value = REG_READ(CRTC_H_BLANK_START_END[pipe->pipe_idx]);
REG_WRITE(CRTC_H_BLANK_START_END[blnd_inst], value); REG_WRITE(CRTC_H_BLANK_START_END[pipe->pipe_idx], value);
} }
} }
} }
......
...@@ -212,17 +212,6 @@ struct dce_hwseq_mask { ...@@ -212,17 +212,6 @@ struct dce_hwseq_mask {
HWSEQ_REG_FIED_LIST(uint32_t) HWSEQ_REG_FIED_LIST(uint32_t)
}; };
struct dce_hwseq_wa {
bool blnd_crtc_trigger;
};
struct dce_hwseq {
struct dc_context *ctx;
const struct dce_hwseq_registers *regs;
const struct dce_hwseq_shift *shifts;
const struct dce_hwseq_mask *masks;
struct dce_hwseq_wa wa;
};
enum blnd_mode { enum blnd_mode {
BLND_MODE_CURRENT_PIPE = 0,/* Data from current pipe only */ BLND_MODE_CURRENT_PIPE = 0,/* Data from current pipe only */
...@@ -233,8 +222,8 @@ enum blnd_mode { ...@@ -233,8 +222,8 @@ enum blnd_mode {
void dce_enable_fe_clock(struct dce_hwseq *hwss, void dce_enable_fe_clock(struct dce_hwseq *hwss,
unsigned int inst, bool enable); unsigned int inst, bool enable);
void dce_pipe_control_lock(struct dce_hwseq *hws, void dce_pipe_control_lock(struct core_dc *dc,
unsigned int blnd_inst, struct pipe_ctx *pipe,
enum pipe_lock_control control_mask, enum pipe_lock_control control_mask,
bool lock); bool lock);
......
...@@ -38,10 +38,22 @@ enum pipe_lock_control { ...@@ -38,10 +38,22 @@ enum pipe_lock_control {
PIPE_LOCK_CONTROL_GRAPHICS = 1 << 0, PIPE_LOCK_CONTROL_GRAPHICS = 1 << 0,
PIPE_LOCK_CONTROL_BLENDER = 1 << 1, PIPE_LOCK_CONTROL_BLENDER = 1 << 1,
PIPE_LOCK_CONTROL_SCL = 1 << 2, PIPE_LOCK_CONTROL_SCL = 1 << 2,
PIPE_LOCK_CONTROL_MODE = 1 << 3 PIPE_LOCK_CONTROL_MODE = 1 << 3,
PIPE_LOCK_CONTROL_MPCC_ADDR = 1 << 4
};
struct dce_hwseq_wa {
bool blnd_crtc_trigger;
};
struct dce_hwseq {
struct dc_context *ctx;
const struct dce_hwseq_registers *regs;
const struct dce_hwseq_shift *shifts;
const struct dce_hwseq_mask *masks;
struct dce_hwseq_wa wa;
}; };
struct dce_hwseq;
struct hw_sequencer_funcs { struct hw_sequencer_funcs {
...@@ -115,8 +127,8 @@ struct hw_sequencer_funcs { ...@@ -115,8 +127,8 @@ struct hw_sequencer_funcs {
struct dc_link_settings *link_settings); struct dc_link_settings *link_settings);
void (*pipe_control_lock)( void (*pipe_control_lock)(
struct dce_hwseq *hwseq, struct core_dc *dc,
unsigned int blnd_inst, struct pipe_ctx *pipe,
enum pipe_lock_control control_mask, enum pipe_lock_control control_mask,
bool lock); bool lock);
......
...@@ -38,6 +38,7 @@ struct drr_params { ...@@ -38,6 +38,7 @@ struct drr_params {
/* defines the maximum possible vertical dimension of display timing /* defines the maximum possible vertical dimension of display timing
* for CRTC as supported by the panel */ * for CRTC as supported by the panel */
uint32_t vertical_total_max; uint32_t vertical_total_max;
bool immediate_flip;
}; };
#endif #endif
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册