Skip to content

Commit 7764c62

Browse files
committed
Merge tag 'devprop-5.13-rc8' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm
Pull device properties framework fix from Rafael Wysocki: "Fix a NULL pointer dereference introduced by a recent commit and occurring when device_remove_software_node() is used with a device that has never been registered (Heikki Krogerus)" * tag 'devprop-5.13-rc8' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: software node: Handle software node injection to an existing device properly
2 parents b960e01 + 5dca69e commit 7764c62

File tree

1 file changed

+12
-4
lines changed

1 file changed

+12
-4
lines changed

drivers/base/swnode.c

Lines changed: 12 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1045,7 +1045,15 @@ int device_add_software_node(struct device *dev, const struct software_node *nod
10451045
}
10461046

10471047
set_secondary_fwnode(dev, &swnode->fwnode);
1048-
software_node_notify(dev, KOBJ_ADD);
1048+
1049+
/*
1050+
* If the device has been fully registered by the time this function is
1051+
* called, software_node_notify() must be called separately so that the
1052+
* symlinks get created and the reference count of the node is kept in
1053+
* balance.
1054+
*/
1055+
if (device_is_registered(dev))
1056+
software_node_notify(dev, KOBJ_ADD);
10491057

10501058
return 0;
10511059
}
@@ -1065,7 +1073,8 @@ void device_remove_software_node(struct device *dev)
10651073
if (!swnode)
10661074
return;
10671075

1068-
software_node_notify(dev, KOBJ_REMOVE);
1076+
if (device_is_registered(dev))
1077+
software_node_notify(dev, KOBJ_REMOVE);
10691078
set_secondary_fwnode(dev, NULL);
10701079
kobject_put(&swnode->kobj);
10711080
}
@@ -1119,8 +1128,7 @@ int software_node_notify(struct device *dev, unsigned long action)
11191128

11201129
switch (action) {
11211130
case KOBJ_ADD:
1122-
ret = sysfs_create_link_nowarn(&dev->kobj, &swnode->kobj,
1123-
"software_node");
1131+
ret = sysfs_create_link(&dev->kobj, &swnode->kobj, "software_node");
11241132
if (ret)
11251133
break;
11261134

0 commit comments

Comments
 (0)