Ignoring errors from devm_clk_get() is wrong. To handle not all platforms
having an axi clk use devm_clk_get_optional() instead and do proper error
handling.

Also the clk API handles NULL as a dummy clk (which is also returned by
devm_clk_get_optional() if there is no clk) so there is no need to check
for NULL before calling clk_prepare_enable() or its counter part.

Signed-off-by: Uwe Kleine-König <u.kleine-koe...@pengutronix.de>
---
 drivers/gpu/drm/mxsfb/mxsfb_drv.c | 10 ++++------
 1 file changed, 4 insertions(+), 6 deletions(-)

diff --git a/drivers/gpu/drm/mxsfb/mxsfb_drv.c 
b/drivers/gpu/drm/mxsfb/mxsfb_drv.c
index fb972dd4f642..6e185ba74b4b 100644
--- a/drivers/gpu/drm/mxsfb/mxsfb_drv.c
+++ b/drivers/gpu/drm/mxsfb/mxsfb_drv.c
@@ -77,14 +77,12 @@ drm_pipe_to_mxsfb_drm_private(struct 
drm_simple_display_pipe *pipe)
 
 void mxsfb_enable_axi_clk(struct mxsfb_drm_private *mxsfb)
 {
-       if (mxsfb->clk_axi)
-               clk_prepare_enable(mxsfb->clk_axi);
+       clk_prepare_enable(mxsfb->clk_axi);
 }
 
 void mxsfb_disable_axi_clk(struct mxsfb_drm_private *mxsfb)
 {
-       if (mxsfb->clk_axi)
-               clk_disable_unprepare(mxsfb->clk_axi);
+       clk_disable_unprepare(mxsfb->clk_axi);
 }
 
 static const struct drm_mode_config_funcs mxsfb_mode_config_funcs = {
@@ -214,9 +212,9 @@ static int mxsfb_load(struct drm_device *drm)
        if (IS_ERR(mxsfb->clk))
                return PTR_ERR(mxsfb->clk);
 
-       mxsfb->clk_axi = devm_clk_get(drm->dev, "axi");
+       mxsfb->clk_axi = devm_clk_get_optional(drm->dev, "axi");
        if (IS_ERR(mxsfb->clk_axi))
-               mxsfb->clk_axi = NULL;
+               return PTR_ERR(mxsfb->clk_axi);
 
        mxsfb->clk_disp_axi = devm_clk_get(drm->dev, "disp_axi");
        if (IS_ERR(mxsfb->clk_disp_axi))
-- 
2.27.0

_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to