diff options
Diffstat (limited to 'fs/vfat/namei.c')
-rw-r--r-- | fs/vfat/namei.c | 17 |
1 files changed, 8 insertions, 9 deletions
diff --git a/fs/vfat/namei.c b/fs/vfat/namei.c index 9a8f48bae956..edb711ff7b05 100644 --- a/fs/vfat/namei.c +++ b/fs/vfat/namei.c | |||
@@ -782,9 +782,9 @@ static int vfat_rmdir(struct inode *dir, struct dentry *dentry) | |||
782 | err = fat_remove_entries(dir, &sinfo); /* and releases bh */ | 782 | err = fat_remove_entries(dir, &sinfo); /* and releases bh */ |
783 | if (err) | 783 | if (err) |
784 | goto out; | 784 | goto out; |
785 | dir->i_nlink--; | 785 | drop_nlink(dir); |
786 | 786 | ||
787 | inode->i_nlink = 0; | 787 | clear_nlink(inode); |
788 | inode->i_mtime = inode->i_atime = CURRENT_TIME_SEC; | 788 | inode->i_mtime = inode->i_atime = CURRENT_TIME_SEC; |
789 | fat_detach(inode); | 789 | fat_detach(inode); |
790 | out: | 790 | out: |
@@ -808,7 +808,7 @@ static int vfat_unlink(struct inode *dir, struct dentry *dentry) | |||
808 | err = fat_remove_entries(dir, &sinfo); /* and releases bh */ | 808 | err = fat_remove_entries(dir, &sinfo); /* and releases bh */ |
809 | if (err) | 809 | if (err) |
810 | goto out; | 810 | goto out; |
811 | inode->i_nlink = 0; | 811 | clear_nlink(inode); |
812 | inode->i_mtime = inode->i_atime = CURRENT_TIME_SEC; | 812 | inode->i_mtime = inode->i_atime = CURRENT_TIME_SEC; |
813 | fat_detach(inode); | 813 | fat_detach(inode); |
814 | out: | 814 | out: |
@@ -837,7 +837,7 @@ static int vfat_mkdir(struct inode *dir, struct dentry *dentry, int mode) | |||
837 | if (err) | 837 | if (err) |
838 | goto out_free; | 838 | goto out_free; |
839 | dir->i_version++; | 839 | dir->i_version++; |
840 | dir->i_nlink++; | 840 | inc_nlink(dir); |
841 | 841 | ||
842 | inode = fat_build_inode(sb, sinfo.de, sinfo.i_pos); | 842 | inode = fat_build_inode(sb, sinfo.de, sinfo.i_pos); |
843 | brelse(sinfo.bh); | 843 | brelse(sinfo.bh); |
@@ -930,9 +930,9 @@ static int vfat_rename(struct inode *old_dir, struct dentry *old_dentry, | |||
930 | if (err) | 930 | if (err) |
931 | goto error_dotdot; | 931 | goto error_dotdot; |
932 | } | 932 | } |
933 | old_dir->i_nlink--; | 933 | drop_nlink(old_dir); |
934 | if (!new_inode) | 934 | if (!new_inode) |
935 | new_dir->i_nlink++; | 935 | inc_nlink(new_dir); |
936 | } | 936 | } |
937 | 937 | ||
938 | err = fat_remove_entries(old_dir, &old_sinfo); /* and releases bh */ | 938 | err = fat_remove_entries(old_dir, &old_sinfo); /* and releases bh */ |
@@ -947,10 +947,9 @@ static int vfat_rename(struct inode *old_dir, struct dentry *old_dentry, | |||
947 | mark_inode_dirty(old_dir); | 947 | mark_inode_dirty(old_dir); |
948 | 948 | ||
949 | if (new_inode) { | 949 | if (new_inode) { |
950 | drop_nlink(new_inode); | ||
950 | if (is_dir) | 951 | if (is_dir) |
951 | new_inode->i_nlink -= 2; | 952 | drop_nlink(new_inode); |
952 | else | ||
953 | new_inode->i_nlink--; | ||
954 | new_inode->i_ctime = ts; | 953 | new_inode->i_ctime = ts; |
955 | } | 954 | } |
956 | out: | 955 | out: |