aboutsummaryrefslogtreecommitdiffstats
path: root/fs/adfs/super.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/adfs/super.c')
-rw-r--r--fs/adfs/super.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/fs/adfs/super.c b/fs/adfs/super.c
index 959dbff2d42d..2d7954049fbe 100644
--- a/fs/adfs/super.c
+++ b/fs/adfs/super.c
@@ -240,11 +240,18 @@ static struct inode *adfs_alloc_inode(struct super_block *sb)
240 return &ei->vfs_inode; 240 return &ei->vfs_inode;
241} 241}
242 242
243static void adfs_destroy_inode(struct inode *inode) 243static void adfs_i_callback(struct rcu_head *head)
244{ 244{
245 struct inode *inode = container_of(head, struct inode, i_rcu);
246 INIT_LIST_HEAD(&inode->i_dentry);
245 kmem_cache_free(adfs_inode_cachep, ADFS_I(inode)); 247 kmem_cache_free(adfs_inode_cachep, ADFS_I(inode));
246} 248}
247 249
250static void adfs_destroy_inode(struct inode *inode)
251{
252 call_rcu(&inode->i_rcu, adfs_i_callback);
253}
254
248static void init_once(void *foo) 255static void init_once(void *foo)
249{ 256{
250 struct adfs_inode_info *ei = (struct adfs_inode_info *) foo; 257 struct adfs_inode_info *ei = (struct adfs_inode_info *) foo;
@@ -466,6 +473,7 @@ static int adfs_fill_super(struct super_block *sb, void *data, int silent)
466 asb->s_namelen = ADFS_F_NAME_LEN; 473 asb->s_namelen = ADFS_F_NAME_LEN;
467 } 474 }
468 475
476 sb->s_d_op = &adfs_dentry_operations;
469 root = adfs_iget(sb, &root_obj); 477 root = adfs_iget(sb, &root_obj);
470 sb->s_root = d_alloc_root(root); 478 sb->s_root = d_alloc_root(root);
471 if (!sb->s_root) { 479 if (!sb->s_root) {
@@ -476,8 +484,7 @@ static int adfs_fill_super(struct super_block *sb, void *data, int silent)
476 kfree(asb->s_map); 484 kfree(asb->s_map);
477 adfs_error(sb, "get root inode failed\n"); 485 adfs_error(sb, "get root inode failed\n");
478 goto error; 486 goto error;
479 } else 487 }
480 sb->s_root->d_op = &adfs_dentry_operations;
481 unlock_kernel(); 488 unlock_kernel();
482 return 0; 489 return 0;
483 490