tools: iio: iio_generic_buffer: allow continuous looping
authorMartin Kelly <mkelly@xevo.com>
Fri, 18 May 2018 00:14:46 +0000 (17:14 -0700)
committerJonathan Cameron <Jonathan.Cameron@huawei.com>
Sun, 20 May 2018 13:55:58 +0000 (14:55 +0100)
Sometimes it's useful to stream samples forever, such as when
stress-testing a driver overnight to check for memory leaks or other
issues. When the program receives a signal, it will gracefully cleanup,
so it is still safe to terminate at any time.

Add support for specifying a negative -c option, meaning that we should
loop forever. To do so, we need to use a long long (instead of just
long) for num_loops so that current code specifying num_loops greater
than UNSIGNED_LONG_MAX doesn't break.

Signed-off-by: Martin Kelly <mkelly@xevo.com>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
tools/iio/iio_generic_buffer.c

index aa765c11992bf202669b550ed365729aa6e0dd78..3040830d779763de73c9fd665ffae1c47d758ad8 100644 (file)
@@ -248,7 +248,7 @@ void print_usage(void)
                "Capture, convert and output data from IIO device buffer\n"
                "  -a         Auto-activate all available channels\n"
                "  -A         Force-activate ALL channels\n"
-               "  -c <n>     Do n conversions\n"
+               "  -c <n>     Do n conversions, or loop forever if n < 0\n"
                "  -e         Disable wait for event (new data)\n"
                "  -g         Use trigger-less mode\n"
                "  -l <n>     Set buffer length to n samples\n"
@@ -330,12 +330,12 @@ static const struct option longopts[] = {
 
 int main(int argc, char **argv)
 {
-       unsigned long num_loops = 2;
+       unsigned long long num_loops = 2;
        unsigned long timedelay = 1000000;
        unsigned long buf_len = 128;
 
        ssize_t i;
-       unsigned long j;
+       unsigned long long j;
        unsigned long toread;
        int ret, c;
        int fp = -1;
@@ -369,7 +369,7 @@ int main(int argc, char **argv)
                        break;  
                case 'c':
                        errno = 0;
-                       num_loops = strtoul(optarg, &dummy, 10);
+                       num_loops = strtoll(optarg, &dummy, 10);
                        if (errno) {
                                ret = -errno;
                                goto error;
@@ -637,7 +637,7 @@ int main(int argc, char **argv)
                goto error;
        }
 
-       for (j = 0; j < num_loops; j++) {
+       for (j = 0; j < num_loops || num_loops < 0; j++) {
                if (!noevents) {
                        struct pollfd pfd = {
                                .fd = fp,