Skip to content

Commit 61c347b

Browse files
committed
afs: Clear AFS_VNODE_CB_PROMISED if we detect callback expiry
Fix afs_validate() to clear AFS_VNODE_CB_PROMISED on a vnode if we detect any condition that causes the callback promise to be broken implicitly, including server break (cb_s_break), volume break (cb_v_break) or callback expiry. Fixes: ae3b736 ("afs: Fix validation/callback interaction") Reported-by: Marc Dionne <[email protected]> Signed-off-by: David Howells <[email protected]>
1 parent f642404 commit 61c347b

File tree

1 file changed

+13
-1
lines changed

1 file changed

+13
-1
lines changed

fs/afs/inode.c

Lines changed: 13 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -571,7 +571,7 @@ bool afs_check_validity(struct afs_vnode *vnode)
571571
struct afs_server *server;
572572
struct afs_volume *volume = vnode->volume;
573573
time64_t now = ktime_get_real_seconds();
574-
bool valid;
574+
bool valid, need_clear = false;
575575
unsigned int cb_break, cb_s_break, cb_v_break;
576576
int seq = 0;
577577

@@ -589,10 +589,13 @@ bool afs_check_validity(struct afs_vnode *vnode)
589589
vnode->cb_v_break != cb_v_break) {
590590
vnode->cb_s_break = cb_s_break;
591591
vnode->cb_v_break = cb_v_break;
592+
need_clear = true;
592593
valid = false;
593594
} else if (test_bit(AFS_VNODE_ZAP_DATA, &vnode->flags)) {
595+
need_clear = true;
594596
valid = false;
595597
} else if (vnode->cb_expires_at - 10 <= now) {
598+
need_clear = true;
596599
valid = false;
597600
} else {
598601
valid = true;
@@ -607,6 +610,15 @@ bool afs_check_validity(struct afs_vnode *vnode)
607610
} while (need_seqretry(&vnode->cb_lock, seq));
608611

609612
done_seqretry(&vnode->cb_lock, seq);
613+
614+
if (need_clear) {
615+
write_seqlock(&vnode->cb_lock);
616+
if (cb_break == vnode->cb_break)
617+
__afs_break_callback(vnode);
618+
write_sequnlock(&vnode->cb_lock);
619+
valid = false;
620+
}
621+
610622
return valid;
611623
}
612624

0 commit comments

Comments
 (0)