Merge "disp: msm: restore dynamic bit clock front porches"

Bu işleme şunda yer alıyor:
qctecmdr
2023-03-24 07:26:43 -07:00
işlemeyi yapan: Gerrit - the friendly Code Review server
işleme d4f055f1fb

Dosyayı Görüntüle

@@ -7000,6 +7000,7 @@ int dsi_display_restore_bit_clk(struct dsi_display *display, struct dsi_display_
{
int i;
u32 clk_rate_hz = 0;
u32 front_porch = 0;
if (!display || !mode || !mode->priv_info) {
DSI_ERR("invalid arguments\n");
@@ -7013,12 +7014,29 @@ int dsi_display_restore_bit_clk(struct dsi_display *display, struct dsi_display_
clk_rate_hz = display->cached_clk_rate;
if (mode->priv_info->bit_clk_list.count) {
/* use first entry as the default bit clk rate */
/* use first entry as the default bit clk rate and front porch*/
clk_rate_hz = mode->priv_info->bit_clk_list.rates[0];
front_porch = mode->priv_info->bit_clk_list.front_porches[0];
for (i = 0; i < mode->priv_info->bit_clk_list.count; i++) {
if (display->dyn_bit_clk == mode->priv_info->bit_clk_list.rates[i])
if (display->dyn_bit_clk == mode->priv_info->bit_clk_list.rates[i]) {
clk_rate_hz = display->dyn_bit_clk;
front_porch = mode->priv_info->bit_clk_list.front_porches[i];
}
}
/* avoid restore front porch if this commit is updating dyn bit clock */
if (!display->dyn_bit_clk_pending && display->dyn_bit_clk) {
switch (display->panel->dyn_clk_caps.type) {
case DSI_DYN_CLK_TYPE_CONST_FPS_ADJUST_HFP:
mode->timing.h_front_porch = front_porch;
break;
case DSI_DYN_CLK_TYPE_CONST_FPS_ADJUST_VFP:
mode->timing.v_front_porch = front_porch;
break;
default:
break;
}
}
}