Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3518698pxf; Mon, 15 Mar 2021 11:20:21 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwc1MnclWtZHhkVPWqW9X+htF9d2nSygli91Fme+zdprfbAbuH04kNCgE57slh3O/2l/aNm X-Received: by 2002:a05:6402:2cd:: with SMTP id b13mr31546334edx.55.1615832421705; Mon, 15 Mar 2021 11:20:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615832421; cv=none; d=google.com; s=arc-20160816; b=JGZmmo1RrHDHjWU0gThlF6gn0kD8k+AV4I9rIWiyhf7yXyH4EVkXZ6EXBP0VUuiqIX ug/CQL4zOSTwpekvwdbvs+BVLLECwopX0nWzsUNYgQvIJGuyGB+dOXjBTgUokVrmAGMM BSEOr2LVRZ/n7WteEt6NlLIUIkbWlTBVPhgmnRenieZikdjX/ArzLDdd3CzbWZ6LdKWG hbeTc84iCEjJWqnzx9hpNifwUkneMjZJW1/dN5z31EjuFZo1PUr2gDrS9W/sXQWmQs3d NCq1Dmv6NI1F+2Lyzrrr1FGqcT3BWqgtk1B8HqhJN/nPYd9xcRrGgCs+rSn/rpliJtgV gFmg== 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=kMiOJfFuvgAUStk1LvP1Bom66gqp4fZhf0ZqLAfBOvw=; b=GzLSWrMH/mHWuz8gC2Kc8yAfLgS0oQBd9omN1lgVrDzpzthCmNbcucTlhgC1oqnpNl EW2druiKzqAn+OLm8Uz3i1pe+GhmLs9zZ+3fEG04XqEK+ELI5ncf8Gj6s1463i/et6Zr BHcrOAruslBSxgQu0PTJ4XfvRyt6/rEN8pBW+KfzbC+HfvvuFIoY4zS5+z84nxwnodWF 6delrJYETwlJnYXO5dwJBTxabRO/xd9o5FAZDxcAwgnS7dDa4bdz6u5xcwiU1rxgSD4e ScZ7+28VcK70zU3E0aOoLnoFuDo2EgFSOaaYd1VgmP3pYgR8/rvw4duNSGk0W30mGXwH HuUw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=yJ+rSNKm; 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 e1si4893620ejx.431.2021.03.15.11.19.59; Mon, 15 Mar 2021 11:20:21 -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=yJ+rSNKm; 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 S237155AbhCOORY (ORCPT + 99 others); Mon, 15 Mar 2021 10:17:24 -0400 Received: from mail.kernel.org ([198.145.29.99]:37582 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232726AbhCON7h (ORCPT ); Mon, 15 Mar 2021 09:59:37 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 4264364F41; Mon, 15 Mar 2021 13:59:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1615816756; bh=h9uepS0IuP/s0KWqGb2pQv8XGPCsQvzxjE0h1JXIjD0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=yJ+rSNKmp28cUofSXBYb5sXZI6fnjLGpNnf/eIZSMOjJC1V7gkUcIPIbvDxvrGcRJ TUsR52aR7WOoImX3Rqr++o4Is7AQt65fmSl/z8WJl69Ngfz2DcHAeprPYOFu7EbxQh qMq2Liy6vj5h+EroaO/2QCtUPZkqXDQN8YiqAPPI= 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.14 40/95] scsi: libiscsi: Fix iscsi_prep_scsi_cmd_pdu() error handling Date: Mon, 15 Mar 2021 14:57:10 +0100 Message-Id: <20210315135741.589419079@linuxfoundation.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210315135740.245494252@linuxfoundation.org> References: <20210315135740.245494252@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 f180d1b4553c..21efe27ebfcc 100644 --- a/drivers/scsi/libiscsi.c +++ b/drivers/scsi/libiscsi.c @@ -1569,14 +1569,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