Re: [PATCH v2 7/7] drm/mediatek: mtk_dsi: Reset the dsi0 hardware

From: Matthias Brugger
Date: Fri Aug 06 2021 - 13:37:17 EST




On 14/07/2021 12:11, Enric Balletbo i Serra wrote:
> Reset dsi0 HW to default when power on. This prevents to have different
> settingbetween the bootloader and the kernel.

settings between the...

>
> As not all Mediatek boards have the reset consumer configured in their
> board description, also is not needed on all of them, the reset is optional,
> so the change is compatible with all boards.
>
> Cc: Jitao Shi <jitao.shi@xxxxxxxxxxxx>
> Suggested-by: Chun-Kuang Hu <chunkuang.hu@xxxxxxxxxx>
> Signed-off-by: Enric Balletbo i Serra <enric.balletbo@xxxxxxxxxxxxx>

Reviewed-by: Matthias Brugger <matthias.bgg@xxxxxxxxx>

> ---
>
> (no changes since v1)
>
> drivers/gpu/drm/mediatek/mtk_dsi.c | 5 ++++-
> 1 file changed, 4 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/gpu/drm/mediatek/mtk_dsi.c b/drivers/gpu/drm/mediatek/mtk_dsi.c
> index ae403c67cbd9..d8b81e2ab841 100644
> --- a/drivers/gpu/drm/mediatek/mtk_dsi.c
> +++ b/drivers/gpu/drm/mediatek/mtk_dsi.c
> @@ -11,6 +11,7 @@
> #include <linux/of_platform.h>
> #include <linux/phy/phy.h>
> #include <linux/platform_device.h>
> +#include <linux/reset.h>
>
> #include <video/mipi_display.h>
> #include <video/videomode.h>
> @@ -980,8 +981,10 @@ static int mtk_dsi_bind(struct device *dev, struct device *master, void *data)
> struct mtk_dsi *dsi = dev_get_drvdata(dev);
>
> ret = mtk_dsi_encoder_init(drm, dsi);
> + if (ret)
> + return ret;
>
> - return ret;
> + return device_reset_optional(dev);
> }
>
> static void mtk_dsi_unbind(struct device *dev, struct device *master,
>