diff options
Diffstat (limited to 'fs/hpfs/namei.c')
-rw-r--r-- | fs/hpfs/namei.c | 53 |
1 files changed, 7 insertions, 46 deletions
diff --git a/fs/hpfs/namei.c b/fs/hpfs/namei.c index d5f8c8a1902..8c9f9153719 100644 --- a/fs/hpfs/namei.c +++ b/fs/hpfs/namei.c | |||
@@ -29,7 +29,7 @@ static int hpfs_mkdir(struct inode *dir, struct dentry *dentry, int mode) | |||
29 | fnode = hpfs_alloc_fnode(dir->i_sb, hpfs_i(dir)->i_dno, &fno, &bh); | 29 | fnode = hpfs_alloc_fnode(dir->i_sb, hpfs_i(dir)->i_dno, &fno, &bh); |
30 | if (!fnode) | 30 | if (!fnode) |
31 | goto bail; | 31 | goto bail; |
32 | dnode = hpfs_alloc_dnode(dir->i_sb, fno, &dno, &qbh0, 1); | 32 | dnode = hpfs_alloc_dnode(dir->i_sb, fno, &dno, &qbh0); |
33 | if (!dnode) | 33 | if (!dnode) |
34 | goto bail1; | 34 | goto bail1; |
35 | memset(&dee, 0, sizeof dee); | 35 | memset(&dee, 0, sizeof dee); |
@@ -60,8 +60,7 @@ static int hpfs_mkdir(struct inode *dir, struct dentry *dentry, int mode) | |||
60 | if (dee.read_only) | 60 | if (dee.read_only) |
61 | result->i_mode &= ~0222; | 61 | result->i_mode &= ~0222; |
62 | 62 | ||
63 | mutex_lock(&hpfs_i(dir)->i_mutex); | 63 | r = hpfs_add_dirent(dir, name, len, &dee); |
64 | r = hpfs_add_dirent(dir, name, len, &dee, 0); | ||
65 | if (r == 1) | 64 | if (r == 1) |
66 | goto bail3; | 65 | goto bail3; |
67 | if (r == -1) { | 66 | if (r == -1) { |
@@ -101,11 +100,9 @@ static int hpfs_mkdir(struct inode *dir, struct dentry *dentry, int mode) | |||
101 | hpfs_write_inode_nolock(result); | 100 | hpfs_write_inode_nolock(result); |
102 | } | 101 | } |
103 | d_instantiate(dentry, result); | 102 | d_instantiate(dentry, result); |
104 | mutex_unlock(&hpfs_i(dir)->i_mutex); | ||
105 | hpfs_unlock(dir->i_sb); | 103 | hpfs_unlock(dir->i_sb); |
106 | return 0; | 104 | return 0; |
107 | bail3: | 105 | bail3: |
108 | mutex_unlock(&hpfs_i(dir)->i_mutex); | ||
109 | iput(result); | 106 | iput(result); |
110 | bail2: | 107 | bail2: |
111 | hpfs_brelse4(&qbh0); | 108 | hpfs_brelse4(&qbh0); |
@@ -168,8 +165,7 @@ static int hpfs_create(struct inode *dir, struct dentry *dentry, int mode, struc | |||
168 | result->i_data.a_ops = &hpfs_aops; | 165 | result->i_data.a_ops = &hpfs_aops; |
169 | hpfs_i(result)->mmu_private = 0; | 166 | hpfs_i(result)->mmu_private = 0; |
170 | 167 | ||
171 | mutex_lock(&hpfs_i(dir)->i_mutex); | 168 | r = hpfs_add_dirent(dir, name, len, &dee); |
172 | r = hpfs_add_dirent(dir, name, len, &dee, 0); | ||
173 | if (r == 1) | 169 | if (r == 1) |
174 | goto bail2; | 170 | goto bail2; |
175 | if (r == -1) { | 171 | if (r == -1) { |
@@ -193,12 +189,10 @@ static int hpfs_create(struct inode *dir, struct dentry *dentry, int mode, struc | |||
193 | hpfs_write_inode_nolock(result); | 189 | hpfs_write_inode_nolock(result); |
194 | } | 190 | } |
195 | d_instantiate(dentry, result); | 191 | d_instantiate(dentry, result); |
196 | mutex_unlock(&hpfs_i(dir)->i_mutex); | ||
197 | hpfs_unlock(dir->i_sb); | 192 | hpfs_unlock(dir->i_sb); |
198 | return 0; | 193 | return 0; |
199 | 194 | ||
200 | bail2: | 195 | bail2: |
201 | mutex_unlock(&hpfs_i(dir)->i_mutex); | ||
202 | iput(result); | 196 | iput(result); |
203 | bail1: | 197 | bail1: |
204 | brelse(bh); | 198 | brelse(bh); |
@@ -254,8 +248,7 @@ static int hpfs_mknod(struct inode *dir, struct dentry *dentry, int mode, dev_t | |||
254 | result->i_blocks = 1; | 248 | result->i_blocks = 1; |
255 | init_special_inode(result, mode, rdev); | 249 | init_special_inode(result, mode, rdev); |
256 | 250 | ||
257 | mutex_lock(&hpfs_i(dir)->i_mutex); | 251 | r = hpfs_add_dirent(dir, name, len, &dee); |
258 | r = hpfs_add_dirent(dir, name, len, &dee, 0); | ||
259 | if (r == 1) | 252 | if (r == 1) |
260 | goto bail2; | 253 | goto bail2; |
261 | if (r == -1) { | 254 | if (r == -1) { |
@@ -271,12 +264,10 @@ static int hpfs_mknod(struct inode *dir, struct dentry *dentry, int mode, dev_t | |||
271 | 264 | ||
272 | hpfs_write_inode_nolock(result); | 265 | hpfs_write_inode_nolock(result); |
273 | d_instantiate(dentry, result); | 266 | d_instantiate(dentry, result); |
274 | mutex_unlock(&hpfs_i(dir)->i_mutex); | ||
275 | brelse(bh); | 267 | brelse(bh); |
276 | hpfs_unlock(dir->i_sb); | 268 | hpfs_unlock(dir->i_sb); |
277 | return 0; | 269 | return 0; |
278 | bail2: | 270 | bail2: |
279 | mutex_unlock(&hpfs_i(dir)->i_mutex); | ||
280 | iput(result); | 271 | iput(result); |
281 | bail1: | 272 | bail1: |
282 | brelse(bh); | 273 | brelse(bh); |
@@ -333,8 +324,7 @@ static int hpfs_symlink(struct inode *dir, struct dentry *dentry, const char *sy | |||
333 | result->i_op = &page_symlink_inode_operations; | 324 | result->i_op = &page_symlink_inode_operations; |
334 | result->i_data.a_ops = &hpfs_symlink_aops; | 325 | result->i_data.a_ops = &hpfs_symlink_aops; |
335 | 326 | ||
336 | mutex_lock(&hpfs_i(dir)->i_mutex); | 327 | r = hpfs_add_dirent(dir, name, len, &dee); |
337 | r = hpfs_add_dirent(dir, name, len, &dee, 0); | ||
338 | if (r == 1) | 328 | if (r == 1) |
339 | goto bail2; | 329 | goto bail2; |
340 | if (r == -1) { | 330 | if (r == -1) { |
@@ -352,11 +342,9 @@ static int hpfs_symlink(struct inode *dir, struct dentry *dentry, const char *sy | |||
352 | 342 | ||
353 | hpfs_write_inode_nolock(result); | 343 | hpfs_write_inode_nolock(result); |
354 | d_instantiate(dentry, result); | 344 | d_instantiate(dentry, result); |
355 | mutex_unlock(&hpfs_i(dir)->i_mutex); | ||
356 | hpfs_unlock(dir->i_sb); | 345 | hpfs_unlock(dir->i_sb); |
357 | return 0; | 346 | return 0; |
358 | bail2: | 347 | bail2: |
359 | mutex_unlock(&hpfs_i(dir)->i_mutex); | ||
360 | iput(result); | 348 | iput(result); |
361 | bail1: | 349 | bail1: |
362 | brelse(bh); | 350 | brelse(bh); |
@@ -382,8 +370,6 @@ static int hpfs_unlink(struct inode *dir, struct dentry *dentry) | |||
382 | hpfs_lock(dir->i_sb); | 370 | hpfs_lock(dir->i_sb); |
383 | hpfs_adjust_length(name, &len); | 371 | hpfs_adjust_length(name, &len); |
384 | again: | 372 | again: |
385 | mutex_lock(&hpfs_i(inode)->i_parent_mutex); | ||
386 | mutex_lock(&hpfs_i(dir)->i_mutex); | ||
387 | err = -ENOENT; | 373 | err = -ENOENT; |
388 | de = map_dirent(dir, hpfs_i(dir)->i_dno, name, len, &dno, &qbh); | 374 | de = map_dirent(dir, hpfs_i(dir)->i_dno, name, len, &dno, &qbh); |
389 | if (!de) | 375 | if (!de) |
@@ -410,8 +396,6 @@ again: | |||
410 | if (rep++) | 396 | if (rep++) |
411 | break; | 397 | break; |
412 | 398 | ||
413 | mutex_unlock(&hpfs_i(dir)->i_mutex); | ||
414 | mutex_unlock(&hpfs_i(inode)->i_parent_mutex); | ||
415 | dentry_unhash(dentry); | 399 | dentry_unhash(dentry); |
416 | if (!d_unhashed(dentry)) { | 400 | if (!d_unhashed(dentry)) { |
417 | dput(dentry); | 401 | dput(dentry); |
@@ -445,8 +429,6 @@ again: | |||
445 | out1: | 429 | out1: |
446 | hpfs_brelse4(&qbh); | 430 | hpfs_brelse4(&qbh); |
447 | out: | 431 | out: |
448 | mutex_unlock(&hpfs_i(dir)->i_mutex); | ||
449 | mutex_unlock(&hpfs_i(inode)->i_parent_mutex); | ||
450 | hpfs_unlock(dir->i_sb); | 432 | hpfs_unlock(dir->i_sb); |
451 | return err; | 433 | return err; |
452 | } | 434 | } |
@@ -466,8 +448,6 @@ static int hpfs_rmdir(struct inode *dir, struct dentry *dentry) | |||
466 | 448 | ||
467 | hpfs_adjust_length(name, &len); | 449 | hpfs_adjust_length(name, &len); |
468 | hpfs_lock(dir->i_sb); | 450 | hpfs_lock(dir->i_sb); |
469 | mutex_lock(&hpfs_i(inode)->i_parent_mutex); | ||
470 | mutex_lock(&hpfs_i(dir)->i_mutex); | ||
471 | err = -ENOENT; | 451 | err = -ENOENT; |
472 | de = map_dirent(dir, hpfs_i(dir)->i_dno, name, len, &dno, &qbh); | 452 | de = map_dirent(dir, hpfs_i(dir)->i_dno, name, len, &dno, &qbh); |
473 | if (!de) | 453 | if (!de) |
@@ -505,8 +485,6 @@ static int hpfs_rmdir(struct inode *dir, struct dentry *dentry) | |||
505 | out1: | 485 | out1: |
506 | hpfs_brelse4(&qbh); | 486 | hpfs_brelse4(&qbh); |
507 | out: | 487 | out: |
508 | mutex_unlock(&hpfs_i(dir)->i_mutex); | ||
509 | mutex_unlock(&hpfs_i(inode)->i_parent_mutex); | ||
510 | hpfs_unlock(dir->i_sb); | 488 | hpfs_unlock(dir->i_sb); |
511 | return err; | 489 | return err; |
512 | } | 490 | } |
@@ -568,12 +546,6 @@ static int hpfs_rename(struct inode *old_dir, struct dentry *old_dentry, | |||
568 | 546 | ||
569 | hpfs_lock(i->i_sb); | 547 | hpfs_lock(i->i_sb); |
570 | /* order doesn't matter, due to VFS exclusion */ | 548 | /* order doesn't matter, due to VFS exclusion */ |
571 | mutex_lock(&hpfs_i(i)->i_parent_mutex); | ||
572 | if (new_inode) | ||
573 | mutex_lock(&hpfs_i(new_inode)->i_parent_mutex); | ||
574 | mutex_lock(&hpfs_i(old_dir)->i_mutex); | ||
575 | if (new_dir != old_dir) | ||
576 | mutex_lock(&hpfs_i(new_dir)->i_mutex); | ||
577 | 549 | ||
578 | /* Erm? Moving over the empty non-busy directory is perfectly legal */ | 550 | /* Erm? Moving over the empty non-busy directory is perfectly legal */ |
579 | if (new_inode && S_ISDIR(new_inode->i_mode)) { | 551 | if (new_inode && S_ISDIR(new_inode->i_mode)) { |
@@ -610,9 +582,7 @@ static int hpfs_rename(struct inode *old_dir, struct dentry *old_dentry, | |||
610 | 582 | ||
611 | if (new_dir == old_dir) hpfs_brelse4(&qbh); | 583 | if (new_dir == old_dir) hpfs_brelse4(&qbh); |
612 | 584 | ||
613 | hpfs_lock_creation(i->i_sb); | 585 | if ((r = hpfs_add_dirent(new_dir, new_name, new_len, &de))) { |
614 | if ((r = hpfs_add_dirent(new_dir, new_name, new_len, &de, 1))) { | ||
615 | hpfs_unlock_creation(i->i_sb); | ||
616 | if (r == -1) hpfs_error(new_dir->i_sb, "hpfs_rename: dirent already exists!"); | 586 | if (r == -1) hpfs_error(new_dir->i_sb, "hpfs_rename: dirent already exists!"); |
617 | err = r == 1 ? -ENOSPC : -EFSERROR; | 587 | err = r == 1 ? -ENOSPC : -EFSERROR; |
618 | if (new_dir != old_dir) hpfs_brelse4(&qbh); | 588 | if (new_dir != old_dir) hpfs_brelse4(&qbh); |
@@ -621,20 +591,17 @@ static int hpfs_rename(struct inode *old_dir, struct dentry *old_dentry, | |||
621 | 591 | ||
622 | if (new_dir == old_dir) | 592 | if (new_dir == old_dir) |
623 | if (!(dep = map_dirent(old_dir, hpfs_i(old_dir)->i_dno, old_name, old_len, &dno, &qbh))) { | 593 | if (!(dep = map_dirent(old_dir, hpfs_i(old_dir)->i_dno, old_name, old_len, &dno, &qbh))) { |
624 | hpfs_unlock_creation(i->i_sb); | ||
625 | hpfs_error(i->i_sb, "lookup succeeded but map dirent failed at #2"); | 594 | hpfs_error(i->i_sb, "lookup succeeded but map dirent failed at #2"); |
626 | err = -ENOENT; | 595 | err = -ENOENT; |
627 | goto end1; | 596 | goto end1; |
628 | } | 597 | } |
629 | 598 | ||
630 | if ((r = hpfs_remove_dirent(old_dir, dno, dep, &qbh, 0))) { | 599 | if ((r = hpfs_remove_dirent(old_dir, dno, dep, &qbh, 0))) { |
631 | hpfs_unlock_creation(i->i_sb); | ||
632 | hpfs_error(i->i_sb, "hpfs_rename: could not remove dirent"); | 600 | hpfs_error(i->i_sb, "hpfs_rename: could not remove dirent"); |
633 | err = r == 2 ? -ENOSPC : -EFSERROR; | 601 | err = r == 2 ? -ENOSPC : -EFSERROR; |
634 | goto end1; | 602 | goto end1; |
635 | } | 603 | } |
636 | hpfs_unlock_creation(i->i_sb); | 604 | |
637 | |||
638 | end: | 605 | end: |
639 | hpfs_i(i)->i_parent_dir = new_dir->i_ino; | 606 | hpfs_i(i)->i_parent_dir = new_dir->i_ino; |
640 | if (S_ISDIR(i->i_mode)) { | 607 | if (S_ISDIR(i->i_mode)) { |
@@ -652,12 +619,6 @@ static int hpfs_rename(struct inode *old_dir, struct dentry *old_dentry, | |||
652 | hpfs_i(i)->i_conv = hpfs_sb(i->i_sb)->sb_conv; | 619 | hpfs_i(i)->i_conv = hpfs_sb(i->i_sb)->sb_conv; |
653 | hpfs_decide_conv(i, new_name, new_len); | 620 | hpfs_decide_conv(i, new_name, new_len); |
654 | end1: | 621 | end1: |
655 | if (old_dir != new_dir) | ||
656 | mutex_unlock(&hpfs_i(new_dir)->i_mutex); | ||
657 | mutex_unlock(&hpfs_i(old_dir)->i_mutex); | ||
658 | mutex_unlock(&hpfs_i(i)->i_parent_mutex); | ||
659 | if (new_inode) | ||
660 | mutex_unlock(&hpfs_i(new_inode)->i_parent_mutex); | ||
661 | hpfs_unlock(i->i_sb); | 622 | hpfs_unlock(i->i_sb); |
662 | return err; | 623 | return err; |
663 | } | 624 | } |