bus: mhi: host: Remove duplicate ee check for syserr
authorJeffrey Hugo <quic_jhugo@quicinc.com>
Mon, 10 Apr 2023 15:58:11 +0000 (09:58 -0600)
committerManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Mon, 10 Apr 2023 16:02:55 +0000 (21:32 +0530)
commitd469d9448a0f1a33c175d3280b1542fa0158ad7a
treef4351307ae3444219f91541be8285aba9bf636a5
parent4308c6878acfb58eda46483644b516abd732b6dd
bus: mhi: host: Remove duplicate ee check for syserr

If we detect a system error via intvec, we only process the syserr if the
current ee is different than the last observed ee.  The reason for this
check is to prevent bhie from running multiple times, but with the single
queue handling syserr, that is not possible.

The check can cause an issue with device recovery.  If PBL loads a bad SBL
via BHI, but that SBL hangs before notifying the host of an ee change,
then issuing soc_reset to crash the device and retry (after supplying a
fixed SBL) will not recover the device as the host will observe a PBL->PBL
transition and not process the syserr.  The device will be stuck until
either the driver is reloaded, or the host is rebooted.  Instead, remove
the check so that we can attempt to recover the device.

Fixes: ef2126c4e2ea ("bus: mhi: core: Process execution environment changes serially")
Cc: stable@vger.kernel.org
Signed-off-by: Jeffrey Hugo <quic_jhugo@quicinc.com>
Reviewed-by: Carl Vanderlip <quic_carlv@quicinc.com>
Reviewed-by: Manivannan Sadhasivam <mani@kernel.org>
Link: https://lore.kernel.org/r/1681142292-27571-2-git-send-email-quic_jhugo@quicinc.com
Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
drivers/bus/mhi/host/main.c