summaryrefslogtreecommitdiffstats
path: root/Modules
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2015-03-27 17:19:03 (GMT)
committerVictor Stinner <victor.stinner@gmail.com>2015-03-27 17:19:03 (GMT)
commit34dc0f46ae5c0c9ec91d9402fac61111b802855f (patch)
tree274e9bac8b7049fabac4f16161676edfd847c771 /Modules
parent7181dec3f12f11c9a5f4adc6336b1c7273452308 (diff)
downloadcpython-34dc0f46ae5c0c9ec91d9402fac61111b802855f.zip
cpython-34dc0f46ae5c0c9ec91d9402fac61111b802855f.tar.gz
cpython-34dc0f46ae5c0c9ec91d9402fac61111b802855f.tar.bz2
Issue #22117: The signal modules uses the new _PyTime_t API
* Add _PyTime_AsTimespec() * Add unit tests for _PyTime_AsTimespec()
Diffstat (limited to 'Modules')
-rw-r--r--Modules/_testcapimodule.c20
-rw-r--r--Modules/signalmodule.c27
2 files changed, 33 insertions, 14 deletions
diff --git a/Modules/_testcapimodule.c b/Modules/_testcapimodule.c
index b382081..5029105 100644
--- a/Modules/_testcapimodule.c
+++ b/Modules/_testcapimodule.c
@@ -3408,6 +3408,23 @@ test_pytime_assecondsdouble(PyObject *self, PyObject *args)
return PyFloat_FromDouble(d);
}
+#ifdef HAVE_CLOCK_GETTIME
+static PyObject *
+test_PyTime_AsTimespec(PyObject *self, PyObject *args)
+{
+ PY_LONG_LONG ns;
+ _PyTime_t t;
+ struct timespec ts;
+
+ if (!PyArg_ParseTuple(args, "L", &ns))
+ return NULL;
+ t = _PyTime_FromNanoseconds(ns);
+ if (_PyTime_AsTimespec(t, &ts) == -1)
+ return NULL;
+ return Py_BuildValue("Nl", _PyLong_FromTime_t(ts.tv_sec), ts.tv_nsec);
+}
+#endif
+
static PyMethodDef TestMethods[] = {
{"raise_exception", raise_exception, METH_VARARGS},
@@ -3573,6 +3590,9 @@ static PyMethodDef TestMethods[] = {
return_result_with_error, METH_NOARGS},
{"PyTime_FromSecondsObject", test_pytime_fromsecondsobject, METH_VARARGS},
{"PyTime_AsSecondsDouble", test_pytime_assecondsdouble, METH_VARARGS},
+#ifdef HAVE_CLOCK_GETTIME
+ {"PyTime_AsTimespec", test_PyTime_AsTimespec, METH_VARARGS},
+#endif
{NULL, NULL} /* sentinel */
};
diff --git a/Modules/signalmodule.c b/Modules/signalmodule.c
index 5dba8b1..f3b2e29 100644
--- a/Modules/signalmodule.c
+++ b/Modules/signalmodule.c
@@ -966,16 +966,18 @@ Returns a struct_siginfo containing information about the signal.");
static PyObject *
signal_sigtimedwait(PyObject *self, PyObject *args)
{
- PyObject *signals;
- double timeout, frac;
+ PyObject *signals, *timeout_obj;
struct timespec ts;
sigset_t set;
siginfo_t si;
int res;
- _PyTime_timeval deadline, monotonic;
+ _PyTime_t timeout, deadline, monotonic;
+
+ if (!PyArg_ParseTuple(args, "OO:sigtimedwait",
+ &signals, &timeout_obj))
+ return NULL;
- if (!PyArg_ParseTuple(args, "Od:sigtimedwait",
- &signals, &timeout))
+ if (_PyTime_FromSecondsObject(&timeout, timeout_obj, _PyTime_ROUND_UP) < 0)
return NULL;
if (timeout < 0) {
@@ -986,14 +988,11 @@ signal_sigtimedwait(PyObject *self, PyObject *args)
if (iterable_to_sigset(signals, &set))
return NULL;
- _PyTime_monotonic(&deadline);
- _PyTime_AddDouble(&deadline, timeout, _PyTime_ROUND_UP);
+ deadline = _PyTime_GetMonotonicClock() + timeout;
do {
- frac = fmod(timeout, 1.0);
- timeout = floor(timeout);
- ts.tv_sec = (long)timeout;
- ts.tv_nsec = (long)(frac*1e9);
+ if (_PyTime_AsTimespec(timeout, &ts) < 0)
+ return NULL;
Py_BEGIN_ALLOW_THREADS
res = sigtimedwait(&set, &si, &ts);
@@ -1013,9 +1012,9 @@ signal_sigtimedwait(PyObject *self, PyObject *args)
if (PyErr_CheckSignals())
return NULL;
- _PyTime_monotonic(&monotonic);
- timeout = _PyTime_INTERVAL(monotonic, deadline);
- if (timeout <= 0.0)
+ monotonic = _PyTime_GetMonotonicClock();
+ timeout = deadline - monotonic;
+ if (timeout <= 0)
break;
} while (1);