]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/commit
pstore/ram: Fix failure-path memory leak in ramoops_init
authorKees Cook <keescook@chromium.org>
Fri, 28 Sep 2018 22:17:50 +0000 (15:17 -0700)
committerJuerg Haefliger <juergh@canonical.com>
Wed, 24 Jul 2019 01:53:06 +0000 (19:53 -0600)
commit85a7eeb008ee047fc9942b128b68aae6b341d545
tree6c57e07c84d8973d53d750b7cece677052aa5f8a
parent443e4eac9b05277bdfbfc7f5260b0cd846ca3473
pstore/ram: Fix failure-path memory leak in ramoops_init

BugLink: https://bugs.launchpad.net/bugs/1836426
commit bac6f6cda206ad7cbe0c73c35e494377ce9c4749 upstream.

As reported by nixiaoming, with some minor clarifications:

1) memory leak in ramoops_register_dummy():
   dummy_data = kzalloc(sizeof(*dummy_data), GFP_KERNEL);
   but no kfree() if platform_device_register_data() fails.

2) memory leak in ramoops_init():
   Missing platform_device_unregister(dummy) and kfree(dummy_data)
   if platform_driver_register(&ramoops_driver) fails.

I've clarified the purpose of ramoops_register_dummy(), and added a
common cleanup routine for all three failure paths to call.

Reported-by: nixiaoming <nixiaoming@huawei.com>
Cc: stable@vger.kernel.org
Cc: Anton Vorontsov <anton@enomsg.org>
Cc: Colin Cross <ccross@android.com>
Cc: Tony Luck <tony.luck@intel.com>
Cc: Joel Fernandes <joelaf@google.com>
Cc: Geliang Tang <geliangtang@gmail.com>
Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Kleber Sacilotto de Souza <kleber.souza@canonical.com>
fs/pstore/ram.c