mirror of
https://github.com/torvalds/linux.git
synced 2024-11-10 14:11:52 +00:00
mei: hbm: drop hbm responses on early shutdown
Drop HBM responses also in the early shutdown phase where the usual traffic is allowed. Extend the rule that drop HBM responses received during the shutdown phase by also in MEI_DEV_POWERING_DOWN state. This resolves the stall if the driver is stopping in the middle of the link init or link reset. Fixes:da3eb47c90
("mei: hbm: drop hbm responses on shutdown") Fixes:36edb1407c
("mei: allow clients on bus to communicate in remove callback") Cc: <stable@vger.kernel.org> # v5.12+ Signed-off-by: Alexander Usyskin <alexander.usyskin@intel.com> Signed-off-by: Tomas Winkler <tomas.winkler@intel.com> Link: https://lore.kernel.org/r/20211013074552.2278419-1-tomas.winkler@intel.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
ff53c4f6a6
commit
6d7163f2c4
@ -1298,7 +1298,8 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
|
||||
|
||||
if (dev->dev_state != MEI_DEV_INIT_CLIENTS ||
|
||||
dev->hbm_state != MEI_HBM_STARTING) {
|
||||
if (dev->dev_state == MEI_DEV_POWER_DOWN) {
|
||||
if (dev->dev_state == MEI_DEV_POWER_DOWN ||
|
||||
dev->dev_state == MEI_DEV_POWERING_DOWN) {
|
||||
dev_dbg(dev->dev, "hbm: start: on shutdown, ignoring\n");
|
||||
return 0;
|
||||
}
|
||||
@ -1381,7 +1382,8 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
|
||||
|
||||
if (dev->dev_state != MEI_DEV_INIT_CLIENTS ||
|
||||
dev->hbm_state != MEI_HBM_DR_SETUP) {
|
||||
if (dev->dev_state == MEI_DEV_POWER_DOWN) {
|
||||
if (dev->dev_state == MEI_DEV_POWER_DOWN ||
|
||||
dev->dev_state == MEI_DEV_POWERING_DOWN) {
|
||||
dev_dbg(dev->dev, "hbm: dma setup response: on shutdown, ignoring\n");
|
||||
return 0;
|
||||
}
|
||||
@ -1448,7 +1450,8 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
|
||||
|
||||
if (dev->dev_state != MEI_DEV_INIT_CLIENTS ||
|
||||
dev->hbm_state != MEI_HBM_CLIENT_PROPERTIES) {
|
||||
if (dev->dev_state == MEI_DEV_POWER_DOWN) {
|
||||
if (dev->dev_state == MEI_DEV_POWER_DOWN ||
|
||||
dev->dev_state == MEI_DEV_POWERING_DOWN) {
|
||||
dev_dbg(dev->dev, "hbm: properties response: on shutdown, ignoring\n");
|
||||
return 0;
|
||||
}
|
||||
@ -1490,7 +1493,8 @@ int mei_hbm_dispatch(struct mei_device *dev, struct mei_msg_hdr *hdr)
|
||||
|
||||
if (dev->dev_state != MEI_DEV_INIT_CLIENTS ||
|
||||
dev->hbm_state != MEI_HBM_ENUM_CLIENTS) {
|
||||
if (dev->dev_state == MEI_DEV_POWER_DOWN) {
|
||||
if (dev->dev_state == MEI_DEV_POWER_DOWN ||
|
||||
dev->dev_state == MEI_DEV_POWERING_DOWN) {
|
||||
dev_dbg(dev->dev, "hbm: enumeration response: on shutdown, ignoring\n");
|
||||
return 0;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user