summaryrefslogtreecommitdiff
path: root/source3/libsmb/libsmbclient.c
diff options
context:
space:
mode:
Diffstat (limited to 'source3/libsmb/libsmbclient.c')
-rw-r--r--source3/libsmb/libsmbclient.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/source3/libsmb/libsmbclient.c b/source3/libsmb/libsmbclient.c
index bf3307cfb8..2b511050ce 100644
--- a/source3/libsmb/libsmbclient.c
+++ b/source3/libsmb/libsmbclient.c
@@ -1282,13 +1282,22 @@ static BOOL smbc_setatr(SMBCCTX * context, SMBCSRV *srv, char *path,
* Get the create time of the file (if not provided); we'll need it in
* the set call.
*/
- if (! srv->no_pathinfo && c_time != 0) {
+ if (! srv->no_pathinfo && c_time == 0) {
if (! cli_qpathinfo(&srv->cli, path,
&c_time, NULL, NULL, NULL, NULL)) {
/* qpathinfo not available */
srv->no_pathinfo = True;
} else {
/*
+ * We got a creation time. Some OS versions don't
+ * return a valid create time, though. If we got an
+ * invalid time, start with the current time instead.
+ */
+ if (c_time == 0 || c_time == (time_t) -1) {
+ c_time = time(NULL);
+ }
+
+ /*
* We got a creation time. For sanity sake, since
* there is no POSIX function to set the create time
* of a file, if the existing create time is greater
@@ -1346,7 +1355,7 @@ static BOOL smbc_setatr(SMBCCTX * context, SMBCSRV *srv, char *path,
/* If we got create time, set times */
if (ret) {
/* Some OS versions don't support create time */
- if (c_time == 0) {
+ if (c_time == 0 || c_time == -1) {
c_time = time(NULL);
}