|
@@ -114,6 +114,7 @@ struct mtk_dpi_yc_limit {
|
|
|
|
|
|
struct mtk_dpi_conf {
|
|
|
u32 reg_h_fre_con;
|
|
|
+ bool edge_sel_en;
|
|
|
};
|
|
|
|
|
|
static void mtk_dpi_mask(struct mtk_dpi *dpi, u32 offset, u32 val, u32 mask)
|
|
@@ -344,6 +345,12 @@ static void mtk_dpi_config_2n_h_fre(struct mtk_dpi *dpi)
|
|
|
mtk_dpi_mask(dpi, dpi->conf->reg_h_fre_con, H_FRE_2N, H_FRE_2N);
|
|
|
}
|
|
|
|
|
|
+static void mtk_dpi_config_disable_edge(struct mtk_dpi *dpi)
|
|
|
+{
|
|
|
+ if (dpi->conf->edge_sel_en)
|
|
|
+ mtk_dpi_mask(dpi, dpi->conf->reg_h_fre_con, 0, EDGE_SEL_EN);
|
|
|
+}
|
|
|
+
|
|
|
static void mtk_dpi_config_color_format(struct mtk_dpi *dpi,
|
|
|
enum mtk_dpi_out_color_format format)
|
|
|
{
|
|
@@ -507,6 +514,7 @@ static int mtk_dpi_set_display_mode(struct mtk_dpi *dpi,
|
|
|
mtk_dpi_config_yc_map(dpi, dpi->yc_map);
|
|
|
mtk_dpi_config_color_format(dpi, dpi->color_format);
|
|
|
mtk_dpi_config_2n_h_fre(dpi);
|
|
|
+ mtk_dpi_config_disable_edge(dpi);
|
|
|
mtk_dpi_sw_reset(dpi, false);
|
|
|
|
|
|
return 0;
|