summaryrefslogtreecommitdiffstats
path: root/init/init_task.c
diff options
context:
space:
mode:
authorGeert Uytterhoeven <geert+renesas@glider.be>2017-12-05 16:27:02 +0100
committerRob Herring <robh@kernel.org>2017-12-06 16:04:36 -0600
commit1352f09b4cc4f9dce386620b118401738bbf0d5f (patch)
tree698e66155eb0e01ddf6acfa8cce1e7433db71dff /init/init_task.c
parent3bcca2c271259ab2c3b539f0afa17d0043854c01 (diff)
downloadblackbird-op-linux-1352f09b4cc4f9dce386620b118401738bbf0d5f.tar.gz
blackbird-op-linux-1352f09b4cc4f9dce386620b118401738bbf0d5f.zip
of: overlay: Fix memory leak in of_overlay_apply() error path
If of_resolve_phandles() fails, free_overlay_changeset() is called in the error path. However, that function returns early if the list hasn't been initialized yet, before freeing the object. Explicitly calling kfree() instead would solve that issue. However, that complicates matter, by having to consider which of two different methods to use to dispose of the same object. Hence make free_overlay_changeset() consider initialization state of the different parts of the object, making it always safe to call (once!) to dispose of a (partially) initialized overlay_changeset: - Only destroy the changeset if the list was initialized, - Make init_overlay_changeset() store the ID in ovcs->id on success, to avoid calling idr_remove() with an error value or an already released ID. Reported-by: Colin King <colin.king@canonical.com> Fixes: f948d6d8b792bb90 ("of: overlay: avoid race condition between applying multiple overlays") Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be> Reviewed-by: Frank Rowand <frank.rowand@sony.com> Signed-off-by: Rob Herring <robh@kernel.org>
Diffstat (limited to 'init/init_task.c')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud