diff mbox series

[3/3] scsi: aic79xx: check for non-NULL scb in ahd_linux_queue_abort_cmd

Message ID 20250417042015.780823-4-bbelyavtsev@usergate.com
State Superseded
Headers show
Series aic79xx: Add some non-NULL checks | expand

Commit Message

Boris Belyavtsev April 17, 2025, 4:20 a.m. UTC
possible NULL pointer dereference in case hardware returns invalid scb
index

Found by Linux Verification Center (linuxtesting.org) with SVACE.

Signed-off-by: Boris Belyavtsev <bbelyavtsev@usergate.com>
---
 drivers/scsi/aic7xxx/aic79xx_osm.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

--
2.43.0

Настоящее электронное сообщение содержит информацию конфиденциального характера, а также может содержать коммерческую тайну ООО «Юзергейт» ИНН 5408308256 (UserGate). Неправомерное использование / раскрытие таковой информации запрещено. Если вы получили настоящее сообщение по ошибке, пожалуйста, свяжитесь с отправителем и удалите все копии сообщения. Настоящее сообщение не является офертой. Сведения о планируемых к разработке технологических решениях, ценовой политике, иные содержащиеся в сообщении сведения имеют исключительно информационных характер и не должны быть расценены в качестве основания для возникновения обязательств любого свойства.
diff mbox series

Patch

diff --git a/drivers/scsi/aic7xxx/aic79xx_osm.c b/drivers/scsi/aic7xxx/aic79xx_osm.c
index 17dfc3c72110..7d40c7d80411 100644
--- a/drivers/scsi/aic7xxx/aic79xx_osm.c
+++ b/drivers/scsi/aic7xxx/aic79xx_osm.c
@@ -2265,7 +2265,8 @@  ahd_linux_queue_abort_cmd(struct scsi_cmnd *cmd)
                 * and hope that the target responds.
                 */
                pending_scb = ahd_lookup_scb(ahd, active_scbptr);
-               pending_scb->flags |= SCB_RECOVERY_SCB|SCB_ABORT;
+               if (pending_scb == NULL)
+                       pending_scb->flags |= SCB_RECOVERY_SCB|SCB_ABORT;
                ahd_outb(ahd, MSG_OUT, HOST_MSG);
                ahd_outb(ahd, SCSISIGO, last_phase|ATNO);
                scmd_printk(KERN_INFO, cmd, "Device is active, asserting ATN\n");