Commit 7521621e authored by Michal Suchanek's avatar Michal Suchanek Committed by Greg Kroah-Hartman

Do not disable driver and bus shutdown hook when class shutdown hook is set.

As seen from the implementation of the single class shutdown hook this
is not very sound design.

Rename the class shutdown hook to shutdown_pre to make it clear it runs
before the driver shutdown hook.
Signed-off-by: default avatarMichal Suchanek <msuchanek@suse.de>
Reviewed-by: default avatarJarkko Sakkinen <jarkko.sakkinen@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent df44d30d
...@@ -2796,11 +2796,12 @@ void device_shutdown(void) ...@@ -2796,11 +2796,12 @@ void device_shutdown(void)
pm_runtime_get_noresume(dev); pm_runtime_get_noresume(dev);
pm_runtime_barrier(dev); pm_runtime_barrier(dev);
if (dev->class && dev->class->shutdown) { if (dev->class && dev->class->shutdown_pre) {
if (initcall_debug) if (initcall_debug)
dev_info(dev, "shutdown\n"); dev_info(dev, "shutdown_pre\n");
dev->class->shutdown(dev); dev->class->shutdown_pre(dev);
} else if (dev->bus && dev->bus->shutdown) { }
if (dev->bus && dev->bus->shutdown) {
if (initcall_debug) if (initcall_debug)
dev_info(dev, "shutdown\n"); dev_info(dev, "shutdown\n");
dev->bus->shutdown(dev); dev->bus->shutdown(dev);
......
...@@ -164,14 +164,7 @@ static int tpm_class_shutdown(struct device *dev) ...@@ -164,14 +164,7 @@ static int tpm_class_shutdown(struct device *dev)
chip->ops = NULL; chip->ops = NULL;
up_write(&chip->ops_sem); up_write(&chip->ops_sem);
} }
/* Allow bus- and device-specific code to run. Note: since chip->ops
* is NULL, more-specific shutdown code will not be able to issue TPM
* commands.
*/
if (dev->bus && dev->bus->shutdown)
dev->bus->shutdown(dev);
else if (dev->driver && dev->driver->shutdown)
dev->driver->shutdown(dev);
return 0; return 0;
} }
...@@ -214,7 +207,7 @@ struct tpm_chip *tpm_chip_alloc(struct device *pdev, ...@@ -214,7 +207,7 @@ struct tpm_chip *tpm_chip_alloc(struct device *pdev,
device_initialize(&chip->devs); device_initialize(&chip->devs);
chip->dev.class = tpm_class; chip->dev.class = tpm_class;
chip->dev.class->shutdown = tpm_class_shutdown; chip->dev.class->shutdown_pre = tpm_class_shutdown;
chip->dev.release = tpm_dev_release; chip->dev.release = tpm_dev_release;
chip->dev.parent = pdev; chip->dev.parent = pdev;
chip->dev.groups = chip->groups; chip->dev.groups = chip->groups;
......
...@@ -375,7 +375,7 @@ int subsys_virtual_register(struct bus_type *subsys, ...@@ -375,7 +375,7 @@ int subsys_virtual_register(struct bus_type *subsys,
* @suspend: Used to put the device to sleep mode, usually to a low power * @suspend: Used to put the device to sleep mode, usually to a low power
* state. * state.
* @resume: Used to bring the device from the sleep mode. * @resume: Used to bring the device from the sleep mode.
* @shutdown: Called at shut-down time to quiesce the device. * @shutdown_pre: Called at shut-down time before driver shutdown.
* @ns_type: Callbacks so sysfs can detemine namespaces. * @ns_type: Callbacks so sysfs can detemine namespaces.
* @namespace: Namespace of the device belongs to this class. * @namespace: Namespace of the device belongs to this class.
* @pm: The default device power management operations of this class. * @pm: The default device power management operations of this class.
...@@ -404,7 +404,7 @@ struct class { ...@@ -404,7 +404,7 @@ struct class {
int (*suspend)(struct device *dev, pm_message_t state); int (*suspend)(struct device *dev, pm_message_t state);
int (*resume)(struct device *dev); int (*resume)(struct device *dev);
int (*shutdown)(struct device *dev); int (*shutdown_pre)(struct device *dev);
const struct kobj_ns_type_operations *ns_type; const struct kobj_ns_type_operations *ns_type;
const void *(*namespace)(struct device *dev); const void *(*namespace)(struct device *dev);
......
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