Merge "disp: msm: dsi: expand matching requirements to find DSI mode match"
Cette révision appartient à :

révisé par
Gerrit - the friendly Code Review server

révision
2f70c01c06
@@ -36,6 +36,8 @@
|
||||
|
||||
#define SEC_PANEL_NAME_MAX_LEN 256
|
||||
|
||||
#define DSI_MODE_MATCH_TIMINGS (1 << 0)
|
||||
|
||||
u8 dbgfs_tx_cmd_buf[SZ_4K];
|
||||
static char dsi_display_primary[MAX_CMDLINE_PARAM_LEN];
|
||||
static char dsi_display_secondary[MAX_CMDLINE_PARAM_LEN];
|
||||
@@ -7078,6 +7080,37 @@ int dsi_display_get_qsync_min_fps(void *display_dsi, u32 mode_fps)
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
static bool dsi_display_match_timings(const struct dsi_display_mode *mode1,
|
||||
struct dsi_display_mode *mode2)
|
||||
{
|
||||
return mode1->timing.h_active == mode2->timing.h_active &&
|
||||
mode1->timing.h_sync_width == mode2->timing.h_sync_width &&
|
||||
mode1->timing.h_back_porch == mode2->timing.h_back_porch &&
|
||||
mode1->timing.h_front_porch == mode2->timing.h_front_porch &&
|
||||
mode1->timing.h_skew == mode2->timing.h_skew &&
|
||||
mode1->timing.v_active == mode2->timing.v_active &&
|
||||
mode1->timing.v_sync_width == mode2->timing.v_sync_width &&
|
||||
mode1->timing.v_back_porch == mode2->timing.v_back_porch &&
|
||||
mode1->timing.v_front_porch == mode2->timing.v_front_porch &&
|
||||
mode1->timing.refresh_rate == mode2->timing.refresh_rate;
|
||||
}
|
||||
|
||||
|
||||
static bool dsi_display_mode_match(const struct dsi_display_mode *mode1,
|
||||
struct dsi_display_mode *mode2, unsigned int match_flags)
|
||||
{
|
||||
if (!mode1 && !mode2)
|
||||
return true;
|
||||
|
||||
if (!mode1 || !mode2)
|
||||
return false;
|
||||
|
||||
if (match_flags & DSI_MODE_MATCH_TIMINGS && !dsi_display_match_timings(mode1, mode2))
|
||||
return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
int dsi_display_find_mode(struct dsi_display *display,
|
||||
const struct dsi_display_mode *cmp,
|
||||
struct dsi_display_mode **out_mode)
|
||||
@@ -7106,9 +7139,7 @@ int dsi_display_find_mode(struct dsi_display *display,
|
||||
for (i = 0; i < count; i++) {
|
||||
struct dsi_display_mode *m = &display->modes[i];
|
||||
|
||||
if (cmp->timing.v_active == m->timing.v_active &&
|
||||
cmp->timing.h_active == m->timing.h_active &&
|
||||
cmp->timing.refresh_rate == m->timing.refresh_rate) {
|
||||
if (dsi_display_mode_match(cmp, m, DSI_MODE_MATCH_TIMINGS)) {
|
||||
*out_mode = m;
|
||||
rc = 0;
|
||||
break;
|
||||
|
Référencer dans un nouveau ticket
Bloquer un utilisateur