diff options
author | cbdev <cb@cbcdn.com> | 2021-01-16 11:43:10 +0100 |
---|---|---|
committer | cbdev <cb@cbcdn.com> | 2021-01-16 11:43:10 +0100 |
commit | b199f019b47829f3745e8af8e62ed1ac4e65acf9 (patch) | |
tree | 43bdc3f1e6b7e9559c21d33692053330f90edbda /backends/evdev.c | |
parent | 71d86ec46259ce1b5488989ec30152c7cf810a8e (diff) | |
download | midimonster-b199f019b47829f3745e8af8e62ed1ac4e65acf9.tar.gz midimonster-b199f019b47829f3745e8af8e62ed1ac4e65acf9.tar.bz2 midimonster-b199f019b47829f3745e8af8e62ed1ac4e65acf9.zip |
Exit when losing evdev connection
Diffstat (limited to 'backends/evdev.c')
-rw-r--r-- | backends/evdev.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/backends/evdev.c b/backends/evdev.c index 4c734f9..3dbf837 100644 --- a/backends/evdev.c +++ b/backends/evdev.c @@ -367,7 +367,9 @@ static int evdev_handle(size_t num, managed_fd* fds){ data = (evdev_instance_data*) inst->impl; - for(read_status = libevdev_next_event(data->input_ev, read_flags, &ev); read_status >= 0; read_status = libevdev_next_event(data->input_ev, read_flags, &ev)){ + for(read_status = libevdev_next_event(data->input_ev, read_flags, &ev); + read_status == LIBEVDEV_READ_STATUS_SUCCESS || read_status == LIBEVDEV_READ_STATUS_SYNC; + read_status = libevdev_next_event(data->input_ev, read_flags, &ev)){ read_flags = LIBEVDEV_READ_FLAG_NORMAL; if(read_status == LIBEVDEV_READ_STATUS_SYNC){ read_flags = LIBEVDEV_READ_FLAG_SYNC; @@ -383,6 +385,11 @@ static int evdev_handle(size_t num, managed_fd* fds){ return 1; } } + + if(read_status != -EAGAIN){ + LOGPF("Failed to handle events: %s\n", strerror(-read_status)); + return 1; + } } return 0; |