|
@@ -142,6 +142,15 @@ static struct inode *alloc_inode(struct super_block *sb)
|
|
return NULL;
|
|
return NULL;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ spin_lock_init(&inode->i_lock);
|
|
|
|
+ lockdep_set_class(&inode->i_lock, &sb->s_type->i_lock_key);
|
|
|
|
+
|
|
|
|
+ mutex_init(&inode->i_mutex);
|
|
|
|
+ lockdep_set_class(&inode->i_mutex, &sb->s_type->i_mutex_key);
|
|
|
|
+
|
|
|
|
+ init_rwsem(&inode->i_alloc_sem);
|
|
|
|
+ lockdep_set_class(&inode->i_alloc_sem, &sb->s_type->i_alloc_sem_key);
|
|
|
|
+
|
|
mapping->a_ops = &empty_aops;
|
|
mapping->a_ops = &empty_aops;
|
|
mapping->host = inode;
|
|
mapping->host = inode;
|
|
mapping->flags = 0;
|
|
mapping->flags = 0;
|
|
@@ -190,8 +199,6 @@ void inode_init_once(struct inode *inode)
|
|
INIT_HLIST_NODE(&inode->i_hash);
|
|
INIT_HLIST_NODE(&inode->i_hash);
|
|
INIT_LIST_HEAD(&inode->i_dentry);
|
|
INIT_LIST_HEAD(&inode->i_dentry);
|
|
INIT_LIST_HEAD(&inode->i_devices);
|
|
INIT_LIST_HEAD(&inode->i_devices);
|
|
- mutex_init(&inode->i_mutex);
|
|
|
|
- init_rwsem(&inode->i_alloc_sem);
|
|
|
|
INIT_RADIX_TREE(&inode->i_data.page_tree, GFP_ATOMIC);
|
|
INIT_RADIX_TREE(&inode->i_data.page_tree, GFP_ATOMIC);
|
|
rwlock_init(&inode->i_data.tree_lock);
|
|
rwlock_init(&inode->i_data.tree_lock);
|
|
spin_lock_init(&inode->i_data.i_mmap_lock);
|
|
spin_lock_init(&inode->i_data.i_mmap_lock);
|
|
@@ -199,7 +206,6 @@ void inode_init_once(struct inode *inode)
|
|
spin_lock_init(&inode->i_data.private_lock);
|
|
spin_lock_init(&inode->i_data.private_lock);
|
|
INIT_RAW_PRIO_TREE_ROOT(&inode->i_data.i_mmap);
|
|
INIT_RAW_PRIO_TREE_ROOT(&inode->i_data.i_mmap);
|
|
INIT_LIST_HEAD(&inode->i_data.i_mmap_nonlinear);
|
|
INIT_LIST_HEAD(&inode->i_data.i_mmap_nonlinear);
|
|
- spin_lock_init(&inode->i_lock);
|
|
|
|
i_size_ordered_init(inode);
|
|
i_size_ordered_init(inode);
|
|
#ifdef CONFIG_INOTIFY
|
|
#ifdef CONFIG_INOTIFY
|
|
INIT_LIST_HEAD(&inode->inotify_watches);
|
|
INIT_LIST_HEAD(&inode->inotify_watches);
|