From patchwork Thu Apr 17 04:22:20 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Boris Belyavtsev X-Patchwork-Id: 882760 Received: from mx2.usergate.com (unknown [46.229.79.2]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 7C2F41DF972; Thu, 17 Apr 2025 04:58:04 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=46.229.79.2 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1744865889; cv=none; b=K6AYJxvvm8KHSNdCM1wUANW11/G1EjWWV7Zb27YgUnSj466Tt7Le9dmw3LawhjETQZU0lV4jZkWDGegox/bU4GLwC6J/hfiRHXrjI0iUrMTdRP6TknaPwwKQ5c9fiKZgoRNh0B7DJHqM13WxKxVARzXIUtC5etik8x33f6WIdNg= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1744865889; c=relaxed/simple; bh=Od0yWLlZbKBUa36Zzz8mWeVChx1sO/abmn2CfT7dci0=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=Y++HZVV93VqooYB331JtMsUPCVpSrewXou5jrtKspkhLZ4qUx/VXlxYpYBDuPDz9FkSYiRmPHMYc4xmt9ythbQR86gxc9Zyeuv2UFv0M9vKWWV/ovjlmSKIkfV3Hu58F6l11Rp4PaYHgZVEKn5zO6T8TNDvRTz/ND/F7NuxLhCM= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=usergate.com; spf=pass smtp.mailfrom=usergate.com; arc=none smtp.client-ip=46.229.79.2 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=usergate.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=usergate.com Received: from mail.usergate.com[192.168.90.36] by mx2.usergate.com with ESMTP id 6C2D10B8719048AC9B342C1F91B4F3E6; Thu, 17 Apr 2025 11:22:28 +0700 From: Boris Belyavtsev To: CC: ,,"Boris Belyavtsev" Subject: [PATCH 3/3] scsi: aic79xx: check for non-NULL scb in ahd_linux_queue_abort_cmd Date: Thu, 17 Apr 2025 11:22:20 +0700 Message-ID: <20250417042220.782230-4-bbelyavtsev@usergate.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250417042220.782230-1-bbelyavtsev@usergate.com> References: <20250417042220.782230-1-bbelyavtsev@usergate.com> Precedence: bulk X-Mailing-List: linux-scsi@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-ClientProxiedBy: ESLSRV-EXCH-01.esafeline.com (192.168.90.36) To nsk02-mbx01.esafeline.com (10.10.1.35) X-Message-Id: 35772813839640AFB2B07F5FF5F13D01 X-MailFileId: 52CED540A56D494C8055DFF53352ED72 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 --- drivers/scsi/aic7xxx/aic79xx_osm.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) -- 2.43.0 Настоящее электронное сообщение содержит информацию конфиденциального характера, а также может содержать коммерческую тайну ООО «Юзергейт» ИНН 5408308256 (UserGate). Неправомерное использование / раскрытие таковой информации запрещено. Если вы получили настоящее сообщение по ошибке, пожалуйста, свяжитесь с отправителем и удалите все копии сообщения. Настоящее сообщение не является офертой. Сведения о планируемых к разработке технологических решениях, ценовой политике, иные содержащиеся в сообщении сведения имеют исключительно информационных характер и не должны быть расценены в качестве основания для возникновения обязательств любого свойства. 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");