Log a few errors, specifically application bugs
authorPeter Hutterer <peter.hutterer@who-t.net>
Sat, 31 Aug 2013 02:53:36 +0000 (12:53 +1000)
committerPeter Hutterer <peter.hutterer@who-t.net>
Tue, 3 Sep 2013 07:01:40 +0000 (17:01 +1000)
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
Reviewed-by: Benjamin Tissoires <benjamin.tissoires@gmail.com>
libevdev/libevdev-uinput.c
libevdev/libevdev.c

index 88ec313..afebc0b 100644 (file)
@@ -260,8 +260,10 @@ libevdev_uinput_create_from_device(const struct libevdev *dev, int fd, struct li
                        return fd;
 
                new_device->fd_is_managed = 1;
-       } else if (fd < 0)
+       } else if (fd < 0) {
+               log_bug("Invalid fd %d\n", fd);
                return -EBADF;
+       }
 
        memset(&uidev, 0, sizeof(uidev));
 
@@ -301,6 +303,7 @@ libevdev_uinput_create_from_device(const struct libevdev *dev, int fd, struct li
        new_device->fd = fd;
 
        if (fetch_syspath_and_devnode(new_device) == -1) {
+               log_error("unable to fetch syspath or device node.\n");
                errno = ENODEV;
                goto error;
        }
index ff1fd07..dcf2beb 100644 (file)
@@ -158,8 +158,10 @@ libevdev_get_log_priority(void)
 LIBEVDEV_EXPORT int
 libevdev_change_fd(struct libevdev *dev, int fd)
 {
-       if (dev->fd == -1)
+       if (dev->fd == -1) {
+               log_bug("device not initialized. call libevdev_set_fd() first\n");
                return -1;
+       }
        dev->fd = fd;
        return 0;
 }
@@ -171,8 +173,10 @@ libevdev_set_fd(struct libevdev* dev, int fd)
        int i;
        char buf[256];
 
-       if (dev->fd != -1)
+       if (dev->fd != -1) {
+               log_bug("device already initialized.\n");
                return -EBADF;
+       }
 
        rc = ioctl(fd, EVIOCGBIT(0, sizeof(dev->bits)), dev->bits);
        if (rc < 0)
@@ -696,11 +700,15 @@ libevdev_next_event(struct libevdev *dev, unsigned int flags, struct input_event
 {
        int rc = 0;
 
-       if (dev->fd < 0)
+       if (dev->fd < 0) {
+               log_bug("device not initialized. call libevdev_set_fd() first\n");
                return -EBADF;
+       }
 
-       if (!(flags & (LIBEVDEV_READ_NORMAL|LIBEVDEV_READ_SYNC|LIBEVDEV_FORCE_SYNC)))
+       if (!(flags & (LIBEVDEV_READ_NORMAL|LIBEVDEV_READ_SYNC|LIBEVDEV_FORCE_SYNC))) {
+               log_bug("invalid flags %#x\n.\n", flags);
                return -EINVAL;
+       }
 
        if (flags & LIBEVDEV_READ_SYNC) {
                if (dev->sync_state == SYNC_NEEDED) {
@@ -782,8 +790,10 @@ libevdev_has_event_pending(struct libevdev *dev)
        struct pollfd fds = { dev->fd, POLLIN, 0 };
        int rc;
 
-       if (dev->fd < 0)
+       if (dev->fd < 0) {
+               log_bug("device not initialized. call libevdev_set_fd() first\n");
                return -EBADF;
+       }
 
        if (queue_num_elements(dev) != 0)
                return 1;
@@ -1164,8 +1174,10 @@ libevdev_kernel_set_abs_info(struct libevdev *dev, unsigned int code, const stru
 {
        int rc;
 
-       if (dev->fd < 0)
+       if (dev->fd < 0) {
+               log_bug("device not initialized. call libevdev_set_fd() first\n");
                return -EBADF;
+       }
 
        if (code > ABS_MAX)
                return -EINVAL;
@@ -1184,11 +1196,15 @@ libevdev_grab(struct libevdev *dev, enum libevdev_grab_mode grab)
 {
        int rc = 0;
 
-       if (dev->fd < 0)
+       if (dev->fd < 0) {
+               log_bug("device not initialized. call libevdev_set_fd() first\n");
                return -EBADF;
+       }
 
-       if (grab != LIBEVDEV_GRAB && grab != LIBEVDEV_UNGRAB)
+       if (grab != LIBEVDEV_GRAB && grab != LIBEVDEV_UNGRAB) {
+               log_bug("invalid grab parameter %#x\n", grab);
                return -EINVAL;
+       }
 
        if (grab == dev->grabbed)
                return 0;
@@ -1290,8 +1306,10 @@ libevdev_kernel_set_led_values(struct libevdev *dev, ...)
        int rc = 0;
        size_t nleds = 0;
 
-       if (dev->fd < 0)
+       if (dev->fd < 0) {
+               log_bug("device not initialized. call libevdev_set_fd() first\n");
                return -EBADF;
+       }
 
        memset(ev, 0, sizeof(ev));