Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp665102pxb; Wed, 24 Feb 2021 11:34:02 -0800 (PST) X-Google-Smtp-Source: ABdhPJwOTl9QBd7MVN4KMC71g1++lBKNoTfjfjNDybADv4QyrIHEsRePWrBgRzAuD7jwSkhol2oM X-Received: by 2002:a17:906:1447:: with SMTP id q7mr33887251ejc.27.1614195242484; Wed, 24 Feb 2021 11:34:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614195242; cv=none; d=google.com; s=arc-20160816; b=AIUa73j40Pjbs5iHrjWjRVNDDLqm6bzc5E9ZHKeES9FbYrJBDM+KlSy5Wf6GgVL6oe UbqYuzrIazX+AHPKLXF84INFoBp1JGdKUHu7UKezQp6KE7Ze93/+zaRrgq5Cvsi0d2+j 8qjYnePfv76eFw1aBZlPbKlckAngH/d/XTmq8fd09DoJgsrTHEZtcXixXGTCfrr/yYIy uKSAFhqJd3uN/xTdCBKPAYOmOzlagmopgj0/24ETTgqAdUqfKPiPitiOoQS7LJiTRcbC iuNUlxFuMjQQQr7RXrSsTtMW70auZYQTFSp8k4ymyDylfAq/DSXzfKYFyeFaPki3VfdQ bx5w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature:dkim-filter; bh=roWvfjCK0FPYROblIPqUILDQ5YNFF8q/h2VopAB96+8=; b=P44FBFY/rtNEI5JhnCUhep+ZSbPjskcsdHjlKBX6JMAlQ269iKDvs/esvRhLXlgiXR RBq/USRpDM66j2y5wheKHwTEpQKdahr+YK/FT01n3N7ky3TG/8+1jjjGCoomF3fnBRcu Bh3F3jPIDf5Jf0mIrsyD7WgkXPTxikl4/qPGOKPjgmPzDzpwDjId592sFBRaVibtm6Ud GO23YmvBZY9wnyQz2fGr084kiOgH8G4vW3VFL8gc8TVDEaCFY0JJ1JDvZDVx4tjs8CfE BGFmfc+8xs293OFfIEjNNp8MbUP7CfG5jl19ANqJvLvCXdh5YcTPUYXtGNpzjWPuRi9A xisw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@fieldses.org header.s=default header.b=0PfunF6n; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-nfs-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 k6si1828534ejz.420.2021.02.24.11.33.31; Wed, 24 Feb 2021 11:34:02 -0800 (PST) Received-SPF: pass (google.com: domain of linux-nfs-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=@fieldses.org header.s=default header.b=0PfunF6n; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234495AbhBXTcX (ORCPT + 99 others); Wed, 24 Feb 2021 14:32:23 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35922 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234302AbhBXTcQ (ORCPT ); Wed, 24 Feb 2021 14:32:16 -0500 Received: from fieldses.org (fieldses.org [IPv6:2600:3c00:e000:2f7::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 83447C061788 for ; Wed, 24 Feb 2021 11:31:36 -0800 (PST) Received: by fieldses.org (Postfix, from userid 2815) id 79E482501; Wed, 24 Feb 2021 14:31:35 -0500 (EST) DKIM-Filter: OpenDKIM Filter v2.11.0 fieldses.org 79E482501 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fieldses.org; s=default; t=1614195095; bh=roWvfjCK0FPYROblIPqUILDQ5YNFF8q/h2VopAB96+8=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=0PfunF6nAZumQn7SWHfyWWG6ailvi+RYm+oDuW0grm7BYSULiwxdmGffiCGBfJbdQ s+coU/40Z7yFHtCqXNGNCGxQiFXxaBPLOLPWct85VekOzqSlpiEhuDnJmqTI3yeKWt jRj638gKv88OkMIb0Hw41nfEbYDK2eRPP87Jd2ks= Date: Wed, 24 Feb 2021 14:31:35 -0500 From: "J. Bruce Fields" To: Chuck Lever Cc: linux-nfs@vger.kernel.org, Olga Kornievskaia Subject: Re: [PATCH] nfsd: don't abort copies early Message-ID: <20210224193135.GC11591@fieldses.org> References: <20210224183950.GB11591@fieldses.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210224183950.GB11591@fieldses.org> User-Agent: Mutt/1.5.21 (2010-09-15) Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org I confess I always have to stare at these comparisons for a minute to figure out which way they should go. And the logic in each of these loops is a little repetitive. Would it be worth creating a little state_expired() helper to work out the comparison and the new timeout? --b. diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c index 61552e89bd89..00fb3603c29e 100644 --- a/fs/nfsd/nfs4state.c +++ b/fs/nfsd/nfs4state.c @@ -5363,6 +5363,22 @@ static bool clients_still_reclaiming(struct nfsd_net *nn) return true; } +struct laundry_time { + time64_t cutoff; + time64_t new_timeo; +}; + +bool state_expired(struct laundry_time *lt, time64_t last_refresh) +{ + time64_t time_remaining; + + if (last_refresh > lt->cutoff) + return true; + time_remaining = lt->cutoff - last_refresh; + lt->new_timeo = min(lt->new_timeo, time_remaining); + return false; +} + static time64_t nfs4_laundromat(struct nfsd_net *nn) { @@ -5372,14 +5388,16 @@ nfs4_laundromat(struct nfsd_net *nn) struct nfs4_ol_stateid *stp; struct nfsd4_blocked_lock *nbl; struct list_head *pos, *next, reaplist; - time64_t cutoff = ktime_get_boottime_seconds() - nn->nfsd4_lease; - time64_t t, new_timeo = nn->nfsd4_lease; + struct laundry_time lt = { + .cutoff = ktime_get_boottime_seconds() - nn->nfsd4_lease, + .new_timeo = nn->nfsd4_lease + }; struct nfs4_cpntf_state *cps; copy_stateid_t *cps_t; int i; if (clients_still_reclaiming(nn)) { - new_timeo = 0; + lt.new_timeo = 0; goto out; } nfsd4_end_grace(nn); @@ -5389,7 +5407,7 @@ nfs4_laundromat(struct nfsd_net *nn) idr_for_each_entry(&nn->s2s_cp_stateids, cps_t, i) { cps = container_of(cps_t, struct nfs4_cpntf_state, cp_stateid); if (cps->cp_stateid.sc_type == NFS4_COPYNOTIFY_STID && - cps->cpntf_time < cutoff) + state_expired(<, cps->cpntf_time)) _free_cpntf_state_locked(nn, cps); } spin_unlock(&nn->s2s_cp_lock); @@ -5397,11 +5415,8 @@ nfs4_laundromat(struct nfsd_net *nn) spin_lock(&nn->client_lock); list_for_each_safe(pos, next, &nn->client_lru) { clp = list_entry(pos, struct nfs4_client, cl_lru); - if (clp->cl_time > cutoff) { - t = clp->cl_time - cutoff; - new_timeo = min(new_timeo, t); + if (!state_expired(<, clp->cl_time)) break; - } if (mark_client_expired_locked(clp)) { trace_nfsd_clid_expired(&clp->cl_clientid); continue; @@ -5418,11 +5433,8 @@ nfs4_laundromat(struct nfsd_net *nn) spin_lock(&state_lock); list_for_each_safe(pos, next, &nn->del_recall_lru) { dp = list_entry (pos, struct nfs4_delegation, dl_recall_lru); - if (dp->dl_time > cutoff) { - t = dp->dl_time - cutoff; - new_timeo = min(new_timeo, t); + if (!state_expired(<, clp->cl_time)) break; - } WARN_ON(!unhash_delegation_locked(dp)); list_add(&dp->dl_recall_lru, &reaplist); } @@ -5438,11 +5450,8 @@ nfs4_laundromat(struct nfsd_net *nn) while (!list_empty(&nn->close_lru)) { oo = list_first_entry(&nn->close_lru, struct nfs4_openowner, oo_close_lru); - if (oo->oo_time > cutoff) { - t = oo->oo_time - cutoff; - new_timeo = min(new_timeo, t); + if (!state_expired(<, oo->oo_time)) break; - } list_del_init(&oo->oo_close_lru); stp = oo->oo_last_closed_stid; oo->oo_last_closed_stid = NULL; @@ -5468,11 +5477,8 @@ nfs4_laundromat(struct nfsd_net *nn) while (!list_empty(&nn->blocked_locks_lru)) { nbl = list_first_entry(&nn->blocked_locks_lru, struct nfsd4_blocked_lock, nbl_lru); - if (nbl->nbl_time > cutoff) { - t = nbl->nbl_time - cutoff; - new_timeo = min(new_timeo, t); + if (!state_expired(<, oo->oo_time)) break; - } list_move(&nbl->nbl_lru, &reaplist); list_del_init(&nbl->nbl_list); } @@ -5485,8 +5491,7 @@ nfs4_laundromat(struct nfsd_net *nn) free_blocked_lock(nbl); } out: - new_timeo = max_t(time64_t, new_timeo, NFSD_LAUNDROMAT_MINTIMEOUT); - return new_timeo; + return max_t(time64_t, lt.new_timeo, NFSD_LAUNDROMAT_MINTIMEOUT); } static struct workqueue_struct *laundry_wq;