Commit 9a4e7849 authored by Russell King's avatar Russell King

component: fix crash on x86_64 with hda audio drivers

Maarten reports that the addition of releasing match data to the
component helper results in a general protection fault on x86_64.

This is caused by the devm resources being freed in reverse order
to their allocation, which caused a use-after-free of the match
array.

Switch the match array to be a more conventional kmalloc/kfree()
affair, explicitly freeing it along with the parent match data
structure.
Reported-by: default avatarMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
Fixes: ce657b1c ("component: add support for releasing match data")
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent ce657b1c
...@@ -206,6 +206,8 @@ static void component_match_release(struct device *master, ...@@ -206,6 +206,8 @@ static void component_match_release(struct device *master,
if (mc->release) if (mc->release)
mc->release(master, mc->data); mc->release(master, mc->data);
} }
kfree(match->compare);
} }
static void devm_component_match_release(struct device *dev, void *res) static void devm_component_match_release(struct device *dev, void *res)
...@@ -221,14 +223,14 @@ static int component_match_realloc(struct device *dev, ...@@ -221,14 +223,14 @@ static int component_match_realloc(struct device *dev,
if (match->alloc == num) if (match->alloc == num)
return 0; return 0;
new = devm_kmalloc_array(dev, num, sizeof(*new), GFP_KERNEL); new = kmalloc_array(num, sizeof(*new), GFP_KERNEL);
if (!new) if (!new)
return -ENOMEM; return -ENOMEM;
if (match->compare) { if (match->compare) {
memcpy(new, match->compare, sizeof(*new) * memcpy(new, match->compare, sizeof(*new) *
min(match->num, num)); min(match->num, num));
devm_kfree(dev, match->compare); kfree(match->compare);
} }
match->compare = new; match->compare = new;
match->alloc = num; match->alloc = num;
......
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