Commit 0d167101 authored by Michal Wilczynski's avatar Michal Wilczynski Committed by Rafael J. Wysocki

ACPI: bus: Set driver_data to NULL every time .add() fails

Most ACPI drivers set driver_data in their .add() callbacks, but usually
they don't clear it in the error code path.

Set driver_data to NULL in acpi_device_probe() to prevent stale pointers
from staying around.
Signed-off-by: default avatarMichal Wilczynski <michal.wilczynski@intel.com>
[ rjw: Subject and changelog edits ]
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent c542ce36
...@@ -1029,8 +1029,10 @@ static int acpi_device_probe(struct device *dev) ...@@ -1029,8 +1029,10 @@ static int acpi_device_probe(struct device *dev)
return -ENOSYS; return -ENOSYS;
ret = acpi_drv->ops.add(acpi_dev); ret = acpi_drv->ops.add(acpi_dev);
if (ret) if (ret) {
acpi_dev->driver_data = NULL;
return ret; return ret;
}
pr_debug("Driver [%s] successfully bound to device [%s]\n", pr_debug("Driver [%s] successfully bound to device [%s]\n",
acpi_drv->name, acpi_dev->pnp.bus_id); acpi_drv->name, acpi_dev->pnp.bus_id);
......
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