Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3311664pxf; Mon, 15 Mar 2021 06:56:23 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxi+bVu6q2z1DnQZptqfMdEqe5FoxAs3vwBS5L0Ll+DH9amq8VHSmJJkuUTobrrPVtoe1pe X-Received: by 2002:a17:906:c45a:: with SMTP id ck26mr23296412ejb.125.1615816582948; Mon, 15 Mar 2021 06:56:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615816582; cv=none; d=google.com; s=arc-20160816; b=fi+kyuA7YMRCGxxEmr2PPemF0GRwzNmINQ6aekYVF0nR3qneIGPJWiOvMT6kRZzC4y GRdrhJuP840M16Wq5Rj75H29BqQWgTxk8GIfj6I+ObxuFC+XN5IdRB3nvCoEUqfadyKJ iVS8Il+hZOctM94RJS1sYaCnThi0ksd+KockeFhPRbLVcjEK0vcoQMSjGe+tV7Dt0Fsb cnofu7hV7tVyIqCQ29Zme6sPQKFXLnbDrhDUydqrpg+d18H7b7/Otcya7Rj28d0hA/8X WW4AxGaZhjoqQTnBwpByqvjR1jS2iJi2QWgo3p4XyqlDxOGTDp1pj3RKI/1dV5SCToQb jmKw== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=nIrkM1lxqo07g55KoMa3iuxoV3T5U9tdQOIniJVnzx8=; b=OrCX9ff4WSyUl7y2eXkXiWGKtz0DtD6MCDAoGhSE4k3U3WhHYz5TJ/i8D1cyIUFnsa Tw3LdlBKY9IpfEsNGuMZToXtW2wI8x4wJ2HkbTvmDuJMfdxmCv3CMTcoocTp1U/id1nB joUo4U5TxjmB7nZa7xJjlDKcaIrDWjB2iv2HqEWsmchIqaM52rkwwX1EaQTVUcsGvSDo /G/oPxjydnxvGkCf8lZaOqQJ6YFM8tzywJoo9MgRN04rsBjQY3I/26e613yPAO5G5+sj 5RVISpgLAFdXYSkfYd45sbg5npbrdtgHs7OUxumVXpxMPc326mQmknP6E4zl/F5fNpYB HbRQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=BVC99hjv; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b1si11122753ejb.401.2021.03.15.06.56.00; Mon, 15 Mar 2021 06:56:22 -0700 (PDT) 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=@linuxfoundation.org header.s=korg header.b=BVC99hjv; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231651AbhCONzC (ORCPT + 99 others); Mon, 15 Mar 2021 09:55:02 -0400 Received: from mail.kernel.org ([198.145.29.99]:55966 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230401AbhCONxd (ORCPT ); Mon, 15 Mar 2021 09:53:33 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 26E1764EEE; Mon, 15 Mar 2021 13:53:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1615816412; bh=rDi+aLYKX1dkvJ+6gS2pl1Wo7QcptLGlOELLIjJyx0g=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=BVC99hjv/kbkhj92q3e0OlCGtv7T3zcfM1m0w2hMTsEoa6gSXRsfPv4sa+dtPRLpu WRCVwwnWNL5ww35j23ikbKGIH6kJC0r34LAJMbvcXukljB+lF1CqPbHxUaCltXn6yt hdLCeiMYjbSRgSjw2+t6bbp0SV/kXZQ4okaopNW4= From: gregkh@linuxfoundation.org To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lee Duncan , Mike Christie , "Martin K. Petersen" , Sasha Levin Subject: [PATCH 4.9 24/78] scsi: libiscsi: Fix iscsi_prep_scsi_cmd_pdu() error handling Date: Mon, 15 Mar 2021 14:51:47 +0100 Message-Id: <20210315135212.852973829@linuxfoundation.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210315135212.060847074@linuxfoundation.org> References: <20210315135212.060847074@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Greg Kroah-Hartman 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 b9c924bb6e3d..50e2943c3337 100644 --- a/drivers/scsi/libiscsi.c +++ b/drivers/scsi/libiscsi.c @@ -1568,14 +1568,9 @@ static int iscsi_data_xmit(struct iscsi_conn *conn) } 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