diff options
| -rw-r--r-- | fs/sysfs/inode.c | 4 | 
1 files changed, 2 insertions, 2 deletions
| diff --git a/fs/sysfs/inode.c b/fs/sysfs/inode.c index 1a81ebce20e9..dbd820f9aeed 100644 --- a/fs/sysfs/inode.c +++ b/fs/sysfs/inode.c | |||
| @@ -215,7 +215,7 @@ static inline void orphan_all_buffers(struct inode *node) | |||
| 215 | struct sysfs_buffer_collection *set = node->i_private; | 215 | struct sysfs_buffer_collection *set = node->i_private; | 
| 216 | struct sysfs_buffer *buf; | 216 | struct sysfs_buffer *buf; | 
| 217 | 217 | ||
| 218 | mutex_lock(&node->i_mutex); | 218 | mutex_lock_nested(&node->i_mutex, I_MUTEX_CHILD); | 
| 219 | if (node->i_private) { | 219 | if (node->i_private) { | 
| 220 | list_for_each_entry(buf, &set->associates, associates) { | 220 | list_for_each_entry(buf, &set->associates, associates) { | 
| 221 | down(&buf->sem); | 221 | down(&buf->sem); | 
| @@ -272,7 +272,7 @@ int sysfs_hash_and_remove(struct dentry * dir, const char * name) | |||
| 272 | return -ENOENT; | 272 | return -ENOENT; | 
| 273 | 273 | ||
| 274 | parent_sd = dir->d_fsdata; | 274 | parent_sd = dir->d_fsdata; | 
| 275 | mutex_lock(&dir->d_inode->i_mutex); | 275 | mutex_lock_nested(&dir->d_inode->i_mutex, I_MUTEX_PARENT); | 
| 276 | list_for_each_entry(sd, &parent_sd->s_children, s_sibling) { | 276 | list_for_each_entry(sd, &parent_sd->s_children, s_sibling) { | 
| 277 | if (!sd->s_element) | 277 | if (!sd->s_element) | 
| 278 | continue; | 278 | continue; | 
