Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp640130ybz; Wed, 22 Apr 2020 05:18:23 -0700 (PDT) X-Google-Smtp-Source: APiQypLR+IsCqu5Rhq6/N44vV3oqyFgVsL+sK9w1FWKmgBPIbApvC06V1pswinbs1ot5RepsN/NY X-Received: by 2002:a17:906:340a:: with SMTP id c10mr26280778ejb.218.1587557903399; Wed, 22 Apr 2020 05:18:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587557903; cv=none; d=google.com; s=arc-20160816; b=nA0h3Eb4Aepc8CxO7VmdHJd08FkZ6Hb17dFtvHl+eDx2ZLe3CN+5G3wyf+M++xm21w ZCHzrnkIKm5xBBpwcrOurgV72pR7+byYobEduI2nLhP4vGfPYnA3Orf09sItXXJk6ldS u8hi8+CsVUgZPkeF/kxEmfnkBdaRHmsebgg9PnnMtLu7d2BOmrOc1026cHQixnEoJqUZ F0Nu5bTizwGSOBNfGY2CDy2HCmtmPzVw0/V4S+vjmoVlIwp8nli5lCtfZ/TNNnJnr6dn /eMp5IEG/Y9eaFA1go2Z1jV/UCa51PzXJZdOpUa66u2p5RQ7a6KJ0bPhSO7Lyv1WtxVA zCjQ== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=9kmCpqPlrNHcAMdeM9AR0EvGUgI+MS2fjMdAiQkwUNI=; b=MPZbVapeSrMkxgaaS1NinzY6XO/VuqelSqi+6tzkL0Cd9PLnq0Bc4OAF4qts1vEoVa gxtfwWjE5sqAsP8FbO9BeL5qInmplB4+yEbujvpdITo1qxYroUGMBZzVeb9jjaiZxx7i 1uOkYfNFPqLuyroy0AMDgoUQLSrKyK+xX51WcHE6KS6jYfXczWQU5rfG0AV3kKQoH0fc uoaxjQCAeJa1Oy6o5n2Y3bPS4yCebvG83GSGD2WXCSC//wJRPDMiGEylwQOtqXcEseMq ksR864EMlKEdRko3aPfiWjPbwiEWPXSDsNMIo8HvvFFcH1/E34lgaK6aH33dXvm7bqrE E2nA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=yJA1TTcL; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g16si3327624ejf.272.2020.04.22.05.17.59; Wed, 22 Apr 2020 05:18:23 -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=yJA1TTcL; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726690AbgDVKAz (ORCPT + 99 others); Wed, 22 Apr 2020 06:00:55 -0400 Received: from mail.kernel.org ([198.145.29.99]:47778 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726487AbgDVKA1 (ORCPT ); Wed, 22 Apr 2020 06:00:27 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 0854F20781; Wed, 22 Apr 2020 10:00:25 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587549626; bh=XlQgfUFUJP4k8L2WBx4a9KrW5lNWt6JVS5ikBhX0mIU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=yJA1TTcLb2Sken75hE8MMoc6vKMIg5i4kp3CbusHEv7TpW/Pbn1yIda1M3PAxGEJG W5A2ymQvJqgDfeiV74/rj3oNzforKdBE14VAGLzhNM4NqdhupqRS3dZjaM6t0LwNbC 3D+nFTD8ZdKZepMcQUzo5wNdxWvgBSDQbNsofk24= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jens Remus , Benjamin Block , Steffen Maier , "Martin K. Petersen" Subject: [PATCH 4.4 040/100] scsi: zfcp: fix missing erp_lock in port recovery trigger for point-to-point Date: Wed, 22 Apr 2020 11:56:10 +0200 Message-Id: <20200422095029.732406211@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200422095022.476101261@linuxfoundation.org> References: <20200422095022.476101261@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Steffen Maier commit 819732be9fea728623e1ed84eba28def7384ad1f upstream. v2.6.27 commit cc8c282963bd ("[SCSI] zfcp: Automatically attach remote ports") introduced zfcp automatic port scan. Before that, the user had to use the sysfs attribute "port_add" of an FCP device (adapter) to add and open remote (target) ports, even for the remote peer port in point-to-point topology. That code path did a proper port open recovery trigger taking the erp_lock. Since above commit, a new helper function zfcp_erp_open_ptp_port() performed an UNlocked port open recovery trigger. This can race with other parallel recovery triggers. In zfcp_erp_action_enqueue() this could corrupt e.g. adapter->erp_total_count or adapter->erp_ready_head. As already found for fabric topology in v4.17 commit fa89adba1941 ("scsi: zfcp: fix infinite iteration on ERP ready list"), there was an endless loop during tracing of rport (un)block. A subsequent v4.18 commit 9e156c54ace3 ("scsi: zfcp: assert that the ERP lock is held when tracing a recovery trigger") introduced a lockdep assertion for that case. As a side effect, that lockdep assertion now uncovered the unlocked code path for PtP. It is from within an adapter ERP action: zfcp_erp_strategy[1479] intentionally DROPs erp lock around zfcp_erp_strategy_do_action() zfcp_erp_strategy_do_action[1441] NO erp lock zfcp_erp_adapter_strategy[876] NO erp lock zfcp_erp_adapter_strategy_open[855] NO erp lock zfcp_erp_adapter_strategy_open_fsf[806]NO erp lock zfcp_erp_adapter_strat_fsf_xconf[772] erp lock only around zfcp_erp_action_to_running(), BUT *_not_* around zfcp_erp_enqueue_ptp_port() zfcp_erp_enqueue_ptp_port[728] BUG: *_not_* taking erp lock _zfcp_erp_port_reopen[432] assumes to be called with erp lock zfcp_erp_action_enqueue[314] assumes to be called with erp lock zfcp_dbf_rec_trig[288] _checks_ to be called with erp lock: lockdep_assert_held(&adapter->erp_lock); It causes the following lockdep warning: WARNING: CPU: 2 PID: 775 at drivers/s390/scsi/zfcp_dbf.c:288 zfcp_dbf_rec_trig+0x16a/0x188 no locks held by zfcperp0.0.17c0/775. Fix this by using the proper locked recovery trigger helper function. Link: https://lore.kernel.org/r/20200312174505.51294-2-maier@linux.ibm.com Fixes: cc8c282963bd ("[SCSI] zfcp: Automatically attach remote ports") Cc: #v2.6.27+ Reviewed-by: Jens Remus Reviewed-by: Benjamin Block Signed-off-by: Steffen Maier Signed-off-by: Martin K. Petersen Signed-off-by: Greg Kroah-Hartman --- drivers/s390/scsi/zfcp_erp.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) --- a/drivers/s390/scsi/zfcp_erp.c +++ b/drivers/s390/scsi/zfcp_erp.c @@ -747,7 +747,7 @@ static void zfcp_erp_enqueue_ptp_port(st adapter->peer_d_id); if (IS_ERR(port)) /* error or port already attached */ return; - _zfcp_erp_port_reopen(port, 0, "ereptp1"); + zfcp_erp_port_reopen(port, 0, "ereptp1"); } static int zfcp_erp_adapter_strat_fsf_xconf(struct zfcp_erp_action *erp_action)