summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristoph M. Becker <cmbecker69@gmx.de>2019-07-03 09:59:17 +0200
committerChristoph M. Becker <cmbecker69@gmx.de>2019-07-03 09:59:17 +0200
commit44c8b7414ce96038017edc2fd827f8250669a62a (patch)
treeec317c10a02bd2a1b66505550170bfc6ac6db2f7
parent32c68428a9888e3776441ed39c85b8b49f08fb88 (diff)
downloadphp-git-44c8b7414ce96038017edc2fd827f8250669a62a.tar.gz
Fix #78241: touch() does not handle dates after 2038 in PHP 64-bit
`time_t` defaults to `_time64` (which is 64bit signed) even on x86, but `Int32x32To64()` truncates it to signed 32bit. We replace the macro with the "manual" calculation.
-rw-r--r--NEWS3
-rw-r--r--TSRM/tsrm_win32.c2
-rw-r--r--ext/standard/tests/file/bug78241.phpt33
3 files changed, 37 insertions, 1 deletions
diff --git a/NEWS b/NEWS
index 078d61c1eb..4c05f42773 100644
--- a/NEWS
+++ b/NEWS
@@ -21,6 +21,9 @@ PHP NEWS
. Fixed #78189 (file cache strips last character of uname hash). (cmb)
. Fixed #78202 (Opcache stats for cache hits are capped at 32bit NUM). (cmb)
+- Standard:
+ . Fixed #78241 (touch() does not handle dates after 2038 in PHP 64-bit). (cmb)
+
27 Jun 2019, PHP 7.2.20
- Core:
diff --git a/TSRM/tsrm_win32.c b/TSRM/tsrm_win32.c
index ca121de057..34b0676461 100644
--- a/TSRM/tsrm_win32.c
+++ b/TSRM/tsrm_win32.c
@@ -804,7 +804,7 @@ static zend_always_inline void UnixTimeToFileTime(time_t t, LPFILETIME pft) /* {
// Note that LONGLONG is a 64-bit value
LONGLONG ll;
- ll = Int32x32To64(t, 10000000) + 116444736000000000;
+ ll = t * 10000000 + 116444736000000000;
pft->dwLowDateTime = (DWORD)ll;
pft->dwHighDateTime = ll >> 32;
}
diff --git a/ext/standard/tests/file/bug78241.phpt b/ext/standard/tests/file/bug78241.phpt
new file mode 100644
index 0000000000..99fed8a5a3
--- /dev/null
+++ b/ext/standard/tests/file/bug78241.phpt
@@ -0,0 +1,33 @@
+--TEST--
+Bug #78241 (touch() does not handle dates after 2038 in PHP 64-bit)
+--SKIPIF--
+<?php
+if (substr(PHP_OS, 0, 3) != 'WIN') die('skip this test is for Windows platforms only');
+if (PHP_INT_SIZE != 8) die('skip this test is for 64bit platforms only');
+?>
+--INI--
+date.timezone=UTC
+--FILE--
+<?php
+$filename = __DIR__ . '/bug78241.txt';
+for ($i = 2037; $i <= 2040; $i++) {
+ $t = mktime(1, 1 , 1, 1, 1, $i);
+ echo 'Date: '.date('D, d M Y H:i:s', $t), PHP_EOL;
+ touch($filename, $t);
+ clearstatcache(true, $filename);
+ $file = filemtime($filename);
+ echo 'File: '.date('D, d M Y H:i:s', $file), PHP_EOL, PHP_EOL;
+}
+?>
+--EXPECT--
+Date: Thu, 01 Jan 2037 01:01:01
+File: Thu, 01 Jan 2037 01:01:01
+
+Date: Fri, 01 Jan 2038 01:01:01
+File: Fri, 01 Jan 2038 01:01:01
+
+Date: Sat, 01 Jan 2039 01:01:01
+File: Sat, 01 Jan 2039 01:01:01
+
+Date: Sun, 01 Jan 2040 01:01:01
+File: Sun, 01 Jan 2040 01:01:01