Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2815791pxj; Mon, 14 Jun 2021 07:48:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxNQrVWa/IrIa8HGsE65hwf80Qj3KvcKKYkO3mQw6dXbtNCR7zacQwvlNIn184xdL5zJds1 X-Received: by 2002:a05:6402:1705:: with SMTP id y5mr17454603edu.232.1623682137436; Mon, 14 Jun 2021 07:48:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623682137; cv=none; d=google.com; s=arc-20160816; b=he45ZpFIhL8BMKjm+Z9vjceoPjsEltd1Fs7sVspQZINN/wzbMCCG2z7Jl8XcuACW5y x8EPcEyDzA5oZ4AeKCibDFMG6v1FBZI/h41JhZZDGseulsJrgdEwawlVT1VWVvlnyDBd j1ZJrTGbjciC69rE7BgZ40xdyANnxamFGoTii6fVBudUytlYjt2IE/GYxX1JLCTzUL0C 0xfSUqK+kkkp589HowaXaA5Vhl/psKkC1evKY33vAbTWb0PWMhyqUL0RXH3oyYyM6V10 EJSp++a06ilFcOAw9VPkdATllvmdXy8q5A1ZpcdWWStkyIdflv7FzMybWNZOERkI+iw9 gzVA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dkim-filter; bh=uy6c7lxflzJHHfLfVTZHoLcllD3BfzeAKR+/zbyDb38=; b=kNpEXAAu0yi/JERnqxQO8OHoDblCqA7poA2wxCVeGBI+7DLqym4iQRmNSY5AqKdG3j dWpghzQaI8oR9Udmf0ZOyC5lvUIVQI/3iaNrK5c94vfR88dPOVakKwcYSCb7P0jpLWqO hg7xc5/8mFeGbA2jaq0BZ2LaBH2LlVD9yw3zPOiF1+KrQCpd2fq3UxScUaUrfjBNFisW 0YYf7m2q7ZS1xabCSBrJuxGTXSNuTw34ezjC44TdA4NSR1gkfQliRivxXptfnTAQfe3d SbOMhFHX0v5T2OPR6KstuqK5wM7nFmR1iRhgJA2onygtDykRJ/dLjWjjgc0qxvSBdpnN eToA== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r2si12035131ejp.248.2021.06.14.07.48.28; Mon, 14 Jun 2021 07:48:57 -0700 (PDT) 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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232864AbhFNOuZ (ORCPT + 99 others); Mon, 14 Jun 2021 10:50:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60480 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232852AbhFNOuY (ORCPT ); Mon, 14 Jun 2021 10:50:24 -0400 Received: from fieldses.org (fieldses.org [IPv6:2600:3c00:e000:2f7::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 27C4CC061766 for ; Mon, 14 Jun 2021 07:48:21 -0700 (PDT) Received: by fieldses.org (Postfix, from userid 2815) id 4B811AB6; Mon, 14 Jun 2021 10:48:19 -0400 (EDT) DKIM-Filter: OpenDKIM Filter v2.11.0 fieldses.org 4B811AB6 From: "J. Bruce Fields" To: Trond Myklebust , Anna Schumaker Cc: daire@dneg.com, linux-nfs@vger.kernel.org, "J. Bruce Fields" Subject: [PATCH 1/3] nfs: don't atempt blocking locks on nfs reexports Date: Mon, 14 Jun 2021 10:48:16 -0400 Message-Id: <1623682098-13236-2-git-send-email-bfields@redhat.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1623682098-13236-1-git-send-email-bfields@redhat.com> References: <1623682098-13236-1-git-send-email-bfields@redhat.com> Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org From: "J. Bruce Fields" NFS implements blocking locks by blocking inside its lock method. In the reexport case, this blocks the nfs server thread, which could lead to deadlocks since an nfs server thread might be required to unlock the conflicting lock. It also causes a crash, since the nfs server thread assumes it can free the lock when its lm_notify lock callback is called. Ideal would be to make the nfs lock method return without blocking in this case, but for now it works just not to attempt blocking locks. The difference is just that the original client will have to poll (as it does in the v4.0 case) instead of getting a callback when the lock's available. Signed-off-by: J. Bruce Fields --- fs/nfs/export.c | 2 +- fs/nfsd/nfs4state.c | 8 ++++++-- include/linux/exportfs.h | 2 ++ 3 files changed, 9 insertions(+), 3 deletions(-) diff --git a/fs/nfs/export.c b/fs/nfs/export.c index 37a1a88df771..d772c20bbfd1 100644 --- a/fs/nfs/export.c +++ b/fs/nfs/export.c @@ -180,5 +180,5 @@ const struct export_operations nfs_export_ops = { .fetch_iversion = nfs_fetch_iversion, .flags = EXPORT_OP_NOWCC|EXPORT_OP_NOSUBTREECHK| EXPORT_OP_CLOSE_BEFORE_UNLINK|EXPORT_OP_REMOTE_FS| - EXPORT_OP_NOATOMIC_ATTR, + EXPORT_OP_NOATOMIC_ATTR|EXPORT_OP_SYNC_LOCKS, }; diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c index 980bd8903f84..00d98bbab2a6 100644 --- a/fs/nfsd/nfs4state.c +++ b/fs/nfsd/nfs4state.c @@ -6835,6 +6835,7 @@ nfsd4_lock(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate, struct nfsd4_blocked_lock *nbl = NULL; struct file_lock *file_lock = NULL; struct file_lock *conflock = NULL; + struct super_block *sb; __be32 status = 0; int lkflg; int err; @@ -6856,6 +6857,7 @@ nfsd4_lock(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate, dprintk("NFSD: nfsd4_lock: permission denied!\n"); return status; } + sb = cstate->current_fh.fh_dentry->d_sb; if (lock->lk_is_new) { if (nfsd4_has_session(cstate)) @@ -6904,7 +6906,8 @@ nfsd4_lock(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate, fp = lock_stp->st_stid.sc_file; switch (lock->lk_type) { case NFS4_READW_LT: - if (nfsd4_has_session(cstate)) + if (nfsd4_has_session(cstate) && + !(sb->s_export_op->flags & EXPORT_OP_SYNC_LOCKS)) fl_flags |= FL_SLEEP; fallthrough; case NFS4_READ_LT: @@ -6916,7 +6919,8 @@ nfsd4_lock(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate, fl_type = F_RDLCK; break; case NFS4_WRITEW_LT: - if (nfsd4_has_session(cstate)) + if (nfsd4_has_session(cstate) && + !(sb->s_export_op->flags & EXPORT_OP_SYNC_LOCKS)) fl_flags |= FL_SLEEP; fallthrough; case NFS4_WRITE_LT: diff --git a/include/linux/exportfs.h b/include/linux/exportfs.h index fe848901fcc3..3260fe714846 100644 --- a/include/linux/exportfs.h +++ b/include/linux/exportfs.h @@ -221,6 +221,8 @@ struct export_operations { #define EXPORT_OP_NOATOMIC_ATTR (0x10) /* Filesystem cannot supply atomic attribute updates */ +#define EXPORT_OP_SYNC_LOCKS (0x20) /* Filesystem can't do + asychronous blocking locks */ unsigned long flags; }; -- 2.31.1