Skip to content

Commit 69a5030

Browse files
authored
Merge pull request #112 from kraj/master
Fix build on 32bit arches with 64bit time_t
2 parents a53106c + bcafe72 commit 69a5030

File tree

2 files changed

+17
-5
lines changed

2 files changed

+17
-5
lines changed

evdev/input.c

Lines changed: 9 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,11 @@
2424
#include <linux/input.h>
2525
#endif
2626

27+
#ifndef input_event_sec
28+
#define input_event_sec time.tv_sec
29+
#define input_event_usec time.tv_usec
30+
#endif
31+
2732
#define MAX_NAME_SIZE 256
2833

2934
extern char* EV_NAME[EV_CNT];
@@ -60,8 +65,8 @@ device_read(PyObject *self, PyObject *args)
6065
return NULL;
6166
}
6267

63-
PyObject* sec = PyLong_FromLong(event.time.tv_sec);
64-
PyObject* usec = PyLong_FromLong(event.time.tv_usec);
68+
PyObject* sec = PyLong_FromLong(event.input_event_sec);
69+
PyObject* usec = PyLong_FromLong(event.input_event_usec);
6570
PyObject* val = PyLong_FromLong(event.value);
6671
PyObject* py_input_event = NULL;
6772

@@ -102,8 +107,8 @@ device_read_many(PyObject *self, PyObject *args)
102107

103108
// Construct a list of event tuples, which we'll make sense of in Python
104109
for (unsigned i = 0 ; i < nread/event_size ; i++) {
105-
sec = PyLong_FromLong(event[i].time.tv_sec);
106-
usec = PyLong_FromLong(event[i].time.tv_usec);
110+
sec = PyLong_FromLong(event[i].input_event_sec);
111+
usec = PyLong_FromLong(event[i].input_event_usec);
107112
val = PyLong_FromLong(event[i].value);
108113

109114
py_input_event = Py_BuildValue("OOhhO", sec, usec, event[i].type, event[i].code, val);

evdev/uinput.c

Lines changed: 8 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,10 @@
1616
#include <linux/uinput.h>
1717
#endif
1818

19+
#ifndef input_event_sec
20+
#define input_event_sec time.tv_sec
21+
#define input_event_usec time.tv_usec
22+
#endif
1923

2024
// Workaround for installing on kernels newer than 4.4.
2125
#ifndef FF_MAX_EFFECTS
@@ -232,8 +236,11 @@ uinput_write(PyObject *self, PyObject *args)
232236
if (!ret) return NULL;
233237

234238
struct input_event event;
239+
struct timeval tval;
235240
memset(&event, 0, sizeof(event));
236-
gettimeofday(&event.time, 0);
241+
gettimeofday(&tval, 0);
242+
event.input_event_usec = tval.tv_usec;
243+
event.input_event_sec = tval.tv_sec;
237244
event.type = type;
238245
event.code = code;
239246
event.value = value;

0 commit comments

Comments
 (0)