diff options
author | Steve French <sfrench@us.ibm.com> | 2006-10-11 20:02:32 -0400 |
---|---|---|
committer | Steve French <sfrench@us.ibm.com> | 2006-10-11 20:02:32 -0400 |
commit | 533f90af6d90b9e4859a158565385d1d84a79f75 (patch) | |
tree | 3f141cf47d27f24e623277d2d6be2a36191c1275 | |
parent | 70903ca004fef17b0f6483714baefdb2f6ecceb0 (diff) |
[CIFS] Fix old DOS time conversion to handle timezone
Signed-off-by: Steve French <sfrench@us.ibm.com>
-rw-r--r-- | fs/cifs/netmisc.c | 2 | ||||
-rw-r--r-- | fs/cifs/readdir.c | 13 |
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 | ||
109 | static 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 | |||
109 | static void fill_in_inode(struct inode *tmp_inode, int new_buf_type, | 120 | static 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); |