Commit 22c2b77f authored by Matt Fleming's avatar Matt Fleming

fs/efivarfs: Fix double kfree() in error path

Julia reported that we may double free 'name' in efivarfs_callback(),
and that this bug was introduced by commit 0d22f33bc37c ("efi: Don't
use spinlocks for efi vars").

Move one of the kfree()s until after the point at which we know we are
definitely on the success path.
Reported-by: default avatarJulia Lawall <julia.lawall@lip6.fr>
Acked-by: default avatarJulia Lawall <julia.lawall@lip6.fr>
Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Cc: Sylvain Chouleur <sylvain.chouleur@gmail.com>
Signed-off-by: default avatarMatt Fleming <matt@codeblueprint.co.uk>
parent 0513fe1d
...@@ -157,14 +157,14 @@ static int efivarfs_callback(efi_char16_t *name16, efi_guid_t vendor, ...@@ -157,14 +157,14 @@ static int efivarfs_callback(efi_char16_t *name16, efi_guid_t vendor,
goto fail_inode; goto fail_inode;
} }
/* copied by the above to local storage in the dentry. */
kfree(name);
efivar_entry_size(entry, &size); efivar_entry_size(entry, &size);
err = efivar_entry_add(entry, &efivarfs_list); err = efivar_entry_add(entry, &efivarfs_list);
if (err) if (err)
goto fail_inode; goto fail_inode;
/* copied by the above to local storage in the dentry. */
kfree(name);
inode_lock(inode); inode_lock(inode);
inode->i_private = entry; inode->i_private = entry;
i_size_write(inode, size + sizeof(entry->var.Attributes)); i_size_write(inode, size + sizeof(entry->var.Attributes));
......
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