aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc
diff options
context:
space:
mode:
Diffstat (limited to 'arch/powerpc')
-rw-r--r--arch/powerpc/platforms/cell/spufs/inode.c20
1 files changed, 10 insertions, 10 deletions
diff --git a/arch/powerpc/platforms/cell/spufs/inode.c b/arch/powerpc/platforms/cell/spufs/inode.c
index 2c3ba4eb41c..45944012b06 100644
--- a/arch/powerpc/platforms/cell/spufs/inode.c
+++ b/arch/powerpc/platforms/cell/spufs/inode.c
@@ -162,10 +162,10 @@ static int spufs_rmdir(struct inode *root, struct dentry *dir_dentry)
162{ 162{
163 struct dentry *dentry, *tmp; 163 struct dentry *dentry, *tmp;
164 struct spu_context *ctx; 164 struct spu_context *ctx;
165 int err;
166 165
167 /* remove all entries */ 166 /* remove all entries */
168 err = 0; 167 down(&root->i_sem);
168 down(&dir_dentry->d_inode->i_sem);
169 list_for_each_entry_safe(dentry, tmp, &dir_dentry->d_subdirs, d_child) { 169 list_for_each_entry_safe(dentry, tmp, &dir_dentry->d_subdirs, d_child) {
170 spin_lock(&dcache_lock); 170 spin_lock(&dcache_lock);
171 spin_lock(&dentry->d_lock); 171 spin_lock(&dentry->d_lock);
@@ -181,16 +181,16 @@ static int spufs_rmdir(struct inode *root, struct dentry *dir_dentry)
181 spin_unlock(&dcache_lock); 181 spin_unlock(&dcache_lock);
182 } 182 }
183 } 183 }
184 shrink_dcache_parent(dir_dentry);
185 up(&dir_dentry->d_inode->i_sem);
186 up(&root->i_sem);
184 187
185 /* We have to give up the mm_struct */ 188 /* We have to give up the mm_struct */
186 ctx = SPUFS_I(dir_dentry->d_inode)->i_ctx; 189 ctx = SPUFS_I(dir_dentry->d_inode)->i_ctx;
187 spu_forget(ctx); 190 spu_forget(ctx);
188 191
189 if (!err) { 192 /* XXX Do we need to hold i_sem here ? */
190 shrink_dcache_parent(dir_dentry); 193 return simple_rmdir(root, dir_dentry);
191 err = simple_rmdir(root, dir_dentry);
192 }
193 return err;
194} 194}
195 195
196static int spufs_dir_close(struct inode *inode, struct file *file) 196static int spufs_dir_close(struct inode *inode, struct file *file)
@@ -201,10 +201,10 @@ static int spufs_dir_close(struct inode *inode, struct file *file)
201 201
202 dentry = file->f_dentry; 202 dentry = file->f_dentry;
203 dir = dentry->d_parent->d_inode; 203 dir = dentry->d_parent->d_inode;
204 down(&dir->i_sem); 204
205 ret = spufs_rmdir(dir, file->f_dentry); 205 ret = spufs_rmdir(dir, dentry);
206 WARN_ON(ret); 206 WARN_ON(ret);
207 up(&dir->i_sem); 207
208 return dcache_dir_close(inode, file); 208 return dcache_dir_close(inode, file);
209} 209}
210 210