mirror of
https://github.com/torvalds/linux.git
synced 2024-11-11 14:42:24 +00:00
mei: me: avoid link reset on shutdown
Avoid lingering reset thread on driver shutdown. If the firmware is down during a shutdown flow do not initiate the link reset, simply disconnect all clients and let shutdown flow finish Signed-off-by: Alexander Usyskin <alexander.usyskin@intel.com> Signed-off-by: Tomas Winkler <tomas.winkler@intel.com> Link: https://lore.kernel.org/r/20220215080438.264876-2-tomas.winkler@intel.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
ccdf6f806f
commit
685867f40c
@ -2148,6 +2148,7 @@ void mei_cl_all_disconnect(struct mei_device *dev)
|
|||||||
list_for_each_entry(cl, &dev->file_list, link)
|
list_for_each_entry(cl, &dev->file_list, link)
|
||||||
mei_cl_set_disconnected(cl);
|
mei_cl_set_disconnected(cl);
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(mei_cl_all_disconnect);
|
||||||
|
|
||||||
static struct mei_cl *mei_cl_dma_map_find(struct mei_device *dev, u8 buffer_id)
|
static struct mei_cl *mei_cl_dma_map_find(struct mei_device *dev, u8 buffer_id)
|
||||||
{
|
{
|
||||||
|
@ -1257,7 +1257,11 @@ irqreturn_t mei_me_irq_thread_handler(int irq, void *dev_id)
|
|||||||
/* check if ME wants a reset */
|
/* check if ME wants a reset */
|
||||||
if (!mei_hw_is_ready(dev) && dev->dev_state != MEI_DEV_RESETTING) {
|
if (!mei_hw_is_ready(dev) && dev->dev_state != MEI_DEV_RESETTING) {
|
||||||
dev_warn(dev->dev, "FW not ready: resetting.\n");
|
dev_warn(dev->dev, "FW not ready: resetting.\n");
|
||||||
schedule_work(&dev->reset_work);
|
if (dev->dev_state == MEI_DEV_POWERING_DOWN ||
|
||||||
|
dev->dev_state == MEI_DEV_POWER_DOWN)
|
||||||
|
mei_cl_all_disconnect(dev);
|
||||||
|
else if (dev->dev_state != MEI_DEV_DISABLED)
|
||||||
|
schedule_work(&dev->reset_work);
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user