summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2013-04-17 20:07:51 (GMT)
committerAntoine Pitrou <solipsis@pitrou.net>2013-04-17 20:07:51 (GMT)
commitb8da0a5842c1bdea30520250b3aa34de51a5845b (patch)
tree648d60851342c2bf7f8531b1e683c99c26c5c8b2
parentc149902175801a448dea3b8c2fa3f496116ce311 (diff)
parentcf8a1e51ece7cad7096963927993ddfa738627e6 (diff)
downloadcpython-b8da0a5842c1bdea30520250b3aa34de51a5845b.zip
cpython-b8da0a5842c1bdea30520250b3aa34de51a5845b.tar.gz
cpython-b8da0a5842c1bdea30520250b3aa34de51a5845b.tar.bz2
Issue #17782: Fix undefined behaviour on platforms where ``struct timespec``'s "tv_nsec" member is not a C long.
-rw-r--r--Misc/NEWS3
-rw-r--r--Modules/posixmodule.c10
-rw-r--r--Modules/signalmodule.c6
-rw-r--r--Modules/timemodule.c6
4 files changed, 21 insertions, 4 deletions
diff --git a/Misc/NEWS b/Misc/NEWS
index 63634dc..0edb8e3 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -10,6 +10,9 @@ What's New in Python 3.4.0 Alpha 1?
Core and Builtins
-----------------
+- Issue #17782: Fix undefined behaviour on platforms where
+ ``struct timespec``'s "tv_nsec" member is not a C long.
+
- Issue #17722: When looking up __round__, resolve descriptors.
- Issue #16061: Speed up str.replace() for replacing 1-character strings.
diff --git a/Modules/posixmodule.c b/Modules/posixmodule.c
index 6830684..1149856 100644
--- a/Modules/posixmodule.c
+++ b/Modules/posixmodule.c
@@ -4507,6 +4507,8 @@ posix_utime(PyObject *self, PyObject *args, PyObject *kwargs)
}
if (times && (times != Py_None)) {
+ time_t a_sec, m_sec;
+ long a_nsec, m_nsec;
if (!PyTuple_CheckExact(times) || (PyTuple_Size(times) != 2)) {
PyErr_SetString(PyExc_TypeError,
"utime: 'times' must be either"
@@ -4515,11 +4517,15 @@ posix_utime(PyObject *self, PyObject *args, PyObject *kwargs)
}
utime.now = 0;
if (_PyTime_ObjectToTimespec(PyTuple_GET_ITEM(times, 0),
- &utime.atime_s, &utime.atime_ns) == -1 ||
+ &a_sec, &a_nsec) == -1 ||
_PyTime_ObjectToTimespec(PyTuple_GET_ITEM(times, 1),
- &utime.mtime_s, &utime.mtime_ns) == -1) {
+ &m_sec, &m_nsec) == -1) {
goto exit;
}
+ utime.atime_s = a_sec;
+ utime.atime_ns = a_nsec;
+ utime.mtime_s = m_sec;
+ utime.mtime_ns = m_nsec;
}
else if (ns) {
if (!PyTuple_CheckExact(ns) || (PyTuple_Size(ns) != 2)) {
diff --git a/Modules/signalmodule.c b/Modules/signalmodule.c
index 8b6c1c2..dd55c10 100644
--- a/Modules/signalmodule.c
+++ b/Modules/signalmodule.c
@@ -779,14 +779,18 @@ signal_sigtimedwait(PyObject *self, PyObject *args)
struct timespec buf;
sigset_t set;
siginfo_t si;
+ time_t tv_sec;
+ long tv_nsec;
int err;
if (!PyArg_ParseTuple(args, "OO:sigtimedwait",
&signals, &timeout))
return NULL;
- if (_PyTime_ObjectToTimespec(timeout, &buf.tv_sec, &buf.tv_nsec) == -1)
+ if (_PyTime_ObjectToTimespec(timeout, &tv_sec, &tv_nsec) == -1)
return NULL;
+ buf.tv_sec = tv_sec;
+ buf.tv_nsec = tv_nsec;
if (buf.tv_sec < 0 || buf.tv_nsec < 0) {
PyErr_SetString(PyExc_ValueError, "timeout must be non-negative");
diff --git a/Modules/timemodule.c b/Modules/timemodule.c
index d5ffdcc..429215f 100644
--- a/Modules/timemodule.c
+++ b/Modules/timemodule.c
@@ -185,14 +185,18 @@ time_clock_settime(PyObject *self, PyObject *args)
{
int clk_id;
PyObject *obj;
+ time_t tv_sec;
+ long tv_nsec;
struct timespec tp;
int ret;
if (!PyArg_ParseTuple(args, "iO:clock_settime", &clk_id, &obj))
return NULL;
- if (_PyTime_ObjectToTimespec(obj, &tp.tv_sec, &tp.tv_nsec) == -1)
+ if (_PyTime_ObjectToTimespec(obj, &tv_sec, &tv_nsec) == -1)
return NULL;
+ tp.tv_sec = tv_sec;
+ tp.tv_nsec = tv_nsec;
ret = clock_settime((clockid_t)clk_id, &tp);
if (ret != 0) {