Commit 5f2ca76d authored by Marco Felsch's avatar Marco Felsch Committed by Philipp Zabel

drm/imx: parallel-display: fix edid memory leak

The edid memory is only freed if the component.unbind() is called. This
is okay if the parallel-display was bound but if the bind() fails we
leak the memory.
Signed-off-by: default avatarMarco Felsch <m.felsch@pengutronix.de>
[p.zabel@pengutronix.de: rebased, dropped now empty unbind()]
Signed-off-by: default avatarPhilipp Zabel <p.zabel@pengutronix.de>
parent 754e0b58
...@@ -325,7 +325,8 @@ static int imx_pd_bind(struct device *dev, struct device *master, void *data) ...@@ -325,7 +325,8 @@ static int imx_pd_bind(struct device *dev, struct device *master, void *data)
edidp = of_get_property(np, "edid", &imxpd->edid_len); edidp = of_get_property(np, "edid", &imxpd->edid_len);
if (edidp) if (edidp)
imxpd->edid = kmemdup(edidp, imxpd->edid_len, GFP_KERNEL); imxpd->edid = devm_kmemdup(dev, edidp, imxpd->edid_len,
GFP_KERNEL);
ret = of_property_read_string(np, "interface-pix-fmt", &fmt); ret = of_property_read_string(np, "interface-pix-fmt", &fmt);
if (!ret) { if (!ret) {
...@@ -349,17 +350,8 @@ static int imx_pd_bind(struct device *dev, struct device *master, void *data) ...@@ -349,17 +350,8 @@ static int imx_pd_bind(struct device *dev, struct device *master, void *data)
return 0; return 0;
} }
static void imx_pd_unbind(struct device *dev, struct device *master,
void *data)
{
struct imx_parallel_display *imxpd = dev_get_drvdata(dev);
kfree(imxpd->edid);
}
static const struct component_ops imx_pd_ops = { static const struct component_ops imx_pd_ops = {
.bind = imx_pd_bind, .bind = imx_pd_bind,
.unbind = imx_pd_unbind,
}; };
static int imx_pd_probe(struct platform_device *pdev) static int imx_pd_probe(struct platform_device *pdev)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment