drm/imx: parallel-display: move panel/bridge detection to fail early
authorMarco Felsch <m.felsch@pengutronix.de>
Wed, 20 Nov 2019 16:54:59 +0000 (17:54 +0100)
committerPhilipp Zabel <p.zabel@pengutronix.de>
Mon, 20 Jul 2020 13:16:05 +0000 (15:16 +0200)
We do some string parsing and string comparison in front of
drm_of_find_panel_or_bridge(). All this work is useless if the call
fails. Move drm_of_find_panel_or_bridge() infront of the parsing work to
fail early.

Signed-off-by: Marco Felsch <m.felsch@pengutronix.de>
Reviewed-by: Philipp Zabel <p.zabel@pengutronix.de>
Signed-off-by: Philipp Zabel <p.zabel@pengutronix.de>
drivers/gpu/drm/imx/parallel-display.c

index 6e55bf9..a831b5b 100644 (file)
@@ -320,6 +320,12 @@ static int imx_pd_bind(struct device *dev, struct device *master, void *data)
        imxpd = dev_get_drvdata(dev);
        memset(imxpd, 0, sizeof(*imxpd));
 
+       /* port@1 is the output port */
+       ret = drm_of_find_panel_or_bridge(np, 1, 0, &imxpd->panel,
+                                         &imxpd->next_bridge);
+       if (ret && ret != -ENODEV)
+               return ret;
+
        edidp = of_get_property(np, "edid", &imxpd->edid_len);
        if (edidp)
                imxpd->edid = kmemdup(edidp, imxpd->edid_len, GFP_KERNEL);
@@ -337,12 +343,6 @@ static int imx_pd_bind(struct device *dev, struct device *master, void *data)
        }
        imxpd->bus_format = bus_format;
 
-       /* port@1 is the output port */
-       ret = drm_of_find_panel_or_bridge(np, 1, 0, &imxpd->panel,
-                                         &imxpd->next_bridge);
-       if (ret && ret != -ENODEV)
-               return ret;
-
        imxpd->dev = dev;
 
        ret = imx_pd_register(drm, imxpd);