Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3524896pxf; Mon, 15 Mar 2021 11:29:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzw+c13p06kWgBZhUfcp0zTJNnCcgpbcuuxl5YgmbutizDYsFIUkMn3el2GqHy3VKrk+xEY X-Received: by 2002:a17:906:400b:: with SMTP id v11mr25065641ejj.194.1615832957743; Mon, 15 Mar 2021 11:29:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615832957; cv=none; d=google.com; s=arc-20160816; b=TcLLo4HJeK+WYLjTzycSmf1UXEtuFmy2s3mOkGelwNPha4CLEsu3b1/+3hjMyR5zDW Acor2ksKuz8tfOaQln+FZ6ECRtN9iUPaK/FMEovwkl8RDPag1MRF/Abgeo0MuVWFAJH/ NAazcy8xB3ATwtKrJ99I/V8uQbfwjMoN+7q0QGQ+yMYTFBts1vV2exTwE8JpzFwTFUPs FLlnhdd5xLYldKGQmpcxIqkipnEFG8P/BOkFwlW8+mewQCRxrMk5ytiM8U+IGc2TPcEv fWqAOe5EJRz9V2E3mr3Ru2mABCvx0d8QoxRwtI/8bcIYkaR7WCEHWhzCCz33p3Npfwuh /QgA== 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=6SSiE6DhOZ1MM46YGeFFWLeCSSTV22hv5goxJVAP55o=; b=e22c/1F41LuVLd101VYNsZToYxw0HC9j6BFeHFaly4QY6uXtnOSAvhtQr0MrOeU9Fp d61g29T4LNreJqelSNEE8X/PaR0CDjwDioCV1nYeeigquBy6oP6sgfrSxNYVAqcX6HZn uc1SkNsqQA6tNxjl633Up6KZjW/wOtHKyxp+H3kn4IwmZtPdkI82zK4CWKDMVIGf+wxe I+6DAGgdkrc3B6sUyj2LWdRua6Bs+R6ParwFy+3Mbm1W1/cWgfn/C7Yp5JH7SpRq8A21 awIYoemdNpvPyWTCzjXsBdcNLo0UaPU/Gzkpt9eci8hzWMynGAXGWzhde5O0nmObybBX UFiA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=ArxNHRge; 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 zj12si11230954ejb.508.2021.03.15.11.28.47; Mon, 15 Mar 2021 11:29:17 -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=ArxNHRge; 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 S239924AbhCOOdS (ORCPT + 99 others); Mon, 15 Mar 2021 10:33:18 -0400 Received: from mail.kernel.org ([198.145.29.99]:37476 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233239AbhCOOBN (ORCPT ); Mon, 15 Mar 2021 10:01:13 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 4117564F56; Mon, 15 Mar 2021 14:00:48 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1615816849; bh=5JkEQhZyy6tNcgw/Mn7IBu1WfEqYGJ4I9IjfJJSL07s=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ArxNHRge61MJcXrbgVFvMWzUIHg7/nWYDPeIu/4FMBefblVqarPR1RMC+/7vnW55T Q9ZzePbk0cdbQ7ARQpV9c7znioFFVW2T1SZC+M+/+fuDP68i2Hzc1iOYYSEcESOkMU E739oTvVIQvvCXYpL0HMhxfgkhNasqQzTDlNO0ls= 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 5.11 160/306] scsi: libiscsi: Fix iscsi_prep_scsi_cmd_pdu() error handling Date: Mon, 15 Mar 2021 14:53:43 +0100 Message-Id: <20210315135513.041699981@linuxfoundation.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210315135507.611436477@linuxfoundation.org> References: <20210315135507.611436477@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 1851015299b3..af40de7e51e7 100644 --- a/drivers/scsi/libiscsi.c +++ b/drivers/scsi/libiscsi.c @@ -1532,14 +1532,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