bus: mhi: ep: Only send -ENOTCONN status if client driver is available
For the STOP and RESET commands, only send the channel disconnect status
-ENOTCONN if client driver is available. Otherwise, it will result in
null pointer dereference.
Cc: <stable@vger.kernel.org> # 5.19
Fixes: e827569062
("bus: mhi: ep: Add support for processing command rings")
Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Reviewed-by: Jeffrey Hugo <quic_jhugo@quicinc.com>
Link: https://lore.kernel.org/r/20221228161704.255268-4-manivannan.sadhasivam@linaro.org
Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
This commit is contained in:
Родитель
6de4941c02
Коммит
e6cebcc275
|
@ -203,9 +203,11 @@ static int mhi_ep_process_cmd_ring(struct mhi_ep_ring *ring, struct mhi_ring_ele
|
||||||
mhi_ep_mmio_disable_chdb(mhi_cntrl, ch_id);
|
mhi_ep_mmio_disable_chdb(mhi_cntrl, ch_id);
|
||||||
|
|
||||||
/* Send channel disconnect status to client drivers */
|
/* Send channel disconnect status to client drivers */
|
||||||
result.transaction_status = -ENOTCONN;
|
if (mhi_chan->xfer_cb) {
|
||||||
result.bytes_xferd = 0;
|
result.transaction_status = -ENOTCONN;
|
||||||
mhi_chan->xfer_cb(mhi_chan->mhi_dev, &result);
|
result.bytes_xferd = 0;
|
||||||
|
mhi_chan->xfer_cb(mhi_chan->mhi_dev, &result);
|
||||||
|
}
|
||||||
|
|
||||||
/* Set channel state to STOP */
|
/* Set channel state to STOP */
|
||||||
mhi_chan->state = MHI_CH_STATE_STOP;
|
mhi_chan->state = MHI_CH_STATE_STOP;
|
||||||
|
@ -235,9 +237,11 @@ static int mhi_ep_process_cmd_ring(struct mhi_ep_ring *ring, struct mhi_ring_ele
|
||||||
mhi_ep_ring_reset(mhi_cntrl, ch_ring);
|
mhi_ep_ring_reset(mhi_cntrl, ch_ring);
|
||||||
|
|
||||||
/* Send channel disconnect status to client driver */
|
/* Send channel disconnect status to client driver */
|
||||||
result.transaction_status = -ENOTCONN;
|
if (mhi_chan->xfer_cb) {
|
||||||
result.bytes_xferd = 0;
|
result.transaction_status = -ENOTCONN;
|
||||||
mhi_chan->xfer_cb(mhi_chan->mhi_dev, &result);
|
result.bytes_xferd = 0;
|
||||||
|
mhi_chan->xfer_cb(mhi_chan->mhi_dev, &result);
|
||||||
|
}
|
||||||
|
|
||||||
/* Set channel state to DISABLED */
|
/* Set channel state to DISABLED */
|
||||||
mhi_chan->state = MHI_CH_STATE_DISABLED;
|
mhi_chan->state = MHI_CH_STATE_DISABLED;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче