Add exported vfs_hash_index() function, which calculates the canonical
pre-masked hash for the given vnode. The function assumes that vp->v_hash is initialized by the filesystem vnode instantiation function. At the moment, it is only done if filesystem uses vfs_hash_insert(). Reviewed by: peter Tested by: peter, pho (previous version) Sponsored by: The FreeBSD Foundation MFC after: 5 days
This commit is contained in:
parent
7b982bc831
commit
f6af8e375c
@ -54,6 +54,13 @@ vfs_hashinit(void *dummy __unused)
|
||||
/* Must be SI_ORDER_SECOND so desiredvnodes is available */
|
||||
SYSINIT(vfs_hash, SI_SUB_VFS, SI_ORDER_SECOND, vfs_hashinit, NULL);
|
||||
|
||||
u_int
|
||||
vfs_hash_index(struct vnode *vp)
|
||||
{
|
||||
|
||||
return (vp->v_hash + vp->v_mount->mnt_hashseed);
|
||||
}
|
||||
|
||||
static struct vfs_hash_head *
|
||||
vfs_hash_bucket(const struct mount *mp, u_int hash)
|
||||
{
|
||||
|
@ -812,6 +812,7 @@ int fifo_printinfo(struct vnode *);
|
||||
typedef int vfs_hash_cmp_t(struct vnode *vp, void *arg);
|
||||
|
||||
int vfs_hash_get(const struct mount *mp, u_int hash, int flags, struct thread *td, struct vnode **vpp, vfs_hash_cmp_t *fn, void *arg);
|
||||
u_int vfs_hash_index(struct vnode *vp);
|
||||
int vfs_hash_insert(struct vnode *vp, u_int hash, int flags, struct thread *td, struct vnode **vpp, vfs_hash_cmp_t *fn, void *arg);
|
||||
void vfs_hash_rehash(struct vnode *vp, u_int hash);
|
||||
void vfs_hash_remove(struct vnode *vp);
|
||||
|
Loading…
Reference in New Issue
Block a user