Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp667912ybv; Thu, 13 Feb 2020 07:28:14 -0800 (PST) X-Google-Smtp-Source: APXvYqzE8hSMe/GHFPBQkzikYP9yoFmlukhqbTLakeKqkFarljvHxlo4zSsM0hFFleuXRPLyp9SK X-Received: by 2002:a9d:ec7:: with SMTP id 65mr14113601otj.309.1581607693477; Thu, 13 Feb 2020 07:28:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581607693; cv=none; d=google.com; s=arc-20160816; b=BNIfbwSkZFK5WBov4i2qfVDcWTtTjT/1Wy2BnEq+4cfaaGwxg9unct3bhPZQrHv4/S SuUpYCucFKKAbu6YfzaHksuuRXNN53TmYOHpkRD/RkF7+uaJ3Tan1fY0d6D7ThWewHJ1 Zoy80GXgLftXJx6rsqJlreESQsY5fHoD+bmxnqinC3tdE4+uUgaGQGCSRpHrhE+zRNw6 YBaI9ELpVB6w+mrGVlupsoy0JQApmOPZKTzT5pEVz5/FAC/mG01mZEA1vHSuWnomGZ6R GY+rsyc8X/2qxjuK6xbQqPYkNQ6LSUrzDJz5iqyq+4ia2GljyYdsQlt5ByZHiAEXeqMd 90Wg== 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=N0WKbBgMUqKhOPvXCVo5taasI57U0dUIDh/tUfGrMh4=; b=mWF4XbLEqP4doQXdlX/MShtJ7GkDWWuJkebtgADoFoUoYd0u7+PANxw6Pa8Zwv8bvO Ryg65dafCfG6yApTUNHb6umrM1Ra8O+dmS+inPPrEs1Yh1k8TDYSTSr/9B02Rv35J8XA V4nq75PmC0ZmDM+C14ckKrkHe4OQmQZSV4XDOzQ/PJxJ3yyhTnjRq7G3ojLRYQQIvdkg Vtui4o9Huvr3WR21f6PvHjgEkTgkCmcFFtymgafTUgRiQpE0lcUG86FH0MP2ee3viH+/ /tqQ5+P4Er2Jied5A1WeEYYDKZ1WlZdlA/0p2s5PIRwIbD6IyiqsxHelsa63rxrAkL04 2BlA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=iNqGoTnr; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 17si1264072otv.149.2020.02.13.07.28.01; Thu, 13 Feb 2020 07:28:13 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=iNqGoTnr; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387514AbgBMP0Q (ORCPT + 99 others); Thu, 13 Feb 2020 10:26:16 -0500 Received: from mail.kernel.org ([198.145.29.99]:37932 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728209AbgBMPY1 (ORCPT ); Thu, 13 Feb 2020 10:24:27 -0500 Received: from localhost (unknown [104.132.1.104]) (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 8390820848; Thu, 13 Feb 2020 15:24:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1581607466; bh=LDwsagcPvncREaWRkphZJJ11vcxiGs5VBaB88r8yZBA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=iNqGoTnroNlka0HwiDU2MhteuulY6VKI7vG4CYBomnoN+h4YQ1pchM+yFN0wXVrGc WtyIfadIHhNZtJm/REe6DP1Vu8qEWuF41sg7GwdLSQFDcJfVSpHmVIe+Dmg+9b84vZ X0odJQSfmuVozJMJAElNbwLYm1Qzk5Po6zjWvouk= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Robert Milkowski , Trond Myklebust , Anna Schumaker Subject: [PATCH 4.9 102/116] NFSv4: try lease recovery on NFS4ERR_EXPIRED Date: Thu, 13 Feb 2020 07:20:46 -0800 Message-Id: <20200213151922.089222431@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200213151842.259660170@linuxfoundation.org> References: <20200213151842.259660170@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: Robert Milkowski commit 924491f2e476f7234d722b24171a4daff61bbe13 upstream. Currently, if an nfs server returns NFS4ERR_EXPIRED to open(), we return EIO to applications without even trying to recover. Fixes: 272289a3df72 ("NFSv4: nfs4_do_handle_exception() handle revoke/expiry of a single stateid") Signed-off-by: Robert Milkowski Reviewed-by: Trond Myklebust Signed-off-by: Anna Schumaker Signed-off-by: Greg Kroah-Hartman --- fs/nfs/nfs4proc.c | 5 +++++ 1 file changed, 5 insertions(+) --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c @@ -2916,6 +2916,11 @@ static struct nfs4_state *nfs4_do_open(s exception.retry = 1; continue; } + if (status == -NFS4ERR_EXPIRED) { + nfs4_schedule_lease_recovery(server->nfs_client); + exception.retry = 1; + continue; + } if (status == -EAGAIN) { /* We must have found a delegation */ exception.retry = 1;