diff options
author | David Howells <dhowells@redhat.com> | 2020-04-16 18:17:13 +0100 |
---|---|---|
committer | David Howells <dhowells@redhat.com> | 2020-04-24 16:33:32 +0100 |
commit | c4bfda16d1b40d1c5941c61b5aa336bdd2d9904a (patch) | |
tree | 4072cea58ebb9e178ee96fa53818e5b20669f2a6 /fs/afs/server.c | |
parent | 69cf3978f3ada4e54beae4ad44868b5627864884 (diff) | |
download | linux-c4bfda16d1b40d1c5941c61b5aa336bdd2d9904a.tar.gz linux-c4bfda16d1b40d1c5941c61b5aa336bdd2d9904a.tar.bz2 linux-c4bfda16d1b40d1c5941c61b5aa336bdd2d9904a.zip |
afs: Make record checking use TASK_UNINTERRUPTIBLE when appropriate
When an operation is meant to be done uninterruptibly (such as
FS.StoreData), we should not be allowing volume and server record checking
to be interrupted.
Fixes: d2ddc776a458 ("afs: Overhaul volume and server record caching and fileserver rotation")
Signed-off-by: David Howells <dhowells@redhat.com>
Diffstat (limited to 'fs/afs/server.c')
-rw-r--r-- | fs/afs/server.c | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/fs/afs/server.c b/fs/afs/server.c index b7f3cb2130ca..11b90ac7ea30 100644 --- a/fs/afs/server.c +++ b/fs/afs/server.c @@ -594,12 +594,9 @@ retry: } ret = wait_on_bit(&server->flags, AFS_SERVER_FL_UPDATING, - TASK_INTERRUPTIBLE); + (fc->flags & AFS_FS_CURSOR_INTR) ? + TASK_INTERRUPTIBLE : TASK_UNINTERRUPTIBLE); if (ret == -ERESTARTSYS) { - if (!(fc->flags & AFS_FS_CURSOR_INTR) && server->addresses) { - _leave(" = t [intr]"); - return true; - } fc->error = ret; _leave(" = f [intr]"); return false; |