diff options
author | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2017-05-23 20:07:43 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2017-05-25 09:37:16 -0400 |
commit | ce57cba37f3721c21e46adf21c61292dfd7a9c04 (patch) | |
tree | 99d4afe300e4bbecb1dca266a22de72b2dafa472 | |
parent | 7f53de2069c801776f0f5d1a1d665324967a4fab (diff) |
firmware: vpd: avoid potential use-after-free when destroying section
We should not free info->key before we remove sysfs attribute that uses
this data as its name.
Fixes: 049a59db34eb ("firmware: Google VPD sysfs driver")
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Reviewed-by: Guenter Roeck <groeck@chromium.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r-- | drivers/firmware/google/vpd.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/firmware/google/vpd.c b/drivers/firmware/google/vpd.c index 23a24a6d02c2..db49c6f98153 100644 --- a/drivers/firmware/google/vpd.c +++ b/drivers/firmware/google/vpd.c | |||
@@ -158,8 +158,8 @@ static void vpd_section_attrib_destroy(struct vpd_section *sec) | |||
158 | struct vpd_attrib_info *temp; | 158 | struct vpd_attrib_info *temp; |
159 | 159 | ||
160 | list_for_each_entry_safe(info, temp, &sec->attribs, list) { | 160 | list_for_each_entry_safe(info, temp, &sec->attribs, list) { |
161 | kfree(info->key); | ||
162 | sysfs_remove_bin_file(sec->kobj, &info->bin_attr); | 161 | sysfs_remove_bin_file(sec->kobj, &info->bin_attr); |
162 | kfree(info->key); | ||
163 | kfree(info); | 163 | kfree(info); |
164 | } | 164 | } |
165 | } | 165 | } |