Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3311403pxf; Mon, 15 Mar 2021 06:55:59 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyO5dXSdsKbtY8Mg5Ylgm+zSbrFmHqzK7CDMSYnVlvkjkBMF8YNDTijzplZAYq/KTCBp5MY X-Received: by 2002:a05:6402:c96:: with SMTP id cm22mr30366526edb.128.1615816559642; Mon, 15 Mar 2021 06:55:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615816559; cv=none; d=google.com; s=arc-20160816; b=H6PEKz/Vvzq9j/57c7TKPRe4McikFUlwkG14rhoJOUThh9P5lgTTrAU/RD2lMeFkNg 8ZJUNIuXB0hfYEAdqAhyY9KNB+fYwR0/YhMxII5t8kTut/cK63vFFNUTmrWXk27lLhsg BqX3YIdhuSgeVVMAdgjYstW+q+2xr64jSH9Xt9I/tiW7Y4g+GY5QrhqtAR8bSV8dnb5a OnhSrH8rEASjhiYbVducnI431beBL6XgtvWQVMErhzvfrHmTezRLzutHMtjhlqZNP/gU FYuKi4d5gwTWZQqGusmzscP9cpfGL3BzdwgyMxj1HuPLezmvLcUoQG6oEuhYVTR5alJi SaEQ== 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=a+E+X0bE5VkzLA8Qo8sOSJz9a3td9jpwbdgqecaZAPs=; b=JI6AdXy9lBPkrbk+NYUWCbkIZULwZ1zJXqO1Z1I39KMO72F9K1SVmzZ+xVQKVFKNgZ kF+tIL7//1abqLYCepnYVyYImn/Kk0xJ6wXUY9JUnuNAaLXDgFmtFUnwI22NeS1IIiWC uV3roqojUeIMZcPYYsuoM63EvdozPtzIDkPPYUfTW2rRgl/Xyr/yFzJyGqWOXUeI+qGE rcLaOWiIFxZbghDJQFkH37bKckXcxd32icTnj7MReWeDyHQzPb5Uj+auE2uqD2n6Z9MR igGhJoBP81UDLK3JfO9BOj1xC+k0XbE159V50YxtxXV17tEOC4iP3sLKAKkBzXtXowx1 /cdw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=CHil81b1; 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 hp15si11062121ejc.548.2021.03.15.06.55.36; Mon, 15 Mar 2021 06:55:59 -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=CHil81b1; 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 S231338AbhCONyk (ORCPT + 99 others); Mon, 15 Mar 2021 09:54:40 -0400 Received: from mail.kernel.org ([198.145.29.99]:55870 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230317AbhCONxY (ORCPT ); Mon, 15 Mar 2021 09:53:24 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 872CA64EF5; Mon, 15 Mar 2021 13:53:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1615816404; bh=zhGzYpt1DWZXepqyUTty50aJRMtJnC4qZUGqNWv8MGE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=CHil81b1rkudT0x/oXooqSsn4Mr/he2CZD8hFhZkr21unINJyaxnTFvSylX9O83sk jyOZcpxjWGdSLNggJjS753VTDR1jO43ceYBoWzEN0mEm7FzllB0jK2gsWQhVU8QFbm czdTEkA5ghw5Jx3RvIJ0nVALz9sJrfhtwktUmo38= 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.4 24/75] scsi: libiscsi: Fix iscsi_prep_scsi_cmd_pdu() error handling Date: Mon, 15 Mar 2021 14:51:38 +0100 Message-Id: <20210315135209.039143393@linuxfoundation.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210315135208.252034256@linuxfoundation.org> References: <20210315135208.252034256@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 ecf3950c4438..18b8d86ef74b 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