mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2026-05-22 10:37:35 +03:00
Remove zpl_revalidate: fix snapshot rollback
Open files, which aren't present in the snapshot, which is being roll-backed to, need to disappear from the visible VFS image of the dataset. Kernel provides d_drop function to drop invalid entry from the dcache, but inode can be referenced by dentry multiple dentries. The introduced zpl_d_drop_aliases function walks and invalidates all aliases of an inode. Reviewed-by: Ryan Moeller <ryan@iXsystems.com> Reviewed-by: Alexander Motin <mav@FreeBSD.org> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Pavel Snajdr <snajpa@snajpa.net> Closes #9600 Closes #14070
This commit is contained in:
committed by
Tony Hutter
parent
4c59fde1f5
commit
52e658edd7
@@ -61,4 +61,25 @@ d_clear_d_op(struct dentry *dentry)
|
||||
DCACHE_OP_REVALIDATE | DCACHE_OP_DELETE);
|
||||
}
|
||||
|
||||
/*
|
||||
* Walk and invalidate all dentry aliases of an inode
|
||||
* unless it's a mountpoint
|
||||
*/
|
||||
static inline void
|
||||
zpl_d_drop_aliases(struct inode *inode)
|
||||
{
|
||||
struct dentry *dentry;
|
||||
spin_lock(&inode->i_lock);
|
||||
#ifdef HAVE_DENTRY_D_U_ALIASES
|
||||
hlist_for_each_entry(dentry, &inode->i_dentry, d_u.d_alias) {
|
||||
#else
|
||||
hlist_for_each_entry(dentry, &inode->i_dentry, d_alias) {
|
||||
#endif
|
||||
if (!IS_ROOT(dentry) && !d_mountpoint(dentry) &&
|
||||
(dentry->d_inode == inode)) {
|
||||
d_drop(dentry);
|
||||
}
|
||||
}
|
||||
spin_unlock(&inode->i_lock);
|
||||
}
|
||||
#endif /* _ZFS_DCACHE_H */
|
||||
|
||||
Reference in New Issue
Block a user