disp: msm: sde: update autorefresh disable seq-2
Update autorefresh disable sequence-2 by avoiding tearcheck enable configuration. Updated sequence will trigger the frame by resetting the write line count with tearcheck start position. Change-Id: I984251c0cb23475f20cd5ea62122a167324d6670 Signed-off-by: Dhaval Patel <pdhaval@codeaurora.org>
Esse commit está contido em:

commit de
Gerrit - the friendly Code Review server

pai
1a9e3bae54
commit
e7123aec1c
@@ -1783,8 +1783,11 @@ static void _sde_encoder_autorefresh_disable_seq2(
|
|||||||
u32 autorefresh_status = 0;
|
u32 autorefresh_status = 0;
|
||||||
struct sde_encoder_phys_cmd *cmd_enc =
|
struct sde_encoder_phys_cmd *cmd_enc =
|
||||||
to_sde_encoder_phys_cmd(phys_enc);
|
to_sde_encoder_phys_cmd(phys_enc);
|
||||||
|
struct intf_tear_status tear_status;
|
||||||
|
struct sde_hw_intf *hw_intf = phys_enc->hw_intf;
|
||||||
|
|
||||||
if (!hw_mdp->ops.get_autorefresh_status) {
|
if (!hw_mdp->ops.get_autorefresh_status ||
|
||||||
|
!hw_intf->ops.check_and_reset_tearcheck) {
|
||||||
SDE_DEBUG_CMDENC(cmd_enc,
|
SDE_DEBUG_CMDENC(cmd_enc,
|
||||||
"autofresh disable seq2 not supported\n");
|
"autofresh disable seq2 not supported\n");
|
||||||
return;
|
return;
|
||||||
@@ -1793,10 +1796,11 @@ static void _sde_encoder_autorefresh_disable_seq2(
|
|||||||
/*
|
/*
|
||||||
* If autorefresh is still enabled after sequence-1, proceed with
|
* If autorefresh is still enabled after sequence-1, proceed with
|
||||||
* below sequence-2.
|
* below sequence-2.
|
||||||
* 1. Disable TEAR CHECK
|
* 1. Disable autorefresh config
|
||||||
* 2. Disable autorefresh config
|
* 2. Run in loop:
|
||||||
* 4. Poll for autorefresh to be disabled
|
* 2.1 Poll for autorefresh to be disabled
|
||||||
* 5. Enable TEAR CHECK
|
* 2.2 Log read and write count status
|
||||||
|
* 2.3 Replace te write count with start_pos to meet trigger window
|
||||||
*/
|
*/
|
||||||
autorefresh_status = hw_mdp->ops.get_autorefresh_status(hw_mdp,
|
autorefresh_status = hw_mdp->ops.get_autorefresh_status(hw_mdp,
|
||||||
phys_enc->intf_idx);
|
phys_enc->intf_idx);
|
||||||
@@ -1813,52 +1817,36 @@ static void _sde_encoder_autorefresh_disable_seq2(
|
|||||||
autorefresh_status, SDE_EVTLOG_FUNC_CASE2);
|
autorefresh_status, SDE_EVTLOG_FUNC_CASE2);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (autorefresh_status & BIT(7)) {
|
while (autorefresh_status & BIT(7)) {
|
||||||
SDE_ERROR_CMDENC(cmd_enc, "autofresh status:0x%x intf:%d\n",
|
if (!trial) {
|
||||||
autorefresh_status, phys_enc->intf_idx - INTF_0);
|
|
||||||
|
|
||||||
if (phys_enc->has_intf_te &&
|
|
||||||
phys_enc->hw_intf->ops.enable_tearcheck)
|
|
||||||
phys_enc->hw_intf->ops.enable_tearcheck(
|
|
||||||
phys_enc->hw_intf, false);
|
|
||||||
else if (phys_enc->hw_pp->ops.enable_tearcheck)
|
|
||||||
phys_enc->hw_pp->ops.enable_tearcheck(
|
|
||||||
phys_enc->hw_pp, false);
|
|
||||||
|
|
||||||
_sde_encoder_phys_cmd_config_autorefresh(phys_enc, 0);
|
|
||||||
|
|
||||||
do {
|
|
||||||
usleep_range(AUTOREFRESH_SEQ2_POLL_TIME,
|
|
||||||
AUTOREFRESH_SEQ2_POLL_TIME + 1);
|
|
||||||
if ((trial * AUTOREFRESH_SEQ2_POLL_TIME)
|
|
||||||
> AUTOREFRESH_SEQ2_POLL_TIMEOUT) {
|
|
||||||
SDE_ERROR_CMDENC(cmd_enc,
|
|
||||||
"disable autorefresh failed\n");
|
|
||||||
SDE_DBG_DUMP("all", "dbg_bus", "vbif_dbg_bus",
|
|
||||||
"panic");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
trial++;
|
|
||||||
autorefresh_status =
|
|
||||||
hw_mdp->ops.get_autorefresh_status(hw_mdp,
|
|
||||||
phys_enc->intf_idx);
|
|
||||||
SDE_ERROR_CMDENC(cmd_enc,
|
SDE_ERROR_CMDENC(cmd_enc,
|
||||||
"autofresh status:0x%x intf:%d\n",
|
"autofresh status:0x%x intf:%d\n", autorefresh_status,
|
||||||
autorefresh_status,
|
phys_enc->intf_idx - INTF_0);
|
||||||
phys_enc->intf_idx - INTF_0);
|
|
||||||
SDE_EVT32(DRMID(phys_enc->parent),
|
|
||||||
phys_enc->intf_idx - INTF_0,
|
|
||||||
autorefresh_status);
|
|
||||||
} while (autorefresh_status & BIT(7));
|
|
||||||
|
|
||||||
if (phys_enc->has_intf_te &&
|
_sde_encoder_phys_cmd_config_autorefresh(phys_enc, 0);
|
||||||
phys_enc->hw_intf->ops.enable_tearcheck)
|
}
|
||||||
phys_enc->hw_intf->ops.enable_tearcheck(
|
|
||||||
phys_enc->hw_intf, true);
|
usleep_range(AUTOREFRESH_SEQ2_POLL_TIME,
|
||||||
else if (phys_enc->hw_pp->ops.enable_tearcheck)
|
AUTOREFRESH_SEQ2_POLL_TIME + 1);
|
||||||
phys_enc->hw_pp->ops.enable_tearcheck(
|
if ((trial * AUTOREFRESH_SEQ2_POLL_TIME)
|
||||||
phys_enc->hw_pp, true);
|
> AUTOREFRESH_SEQ2_POLL_TIMEOUT) {
|
||||||
|
SDE_ERROR_CMDENC(cmd_enc,
|
||||||
|
"disable autorefresh failed\n");
|
||||||
|
SDE_DBG_DUMP("all", "dbg_bus", "vbif_dbg_bus", "panic");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
trial++;
|
||||||
|
autorefresh_status = hw_mdp->ops.get_autorefresh_status(hw_mdp,
|
||||||
|
phys_enc->intf_idx);
|
||||||
|
hw_intf->ops.check_and_reset_tearcheck(hw_intf, &tear_status);
|
||||||
|
SDE_ERROR_CMDENC(cmd_enc,
|
||||||
|
"autofresh status:0x%x intf:%d tear_read:0x%x tear_write:0x%x\n",
|
||||||
|
autorefresh_status, phys_enc->intf_idx - INTF_0,
|
||||||
|
tear_status.read_count, tear_status.write_count);
|
||||||
|
SDE_EVT32(DRMID(phys_enc->parent), phys_enc->intf_idx - INTF_0,
|
||||||
|
autorefresh_status, tear_status.read_count,
|
||||||
|
tear_status.write_count);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -672,6 +672,27 @@ static int sde_hw_intf_get_vsync_info(struct sde_hw_intf *intf,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int sde_hw_intf_v1_check_and_reset_tearcheck(struct sde_hw_intf *intf,
|
||||||
|
struct intf_tear_status *status)
|
||||||
|
{
|
||||||
|
struct sde_hw_blk_reg_map *c = &intf->hw;
|
||||||
|
u32 start_pos;
|
||||||
|
|
||||||
|
if (!intf || !status)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
c = &intf->hw;
|
||||||
|
|
||||||
|
status->read_count = SDE_REG_READ(c, INTF_TEAR_INT_COUNT_VAL);
|
||||||
|
start_pos = SDE_REG_READ(c, INTF_TEAR_START_POS);
|
||||||
|
status->write_count = SDE_REG_READ(c, INTF_TEAR_SYNC_WRCOUNT);
|
||||||
|
status->write_count &= 0xffff0000;
|
||||||
|
status->write_count |= start_pos;
|
||||||
|
SDE_REG_WRITE(c, INTF_TEAR_SYNC_WRCOUNT, status->write_count);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static void sde_hw_intf_vsync_sel(struct sde_hw_intf *intf,
|
static void sde_hw_intf_vsync_sel(struct sde_hw_intf *intf,
|
||||||
u32 vsync_source)
|
u32 vsync_source)
|
||||||
{
|
{
|
||||||
@@ -739,6 +760,8 @@ static void _setup_intf_ops(struct sde_hw_intf_ops *ops,
|
|||||||
ops->poll_timeout_wr_ptr = sde_hw_intf_poll_timeout_wr_ptr;
|
ops->poll_timeout_wr_ptr = sde_hw_intf_poll_timeout_wr_ptr;
|
||||||
ops->vsync_sel = sde_hw_intf_vsync_sel;
|
ops->vsync_sel = sde_hw_intf_vsync_sel;
|
||||||
ops->get_status = sde_hw_intf_v1_get_status;
|
ops->get_status = sde_hw_intf_v1_get_status;
|
||||||
|
ops->check_and_reset_tearcheck =
|
||||||
|
sde_hw_intf_v1_check_and_reset_tearcheck;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -52,6 +52,11 @@ struct intf_status {
|
|||||||
u32 line_count; /* current line count including blanking */
|
u32 line_count; /* current line count including blanking */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct intf_tear_status {
|
||||||
|
u32 read_count; /* frame & line count for tear init value */
|
||||||
|
u32 write_count; /* frame & line count for tear write */
|
||||||
|
};
|
||||||
|
|
||||||
struct intf_avr_params {
|
struct intf_avr_params {
|
||||||
u32 default_fps;
|
u32 default_fps;
|
||||||
u32 min_fps;
|
u32 min_fps;
|
||||||
@@ -188,6 +193,12 @@ struct sde_hw_intf_ops {
|
|||||||
*/
|
*/
|
||||||
void (*enable_compressed_input)(struct sde_hw_intf *intf,
|
void (*enable_compressed_input)(struct sde_hw_intf *intf,
|
||||||
bool compression_en, bool dsc_4hs_merge);
|
bool compression_en, bool dsc_4hs_merge);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check the intf tear check status and reset it to start_pos
|
||||||
|
*/
|
||||||
|
int (*check_and_reset_tearcheck)(struct sde_hw_intf *intf,
|
||||||
|
struct intf_tear_status *status);
|
||||||
};
|
};
|
||||||
|
|
||||||
struct sde_hw_intf {
|
struct sde_hw_intf {
|
||||||
|
Referência em uma nova issue
Block a user