aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorSteve French <sfrench@us.ibm.com>2006-10-11 20:02:32 -0400
committerSteve French <sfrench@us.ibm.com>2006-10-11 20:02:32 -0400
commit533f90af6d90b9e4859a158565385d1d84a79f75 (patch)
tree3f141cf47d27f24e623277d2d6be2a36191c1275 /fs
parent70903ca004fef17b0f6483714baefdb2f6ecceb0 (diff)
[CIFS] Fix old DOS time conversion to handle timezone
Signed-off-by: Steve French <sfrench@us.ibm.com>
Diffstat (limited to 'fs')
-rw-r--r--fs/cifs/netmisc.c2
-rw-r--r--fs/cifs/readdir.c13
2 files changed, 13 insertions, 2 deletions
diff --git a/fs/cifs/netmisc.c b/fs/cifs/netmisc.c
index 3adbd128e08e..992e80edc720 100644
--- a/fs/cifs/netmisc.c
+++ b/fs/cifs/netmisc.c
@@ -942,7 +942,7 @@ struct timespec cnvrtDosUnixTm(__u16 date, __u16 time)
942 cERROR(1,("illegal date, month %d day: %d", month, days)); 942 cERROR(1,("illegal date, month %d day: %d", month, days));
943 month -= 1; 943 month -= 1;
944 days += total_days_of_prev_months[month]; 944 days += total_days_of_prev_months[month];
945 days += 3653; /* account for difference in days between 1980 and 1970 */ 945 days += 3652; /* account for difference in days between 1980 and 1970 */
946 year = sd->Year; 946 year = sd->Year;
947 days += year * 365; 947 days += year * 365;
948 days += (year/4); /* leap year */ 948 days += (year/4); /* leap year */
diff --git a/fs/cifs/readdir.c b/fs/cifs/readdir.c
index 81e7b2e5fb4d..80e6ebd440a8 100644
--- a/fs/cifs/readdir.c
+++ b/fs/cifs/readdir.c
@@ -106,6 +106,17 @@ static int construct_dentry(struct qstr *qstring, struct file *file,
106 return rc; 106 return rc;
107} 107}
108 108
109static void AdjustForTZ(struct cifsTconInfo * tcon, struct inode * inode)
110{
111 if((tcon) && (tcon->ses) && (tcon->ses->server)) {
112 inode->i_ctime.tv_sec += tcon->ses->server.timeAdj;
113 inode->i_mtime.tv_sec += tcon->ses->server.timeAdj;
114 inode->i_atime.tv_sec += tcon->ses->server.timeAdj;
115 }
116 return;
117}
118
119
109static void fill_in_inode(struct inode *tmp_inode, int new_buf_type, 120static void fill_in_inode(struct inode *tmp_inode, int new_buf_type,
110 char * buf, int *pobject_type, int isNewInode) 121 char * buf, int *pobject_type, int isNewInode)
111{ 122{
@@ -148,7 +159,7 @@ static void fill_in_inode(struct inode *tmp_inode, int new_buf_type,
148 tmp_inode->i_ctime = cnvrtDosUnixTm( 159 tmp_inode->i_ctime = cnvrtDosUnixTm(
149 le16_to_cpu(pfindData->LastWriteDate), 160 le16_to_cpu(pfindData->LastWriteDate),
150 le16_to_cpu(pfindData->LastWriteTime)); 161 le16_to_cpu(pfindData->LastWriteTime));
151 162 AdjustForTZ(cifs_sb->tcon, tmp_inode);
152 attr = le16_to_cpu(pfindData->Attributes); 163 attr = le16_to_cpu(pfindData->Attributes);
153 allocation_size = le32_to_cpu(pfindData->AllocationSize); 164 allocation_size = le32_to_cpu(pfindData->AllocationSize);
154 end_of_file = le32_to_cpu(pfindData->DataSize); 165 end_of_file = le32_to_cpu(pfindData->DataSize);