From: "J. Bruce Fields" <bfields@fieldses.org>
To: Dai Ngo <dai.ngo@oracle.com>
Cc: chuck.lever@oracle.com, jlayton@redhat.com,
viro@zeniv.linux.org.uk, linux-nfs@vger.kernel.org,
linux-fsdevel@vger.kernel.org
Subject: Re: [PATCH RFC v21 0/7] NFSD: Initial implementation of NFSv4 Courteous Server
Date: Mon, 25 Apr 2022 12:17:22 -0400 [thread overview]
Message-ID: <20220425161722.GC24825@fieldses.org> (raw)
In-Reply-To: <1650739455-26096-1-git-send-email-dai.ngo@oracle.com>
On Sat, Apr 23, 2022 at 11:44:08AM -0700, Dai Ngo wrote:
> . Redo based on Bruce's suggestion by breaking the patches into functionality
> and also don't remove client record of courtesy client until the client is
> actually expired.
>
> 0001: courteous server framework with support for client with delegation only.
> This patch also handles COURTESY and EXPIRABLE reconnect.
> Conflict is resolved by set the courtesy client to EXPIRABLE, let the
> laundromat expires the client on next run and return NFS4ERR_DELAY
> OPEN request.
>
> 0002: add support for opens/share reservation to courteous server
> Conflict is resolved by set the courtesy client to EXPIRABLE, let the
> laundromat expires the client on next run and return NFS4ERR_DELAY
> OPEN request.
>
> 0003: mv creation/destroying laundromat workqueue from nfs4_state_start and
> and nfs4_state_shutdown_net to init_nfsd and exit_nfsd.
>
> 0004: fs/lock: add locks_owner_has_blockers helper
>
> 0005: add 2 callbacks to lock_manager_operations for resolving lock conflict
>
> 0006: add support for locks to courteous server, making use of 0004 and 0005
> Conflict is resolved by set the courtesy client to EXPIRABLE, run the
> laundromat immediately and wait for it to complete before returning to
> fs/lock code to recheck the lock list from the beginning.
>
> NOTE: I could not get queue_work/queue_delay_work and flush_workqueue
> to work as expected, I have to use mod_delayed_work and flush_workqueue
> to get the laundromat to run immediately.
Whoops, yes, my bad.
> When we check for blockers in nfs4_anylock_blockers, we do not check
> for client with delegation conflict. This is because we already hold
> the client_lock and to check for delegation conflict we need the state_lock
> and scanning the del_recall_lru list each time. So to avoid this overhead
> and potential deadlock (not sure about lock of ordering of these locks)
> we check and set the COURTESY client with delegation being recalled to
> EXPIRABLE later in nfs4_laundromat.
Hm, OK, I'll think about that, but sounds like it should work.
--b.
>
> 0007: show state of courtesy client in client info.
next prev parent reply other threads:[~2022-04-25 16:17 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-04-23 18:44 [PATCH RFC v21 0/7] NFSD: Initial implementation of NFSv4 Courteous Server Dai Ngo
2022-04-23 18:44 ` [PATCH RFC v21 1/7] NFSD: add courteous server support for thread with only delegation Dai Ngo
2022-04-25 18:51 ` J. Bruce Fields
2022-04-25 19:42 ` dai.ngo
2022-04-25 20:40 ` J. Bruce Fields
2022-04-25 21:35 ` dai.ngo
2022-04-25 21:48 ` J. Bruce Fields
2022-04-25 22:24 ` dai.ngo
2022-04-25 23:17 ` J. Bruce Fields
2022-04-23 18:44 ` [PATCH RFC v21 2/7] NFSD: add support for share reservation conflict to courteous server Dai Ngo
2022-04-25 13:15 ` Chuck Lever III
2022-04-25 15:08 ` dai.ngo
2022-04-23 18:44 ` [PATCH RFC v21 3/7] NFSD: move create/destroy of laundry_wq to init_nfsd and exit_nfsd Dai Ngo
2022-04-25 15:27 ` dai.ngo
2022-04-25 19:35 ` J. Bruce Fields
2022-04-25 19:46 ` dai.ngo
2022-04-23 18:44 ` [PATCH RFC v21 4/7] fs/lock: add helper locks_owner_has_blockers to check for blockers Dai Ngo
2022-04-23 18:44 ` [PATCH RFC v21 5/7] fs/lock: add 2 callbacks to lock_manager_operations to resolve conflict Dai Ngo
2022-04-23 18:44 ` [PATCH RFC v21 6/7] NFSD: add support for lock conflict to courteous server Dai Ngo
2022-04-23 18:44 ` [PATCH RFC v21 7/7] NFSD: Show state of courtesy client in client info Dai Ngo
2022-04-25 16:17 ` J. Bruce Fields [this message]
2022-04-25 17:53 ` [PATCH RFC v21 0/7] NFSD: Initial implementation of NFSv4 Courteous Server J. Bruce Fields
2022-04-25 18:16 ` dai.ngo
2022-04-25 19:19 ` J. Bruce Fields
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20220425161722.GC24825@fieldses.org \
--to=bfields@fieldses.org \
--cc=chuck.lever@oracle.com \
--cc=dai.ngo@oracle.com \
--cc=jlayton@redhat.com \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-nfs@vger.kernel.org \
--cc=viro@zeniv.linux.org.uk \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).