From 2114e08a87b723891daa5ea215d3a188be8a6ac7 Mon Sep 17 00:00:00 2001 From: "Dmitry V. Levin" Date: Fri, 27 May 2016 00:40:02 +0000 Subject: [PATCH] evdev.c: decode all directions except _IOC_READ on entering syscall * evdev.c (evdev_write_ioctl): Remove exiting check. (evdev_read_ioctl): Move entering check ... (evdev_ioctl): ... here. Add RVAL_DECODED to return code in _IOC_WRITE and default cases. --- evdev.c | 14 ++++---------- 1 file changed, 4 insertions(+), 10 deletions(-) diff --git a/evdev.c b/evdev.c index 1bd9c88b..dd068a86 100644 --- a/evdev.c +++ b/evdev.c @@ -310,9 +310,6 @@ repeat_ioctl(struct tcb *tcp, long arg) static int evdev_read_ioctl(struct tcb *tcp, const unsigned int code, long arg) { - if (entering(tcp)) - return 1; - if (syserror(tcp)) return 0; @@ -425,9 +422,6 @@ evdev_read_ioctl(struct tcb *tcp, const unsigned int code, long arg) static int evdev_write_ioctl(struct tcb *tcp, const unsigned int code, long arg) { - if (exiting(tcp)) - return 1; - if ((_IOC_NR(code) & ~ABS_MAX) == _IOC_NR(EVIOCSABS(0))) return abs_ioctl(tcp, arg); @@ -465,13 +459,13 @@ evdev_ioctl(struct tcb *tcp, const unsigned int code, long arg) { switch(_IOC_DIR(code)) { case _IOC_READ: + if (entering(tcp)) + return 0; return evdev_read_ioctl(tcp, code, arg); case _IOC_WRITE: - if (!evdev_write_ioctl(tcp, code, arg)) - tprintf(", %lx", arg); - return 1; + return evdev_write_ioctl(tcp, code, arg) | RVAL_DECODED; default: - return 0; + return RVAL_DECODED; } }