summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAdam Jackson <ajax@redhat.com>2009-02-24 10:08:22 +1000
committerPeter Hutterer <peter.hutterer@who-t.net>2009-02-26 09:11:02 +1000
commit7977947e0df6ea6379dab76805b06be6bdd71947 (patch)
tree8050fdf138c16a12c0101bdd0a7b80f3ee9d80b5
parent11a56d4a176a2c5b2f8794147d4bafd88477b80b (diff)
Reduce the number of read calls in ReadInput.
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net> Signed-off-by: Adam Jackson <ajax@redhat.com>
-rw-r--r--src/evdev.c36
1 files changed, 22 insertions, 14 deletions
diff --git a/src/evdev.c b/src/evdev.c
index 50ca103..c9fd53b 100644
--- a/src/evdev.c
+++ b/src/evdev.c
@@ -507,23 +507,21 @@ EvdevProcessEvent(InputInfoPtr pInfo, struct input_event *ev)
}
}
+/* just a magic number to reduce the number of reads */
+#define NUM_EVENTS 16
+
static void
EvdevReadInput(InputInfoPtr pInfo)
{
- struct input_event ev;
- int len;
+ struct input_event ev[NUM_EVENTS];
+ int i, len = sizeof(ev);
EvdevPtr pEvdev = pInfo->private;
- while (1) {
- len = read(pInfo->fd, &ev, sizeof ev);
- if (len != sizeof ev) {
- if (errno == EAGAIN)
- break;
-
- /* The kernel promises that we always only read a complete
- * event, so len != sizeof ev is an error. */
- xf86Msg(X_ERROR, "%s: Read error: %s\n", pInfo->name, strerror(errno));
-
+ while (len == sizeof(ev))
+ {
+ len = read(pInfo->fd, &ev, sizeof(ev));
+ if (len == 0)
+ {
if (errno == ENODEV) /* May happen after resume */
{
xf86RemoveEnabledDevice(pInfo);
@@ -531,11 +529,21 @@ EvdevReadInput(InputInfoPtr pInfo)
pInfo->fd = -1;
pEvdev->reopen_left = pEvdev->reopen_attempts;
pEvdev->reopen_timer = TimerSet(NULL, 0, 100, EvdevReopenTimer, pInfo);
- }
+ } else if (errno != EAGAIN)
+ xf86Msg(X_ERROR, "%s: Read error: %s\n", pInfo->name,
+ strerror(errno));
+ break;
+ }
+
+ if (len % sizeof(ev[0])) {
+ /* The kernel promises that we always only read a complete
+ * event, so len != sizeof ev is an error. */
+ xf86Msg(X_ERROR, "%s: Read error: %s\n", pInfo->name, strerror(errno));
break;
}
- EvdevProcessEvent(pInfo, &ev);
+ for (i = 0; i < len/sizeof(ev[0]); i++)
+ EvdevProcessEvent(pInfo, &ev[i]);
}
}