On 30/11/17 12:14, Frank Rowand wrote: > On 11/29/17 14:17, Colin King wrote: >> From: Colin Ian King <colin.king@xxxxxxxxxxxxx> >> >> Currently if the call to of_resolve_phandles fails then then ovcs >> is not kfree'd on the error exit path. Rather than try and make >> the clean up exit path more convoluted, fix this by just kfree'ing >> ovcs at the point of error detection and exit via the same exit >> path. >> >> Detected by CoverityScan, CID#1462296 ("Resource Leak") >> >> Fixes: f948d6d8b792 ("of: overlay: avoid race condition between applying multiple overlays") >> Signed-off-by: Colin Ian King <colin.king@xxxxxxxxxxxxx> >> --- >> drivers/of/overlay.c | 4 +++- >> 1 file changed, 3 insertions(+), 1 deletion(-) >> >> diff --git a/drivers/of/overlay.c b/drivers/of/overlay.c >> index 53bc9e3f0b98..6c8efe7d8cbb 100644 >> --- a/drivers/of/overlay.c >> +++ b/drivers/of/overlay.c >> @@ -708,8 +708,10 @@ int of_overlay_apply(struct device_node *tree, int *ovcs_id) >> of_overlay_mutex_lock(); >> >> ret = of_resolve_phandles(tree); >> - if (ret) >> + if (ret) { >> + kfree(ovcs); >> goto err_overlay_unlock; >> + } >> >> mutex_lock(&of_mutex); >> >> > > False coverity warning. ovcs is freed in free_overlay_changeset(). > The error exit path is via err_overlay_unlock: err_overlay_unlock: of_overlay_mutex_unlock(); out: pr_debug("%s() err=%d\n", __func__, ret); return ret; ..so there is no call to free_overlay_changeset there. Colin -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html