[PATCH 6/9] erofs-utils: add inode hash helper
Gao Xiang
hsiangkao at linux.alibaba.com
Thu Jul 27 16:12:11 AEST 2023
On 2023/7/27 12:57, Jingbo Xu wrote:
> Add erofs_insert_ihash() helper inserting inode into inode hash table,
> and erofs_cleanup_ihash() helper cleaning up inode hash table.
>
> Also add prototypes of erofs_iget() and erofs_iget_by_nid() in the
> header file.
>
> Signed-off-by: Jingbo Xu <jefflexu at linux.alibaba.com>
> ---
> include/erofs/inode.h | 4 ++++
> lib/inode.c | 22 +++++++++++++++++++---
> 2 files changed, 23 insertions(+), 3 deletions(-)
>
> diff --git a/include/erofs/inode.h b/include/erofs/inode.h
> index e8a5670..aba2a94 100644
> --- a/include/erofs/inode.h
> +++ b/include/erofs/inode.h
> @@ -25,6 +25,10 @@ u32 erofs_new_encode_dev(dev_t dev);
> unsigned char erofs_mode_to_ftype(umode_t mode);
> unsigned char erofs_ftype_to_dtype(unsigned int filetype);
> void erofs_inode_manager_init(void);
> +void erofs_insert_ihash(struct erofs_inode *inode, dev_t dev, ino_t ino);
> +void erofs_cleanup_ihash(void);
> +struct erofs_inode *erofs_iget(dev_t dev, ino_t ino);
> +struct erofs_inode *erofs_iget_by_nid(erofs_nid_t nid);
> unsigned int erofs_iput(struct erofs_inode *inode);
> erofs_nid_t erofs_lookupnid(struct erofs_inode *inode);
> struct erofs_dentry *erofs_d_alloc(struct erofs_inode *parent,
> diff --git a/lib/inode.c b/lib/inode.c
> index d54f84f..d82ea95 100644
> --- a/lib/inode.c
> +++ b/lib/inode.c
> @@ -75,6 +75,24 @@ void erofs_inode_manager_init(void)
> init_list_head(&inode_hashtable[i]);
> }
>
> +void erofs_insert_ihash(struct erofs_inode *inode, dev_t dev, ino_t ino)
> +{
> + list_add(&inode->i_hash,
> + &inode_hashtable[(ino ^ dev) % NR_INODE_HASHTABLE]);
> +}
> +
> +void erofs_cleanup_ihash(void)
> +{
> + unsigned int i;
> + struct erofs_inode *inode, *n;
> +
> + for (i = 0; i < NR_INODE_HASHTABLE; ++i) {
> + list_for_each_entry_safe(inode, n, &inode_hashtable[i], i_hash)
Why are there still inodes here? I think we should just check:
DBG_BUGON(!list_empty(&inode_hashtable[i]));
Thanks,
Gao Xiang
More information about the Linux-erofs
mailing list