aboutsummaryrefslogtreecommitdiffstats
path: root/fs/fat/namei_vfat.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/fat/namei_vfat.c')
-rw-r--r--fs/fat/namei_vfat.c11
1 files changed, 3 insertions, 8 deletions
diff --git a/fs/fat/namei_vfat.c b/fs/fat/namei_vfat.c
index 6cc480652433..6a6d8c0715a1 100644
--- a/fs/fat/namei_vfat.c
+++ b/fs/fat/namei_vfat.c
@@ -651,8 +651,7 @@ shortname:
651 de->time = de->ctime = time; 651 de->time = de->ctime = time;
652 de->date = de->cdate = de->adate = date; 652 de->date = de->cdate = de->adate = date;
653 de->ctime_cs = time_cs; 653 de->ctime_cs = time_cs;
654 de->start = cpu_to_le16(cluster); 654 fat_set_start(de, cluster);
655 de->starthi = cpu_to_le16(cluster >> 16);
656 de->size = 0; 655 de->size = 0;
657out_free: 656out_free:
658 __putname(uname); 657 __putname(uname);
@@ -965,9 +964,7 @@ static int vfat_rename(struct inode *old_dir, struct dentry *old_dentry,
965 mark_inode_dirty(old_inode); 964 mark_inode_dirty(old_inode);
966 965
967 if (update_dotdot) { 966 if (update_dotdot) {
968 int start = MSDOS_I(new_dir)->i_logstart; 967 fat_set_start(dotdot_de, MSDOS_I(new_dir)->i_logstart);
969 dotdot_de->start = cpu_to_le16(start);
970 dotdot_de->starthi = cpu_to_le16(start >> 16);
971 mark_buffer_dirty_inode(dotdot_bh, old_inode); 968 mark_buffer_dirty_inode(dotdot_bh, old_inode);
972 if (IS_DIRSYNC(new_dir)) { 969 if (IS_DIRSYNC(new_dir)) {
973 err = sync_dirty_buffer(dotdot_bh); 970 err = sync_dirty_buffer(dotdot_bh);
@@ -1009,9 +1006,7 @@ error_dotdot:
1009 corrupt = 1; 1006 corrupt = 1;
1010 1007
1011 if (update_dotdot) { 1008 if (update_dotdot) {
1012 int start = MSDOS_I(old_dir)->i_logstart; 1009 fat_set_start(dotdot_de, MSDOS_I(old_dir)->i_logstart);
1013 dotdot_de->start = cpu_to_le16(start);
1014 dotdot_de->starthi = cpu_to_le16(start >> 16);
1015 mark_buffer_dirty_inode(dotdot_bh, old_inode); 1010 mark_buffer_dirty_inode(dotdot_bh, old_inode);
1016 corrupt |= sync_dirty_buffer(dotdot_bh); 1011 corrupt |= sync_dirty_buffer(dotdot_bh);
1017 } 1012 }