Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1760945ybz; Sat, 18 Apr 2020 07:57:41 -0700 (PDT) X-Google-Smtp-Source: APiQypKYaR21Vbil/r39jMWuOIdoMR712CwLbHNDihmSt9WBp3VMnPt15AIRsXQcsnPjo1Bi7tYW X-Received: by 2002:a17:907:20f7:: with SMTP id rh23mr7907541ejb.71.1587221861272; Sat, 18 Apr 2020 07:57:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587221861; cv=none; d=google.com; s=arc-20160816; b=AYmoi49lvCe6AEeJQ8FUHNdgjwiOa2PrfkN6O0mcHn7hm8VHTTEu/AHAtAQpGEjIdM 5tprDMC+5r/OMJUzKBT6PATK/nwUvaQNnE6aIM1y1xK0YGu3D/nGmBQqUmoshyYvElmg i/cbEh131ZvGU5htqgSq5p23eI4Tw9Ae5TSpsMMj9cwXy8FSj3WyBhMhTGLhdKGk0hnX sQkr0Da0trM64e+jehTtDrY3T1cbsrkcpQqqoYoUAP7F9MuV1XmDVyajxBI4ZTKiFyWm DAfnjCBWgJgh/6FhXOcaqi5sfYBzKEllFrr9IXkQqQxv+fv2EDC+WcT+OpJgcOOBfBuB P64w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=wovx1rfLb39v9HLVAictmr0GxTmvEMp3pdIwhqt0VjA=; b=EMiqGP2dLCKOVBGqqz+FFwhlTDlgFXc891juHkWhDMpcbjuUQXzQ3dNJmnUGJYJlQH fLvLzNfTESYFfCOcILnr5ZqfDz6xHEZW7jqsT2jJiVkasCxerVtg3UrJTl5OrJV4gXgi /uyRZyIFPlh/S+rW8T26Lpz5BbuHgClwEyarON3nl0gZPo6EZkPV5NRFsABNMf8hkV21 SxVuWBXzgWqkvyIQ5OG0r/+7/0bYs6NTXPguWfpFkyENXag0WqaKXThmecXpuy5w/AeM HigVwf0xE8gKpdKomb/TAVboYEjNOk7VIfR5hmfmxOowNz9H6jtrpek58yW1c5FJYVsM uYzg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=G90+x+DR; 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 x68si14042692ede.282.2020.04.18.07.57.18; Sat, 18 Apr 2020 07:57:41 -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=@kernel.org header.s=default header.b=G90+x+DR; 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 S1727853AbgDROlR (ORCPT + 99 others); Sat, 18 Apr 2020 10:41:17 -0400 Received: from mail.kernel.org ([198.145.29.99]:49922 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727773AbgDROlJ (ORCPT ); Sat, 18 Apr 2020 10:41:09 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id B9D9E22245; Sat, 18 Apr 2020 14:41:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587220868; bh=jLQjo7sVMrW78vbiNqRpHkEm3YVGC3+qwmWujhDT2RA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=G90+x+DRTgSAPiMWvId7MNTvLfEz+KhgwO33G5Q7CrOnKvCn4/PbhzgyZV0DP8cfB FoCrJPh+YlIW6PgK0cOCqafzXMZ23UOwUQ7RyTIBEDzp6LgbLHE+dHOEaSd7CoXGhi uk4q7WWgRGLHdGHv/BHcnNEHSiZDX/Ws88pJ1+Ks= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Wu Bo , Lee Duncan , "Martin K . Petersen" , Sasha Levin , open-iscsi@googlegroups.com, linux-scsi@vger.kernel.org Subject: [PATCH AUTOSEL 5.4 17/78] scsi: iscsi: Report unbind session event when the target has been removed Date: Sat, 18 Apr 2020 10:39:46 -0400 Message-Id: <20200418144047.9013-17-sashal@kernel.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20200418144047.9013-1-sashal@kernel.org> References: <20200418144047.9013-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Wu Bo [ Upstream commit 13e60d3ba287d96eeaf1deaadba51f71578119a3 ] If the daemon is restarted or crashes while logging out of a session, the unbind session event sent by the kernel is not processed and is lost. When the daemon starts again, the session can't be unbound because the daemon is waiting for the event message. However, the kernel has already logged out and the event will not be resent. When iscsid restart is complete, logout session reports error: Logging out of session [sid: 6, target: iqn.xxxxx, portal: xx.xx.xx.xx,3260] iscsiadm: Could not logout of [sid: 6, target: iscsiadm -m node iqn.xxxxx, portal: xx.xx.xx.xx,3260]. iscsiadm: initiator reported error (9 - internal error) iscsiadm: Could not logout of all requested sessions Make sure the unbind event is emitted. [mkp: commit desc and applied by hand since patch was mangled] Link: https://lore.kernel.org/r/4eab1771-2cb3-8e79-b31c-923652340e99@huawei.com Reviewed-by: Lee Duncan Signed-off-by: Wu Bo Signed-off-by: Martin K. Petersen Signed-off-by: Sasha Levin --- drivers/scsi/scsi_transport_iscsi.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/scsi/scsi_transport_iscsi.c b/drivers/scsi/scsi_transport_iscsi.c index 271afea654e2b..a5c78b38d3022 100644 --- a/drivers/scsi/scsi_transport_iscsi.c +++ b/drivers/scsi/scsi_transport_iscsi.c @@ -2012,7 +2012,7 @@ static void __iscsi_unbind_session(struct work_struct *work) if (session->target_id == ISCSI_MAX_TARGET) { spin_unlock_irqrestore(&session->lock, flags); mutex_unlock(&ihost->mutex); - return; + goto unbind_session_exit; } target_id = session->target_id; @@ -2024,6 +2024,8 @@ static void __iscsi_unbind_session(struct work_struct *work) ida_simple_remove(&iscsi_sess_ida, target_id); scsi_remove_target(&session->dev); + +unbind_session_exit: iscsi_session_event(session, ISCSI_KEVENT_UNBIND_SESSION); ISCSI_DBG_TRANS_SESSION(session, "Completed target removal\n"); } -- 2.20.1