projects
/
project
/
netifd.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fix use-after-free on device free codepath due to recursion issues, and fix dev-...
[project/netifd.git]
/
device.c
diff --git
a/device.c
b/device.c
index
b2db291
..
91cb37a
100644
(file)
--- a/
device.c
+++ b/
device.c
@@
-68,12
+68,17
@@
static int set_device_state(struct device *dev, bool state)
static int
simple_device_set_state(struct device *dev, bool state)
{
static int
simple_device_set_state(struct device *dev, bool state)
{
+ struct device *pdev;
int ret = 0;
int ret = 0;
- if (state && !dev->parent.dev)
- dev->parent.dev = system_if_get_parent(dev);
+ pdev = dev->parent.dev;
+ if (state && !pdev) {
+ pdev = system_if_get_parent(dev);
+ if (pdev)
+ device_add_user(&dev->parent, pdev);
+ }
- if (
dev->parent.
dev) {
+ if (
p
dev) {
if (state)
ret = device_claim(&dev->parent);
else
if (state)
ret = device_claim(&dev->parent);
else
@@
-425,6
+430,14
@@
void device_add_user(struct device_user *dep, struct device *dev)
}
}
}
}
+void
+device_free(struct device *dev)
+{
+ __devlock++;
+ dev->type->free(dev);
+ __devlock--;
+}
+
static void
__device_free_unused(struct device *dev)
{
static void
__device_free_unused(struct device *dev)
{