Commit 36edb140 authored by Alexander Usyskin's avatar Alexander Usyskin Committed by Greg Kroah-Hartman

mei: allow clients on bus to communicate in remove callback

Introduce new intermediate state to allow the clients on the bus
to communicate with the firmware from the remove handler.
This is to enable to perform a clean shutdown.
Signed-off-by: default avatarAlexander Usyskin <alexander.usyskin@intel.com>
Signed-off-by: default avatarTomas Winkler <tomas.winkler@intel.com>
Link: https://lore.kernel.org/r/20210206144325.25682-2-tomas.winkler@intel.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 37f1cda4
...@@ -44,7 +44,8 @@ ssize_t __mei_cl_send(struct mei_cl *cl, u8 *buf, size_t length, u8 vtag, ...@@ -44,7 +44,8 @@ ssize_t __mei_cl_send(struct mei_cl *cl, u8 *buf, size_t length, u8 vtag,
bus = cl->dev; bus = cl->dev;
mutex_lock(&bus->device_lock); mutex_lock(&bus->device_lock);
if (bus->dev_state != MEI_DEV_ENABLED) { if (bus->dev_state != MEI_DEV_ENABLED &&
bus->dev_state != MEI_DEV_POWERING_DOWN) {
rets = -ENODEV; rets = -ENODEV;
goto out; goto out;
} }
...@@ -128,7 +129,8 @@ ssize_t __mei_cl_recv(struct mei_cl *cl, u8 *buf, size_t length, u8 *vtag, ...@@ -128,7 +129,8 @@ ssize_t __mei_cl_recv(struct mei_cl *cl, u8 *buf, size_t length, u8 *vtag,
bus = cl->dev; bus = cl->dev;
mutex_lock(&bus->device_lock); mutex_lock(&bus->device_lock);
if (bus->dev_state != MEI_DEV_ENABLED) { if (bus->dev_state != MEI_DEV_ENABLED &&
bus->dev_state != MEI_DEV_POWERING_DOWN) {
rets = -ENODEV; rets = -ENODEV;
goto out; goto out;
} }
......
...@@ -990,7 +990,8 @@ int mei_cl_disconnect(struct mei_cl *cl) ...@@ -990,7 +990,8 @@ int mei_cl_disconnect(struct mei_cl *cl)
return 0; return 0;
} }
if (dev->dev_state == MEI_DEV_POWER_DOWN) { if (dev->dev_state == MEI_DEV_POWERING_DOWN ||
dev->dev_state == MEI_DEV_POWER_DOWN) {
cl_dbg(dev, cl, "Device is powering down, don't bother with disconnection\n"); cl_dbg(dev, cl, "Device is powering down, don't bother with disconnection\n");
mei_cl_set_disconnected(cl); mei_cl_set_disconnected(cl);
return 0; return 0;
......
...@@ -303,9 +303,12 @@ void mei_stop(struct mei_device *dev) ...@@ -303,9 +303,12 @@ void mei_stop(struct mei_device *dev)
dev_dbg(dev->dev, "stopping the device.\n"); dev_dbg(dev->dev, "stopping the device.\n");
mutex_lock(&dev->device_lock); mutex_lock(&dev->device_lock);
mei_set_devstate(dev, MEI_DEV_POWER_DOWN); mei_set_devstate(dev, MEI_DEV_POWERING_DOWN);
mutex_unlock(&dev->device_lock); mutex_unlock(&dev->device_lock);
mei_cl_bus_remove_devices(dev); mei_cl_bus_remove_devices(dev);
mutex_lock(&dev->device_lock);
mei_set_devstate(dev, MEI_DEV_POWER_DOWN);
mutex_unlock(&dev->device_lock);
mei_cancel_work(dev); mei_cancel_work(dev);
......
...@@ -57,6 +57,7 @@ enum mei_dev_state { ...@@ -57,6 +57,7 @@ enum mei_dev_state {
MEI_DEV_ENABLED, MEI_DEV_ENABLED,
MEI_DEV_RESETTING, MEI_DEV_RESETTING,
MEI_DEV_DISABLED, MEI_DEV_DISABLED,
MEI_DEV_POWERING_DOWN,
MEI_DEV_POWER_DOWN, MEI_DEV_POWER_DOWN,
MEI_DEV_POWER_UP MEI_DEV_POWER_UP
}; };
......
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