tools:iio:generic_buffer: add error handling
authorHartmut Knaack <knaack.h@gmx.de>
Sun, 31 May 2015 12:40:04 +0000 (14:40 +0200)
committerJonathan Cameron <jic23@kernel.org>
Sun, 31 May 2015 18:24:18 +0000 (19:24 +0100)
Add error handling to calls which can indicate a major problem by
returning an error code.

Signed-off-by: Hartmut Knaack <knaack.h@gmx.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
tools/iio/generic_buffer.c

index 93ac93f745497a12eb8239b9563e96f4fae175fd..cf9a4120204f89a629d34f73bc7c813dd385f7c1 100644 (file)
@@ -347,7 +347,14 @@ int main(int argc, char **argv)
                                .events = POLLIN,
                        };
 
-                       poll(&pfd, 1, -1);
+                       ret = poll(&pfd, 1, -1);
+                       if (ret < 0) {
+                               ret = -errno;
+                               goto error_close_buffer_access;
+                       } else if (ret == 0) {
+                               continue;
+                       }
+
                        toread = buf_len;
 
                } else {
@@ -378,11 +385,14 @@ int main(int argc, char **argv)
 
        if (!notrigger)
                /* Disconnect the trigger - just write a dummy name. */
-               write_sysfs_string("trigger/current_trigger",
-                                  dev_dir_name, "NULL");
+               ret = write_sysfs_string("trigger/current_trigger",
+                                        dev_dir_name, "NULL");
+               if (ret < 0)
+                       printf("Failed to write to %s\n", dev_dir_name);
 
 error_close_buffer_access:
-       close(fp);
+       if (close(fp) == -1)
+               perror("Failed to close buffer");
 error_free_buffer_access:
        free(buffer_access);
 error_free_data: