Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp958179pxb; Wed, 3 Mar 2021 22:31:18 -0800 (PST) X-Google-Smtp-Source: ABdhPJyCCzUUBsKGDcv4oZtxKe+W1b0t0I9KrFCJoWOYwPUVvyYpqpiVW7vN3Sfc05iiGHuEoKsY X-Received: by 2002:a17:906:4d44:: with SMTP id b4mr2590195ejv.338.1614839478671; Wed, 03 Mar 2021 22:31:18 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614839478; cv=none; d=google.com; s=arc-20160816; b=jfJt2zMCBpT7Xhj1V6s5B3BCTNQo7aqIwh6hQIIMRbevlpyqXWSt5zVPpsB2MNOlO3 /URm4B77IF+0tvWXlrykVLthB5N1M9tpvQU1YD0DGZY4Oz10w6bjXAn47CvJOAhSDCJ7 DeOpBQ8d/8Hed+Jd8H9i9P9j+YNXxC50oBsI4e2/H6THrQpuvMjH5TkCB0CSRmrdXZJf OwZ+05LUZinqJtPhAPouCmtAULyC60fZzPCptqytT5RfgZ4IyImRAShRfhkJ1h4JaxcF J90NInifnxWMLq5KitwlGuPm61kaZESGkgYDoT7QynOkjX6RwogEE3aGXQliMdJrr8kl 0MxQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=HohJAJGZrDa8jqEZZrPyJx7LaI0A2bY5UexTk8H+kRw=; b=rX84PIbQ6VqkiSzliGYw+SbD2fSx0P+k8TV3m8ASaMNx/YkwImrzGgYWvOm+SX2qnK lHYm1sUSGR05kSUBHzfFyw3btCVhIGLtnpX+pxvbZgXXX5uR1lazxFbcCVJ/eIc+okRD 4BjplLdByP7fmoscue/cj4RMuaiWK2nHtu2c2K6QMEH7LjvchEoJEvR4pV374hH6zQA0 Et7wVl3Yi6yaOnaNYRGLJ+w0D+WtUviu0dCy09gbVv0iccHymYiISppBDQiW7swenR7F hdplsnKw/oh4kGa3K301GuE6mDmxhMuMyI4a8iZIyDeo5sM+9pcU+cqfCvwPuUaV7p2e zVdg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=C+1pYb82; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k5si16924284ejj.483.2021.03.03.22.30.56; Wed, 03 Mar 2021 22:31:18 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=C+1pYb82; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1579679AbhCBQ7f (ORCPT + 99 others); Tue, 2 Mar 2021 11:59:35 -0500 Received: from mail.kernel.org ([198.145.29.99]:46238 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1351370AbhCBOWL (ORCPT ); Tue, 2 Mar 2021 09:22:11 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 0343B64FC1; Tue, 2 Mar 2021 11:59:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1614686361; bh=S90zOVBYVNTBiDdDro2mlZD3KG7wvAcanIK0Pxeg7WU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=C+1pYb82Vmf6EsXYLMjYCmKy0pPXTw3IUOHZM/vHJWOUIQBMmnRDpeIs2XaDO6KPp h0McQ4R8v4yxpT7H2C/frOIIIljraA9JOej6oXquf0L2/0UgclWkz+eVnC4eGlnEp1 YL3a1uCdfk3OSW2slN2isQjLCSjjDxCPjaNB8dxhQMYGqVwFpdme9wh2tbmB0au8jR HdZ0qEPEjziWlzlk1tDbU5SwsLRS5zagSDlXJphYc7kSMU65XIDHj8z/GSxZmMiwTt KGDt+RUyy9QbUByH66b5/wMZV/khnKw3MeHnh8HMu+Wwud/qULtJ0kXV18s8wTQNNu N09ofAfO3BCEA== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Mike Christie , Lee Duncan , "Martin K . Petersen" , Sasha Levin , open-iscsi@googlegroups.com, linux-scsi@vger.kernel.org Subject: [PATCH AUTOSEL 4.14 13/13] scsi: libiscsi: Fix iscsi_prep_scsi_cmd_pdu() error handling Date: Tue, 2 Mar 2021 06:59:03 -0500 Message-Id: <20210302115903.63458-13-sashal@kernel.org> X-Mailer: git-send-email 2.30.1 In-Reply-To: <20210302115903.63458-1-sashal@kernel.org> References: <20210302115903.63458-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Mike Christie [ Upstream commit d28d48c699779973ab9a3bd0e5acfa112bd4fdef ] If iscsi_prep_scsi_cmd_pdu() fails we try to add it back to the cmdqueue, but we leave it partially setup. We don't have functions that can undo the pdu and init task setup. We only have cleanup_task which can clean up both parts. So this has us just fail the cmd and go through the standard cleanup routine and then have the SCSI midlayer retry it like is done when it fails in the queuecommand path. Link: https://lore.kernel.org/r/20210207044608.27585-2-michael.christie@oracle.com Reviewed-by: Lee Duncan Signed-off-by: Mike Christie Signed-off-by: Martin K. Petersen Signed-off-by: Sasha Levin --- drivers/scsi/libiscsi.c | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/drivers/scsi/libiscsi.c b/drivers/scsi/libiscsi.c index f7e1af90849b..fffaf9b3476d 100644 --- a/drivers/scsi/libiscsi.c +++ b/drivers/scsi/libiscsi.c @@ -1569,14 +1569,9 @@ check_mgmt: } rc = iscsi_prep_scsi_cmd_pdu(conn->task); if (rc) { - if (rc == -ENOMEM || rc == -EACCES) { - spin_lock_bh(&conn->taskqueuelock); - list_add_tail(&conn->task->running, - &conn->cmdqueue); - conn->task = NULL; - spin_unlock_bh(&conn->taskqueuelock); - goto done; - } else + if (rc == -ENOMEM || rc == -EACCES) + fail_scsi_task(conn->task, DID_IMM_RETRY); + else fail_scsi_task(conn->task, DID_ABORT); spin_lock_bh(&conn->taskqueuelock); continue; -- 2.30.1