diff options
Diffstat (limited to 'fs/udf/inode.c')
-rw-r--r-- | fs/udf/inode.c | 49 |
1 files changed, 26 insertions, 23 deletions
diff --git a/fs/udf/inode.c b/fs/udf/inode.c index 3c0a60dad478..a7646e9bdbde 100644 --- a/fs/udf/inode.c +++ b/fs/udf/inode.c | |||
@@ -1136,20 +1136,6 @@ static void __udf_read_inode(struct inode *inode) | |||
1136 | brelse(bh); | 1136 | brelse(bh); |
1137 | } | 1137 | } |
1138 | 1138 | ||
1139 | static void udf_fill_inode_time(struct timespec *tspec, | ||
1140 | const timestamp *tstamp, | ||
1141 | struct udf_sb_info *sbi) | ||
1142 | { | ||
1143 | time_t convtime; | ||
1144 | long convtime_usec; | ||
1145 | if (udf_stamp_to_time(&convtime, &convtime_usec, | ||
1146 | lets_to_cpu(*tstamp))) { | ||
1147 | tspec->tv_sec = convtime; | ||
1148 | tspec->tv_nsec = convtime_usec * 1000; | ||
1149 | } else | ||
1150 | *tspec = sbi->s_record_time; | ||
1151 | } | ||
1152 | |||
1153 | static void udf_fill_inode(struct inode *inode, struct buffer_head *bh) | 1139 | static void udf_fill_inode(struct inode *inode, struct buffer_head *bh) |
1154 | { | 1140 | { |
1155 | struct fileEntry *fe; | 1141 | struct fileEntry *fe; |
@@ -1241,10 +1227,17 @@ static void udf_fill_inode(struct inode *inode, struct buffer_head *bh) | |||
1241 | inode->i_blocks = le64_to_cpu(fe->logicalBlocksRecorded) << | 1227 | inode->i_blocks = le64_to_cpu(fe->logicalBlocksRecorded) << |
1242 | (inode->i_sb->s_blocksize_bits - 9); | 1228 | (inode->i_sb->s_blocksize_bits - 9); |
1243 | 1229 | ||
1244 | udf_fill_inode_time(&inode->i_atime, &fe->accessTime, sbi); | 1230 | if (!udf_stamp_to_time(&inode->i_atime, |
1245 | udf_fill_inode_time(&inode->i_mtime, &fe->modificationTime, | 1231 | lets_to_cpu(fe->accessTime))) |
1246 | sbi); | 1232 | inode->i_atime = sbi->s_record_time; |
1247 | udf_fill_inode_time(&inode->i_ctime, &fe->attrTime, sbi); | 1233 | |
1234 | if (!udf_stamp_to_time(&inode->i_mtime, | ||
1235 | lets_to_cpu(fe->modificationTime))) | ||
1236 | inode->i_mtime = sbi->s_record_time; | ||
1237 | |||
1238 | if (!udf_stamp_to_time(&inode->i_ctime, | ||
1239 | lets_to_cpu(fe->attrTime))) | ||
1240 | inode->i_ctime = sbi->s_record_time; | ||
1248 | 1241 | ||
1249 | iinfo->i_unique = le64_to_cpu(fe->uniqueID); | 1242 | iinfo->i_unique = le64_to_cpu(fe->uniqueID); |
1250 | iinfo->i_lenEAttr = le32_to_cpu(fe->lengthExtendedAttr); | 1243 | iinfo->i_lenEAttr = le32_to_cpu(fe->lengthExtendedAttr); |
@@ -1254,11 +1247,21 @@ static void udf_fill_inode(struct inode *inode, struct buffer_head *bh) | |||
1254 | inode->i_blocks = le64_to_cpu(efe->logicalBlocksRecorded) << | 1247 | inode->i_blocks = le64_to_cpu(efe->logicalBlocksRecorded) << |
1255 | (inode->i_sb->s_blocksize_bits - 9); | 1248 | (inode->i_sb->s_blocksize_bits - 9); |
1256 | 1249 | ||
1257 | udf_fill_inode_time(&inode->i_atime, &efe->accessTime, sbi); | 1250 | if (!udf_stamp_to_time(&inode->i_atime, |
1258 | udf_fill_inode_time(&inode->i_mtime, &efe->modificationTime, | 1251 | lets_to_cpu(efe->accessTime))) |
1259 | sbi); | 1252 | inode->i_atime = sbi->s_record_time; |
1260 | udf_fill_inode_time(&iinfo->i_crtime, &efe->createTime, sbi); | 1253 | |
1261 | udf_fill_inode_time(&inode->i_ctime, &efe->attrTime, sbi); | 1254 | if (!udf_stamp_to_time(&inode->i_mtime, |
1255 | lets_to_cpu(efe->modificationTime))) | ||
1256 | inode->i_mtime = sbi->s_record_time; | ||
1257 | |||
1258 | if (!udf_stamp_to_time(&iinfo->i_crtime, | ||
1259 | lets_to_cpu(efe->createTime))) | ||
1260 | iinfo->i_crtime = sbi->s_record_time; | ||
1261 | |||
1262 | if (!udf_stamp_to_time(&inode->i_ctime, | ||
1263 | lets_to_cpu(efe->attrTime))) | ||
1264 | inode->i_ctime = sbi->s_record_time; | ||
1262 | 1265 | ||
1263 | iinfo->i_unique = le64_to_cpu(efe->uniqueID); | 1266 | iinfo->i_unique = le64_to_cpu(efe->uniqueID); |
1264 | iinfo->i_lenEAttr = le32_to_cpu(efe->lengthExtendedAttr); | 1267 | iinfo->i_lenEAttr = le32_to_cpu(efe->lengthExtendedAttr); |