Commit 3b90040d authored by Axel Haslam's avatar Axel Haslam Committed by Greg Kroah-Hartman

greybus: loopback_test: handle SIGINT signal

Adding a default timeout may not be representative of every
usecase for gb_loopback. Also, tests may continue to run
on the driver in case of a timeout.

To avoid adding a default timeout, handle SIGINT so that when the user
presses ctrl-c the test are stoped. The user can still specify a timeout
value with the -O option.
Signed-off-by: default avatarAxel Haslam <ahaslam@baylibre.com>
Reviewed-by: default avatarBryan O'Donoghue <bryan.odonoghue@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@google.com>
parent fece9c87
...@@ -17,13 +17,13 @@ ...@@ -17,13 +17,13 @@
#include <time.h> #include <time.h>
#include <unistd.h> #include <unistd.h>
#include <dirent.h> #include <dirent.h>
#include <signal.h>
#define MAX_NUM_DEVICES 10 #define MAX_NUM_DEVICES 10
#define MAX_SYSFS_PATH 0x200 #define MAX_SYSFS_PATH 0x200
#define CSV_MAX_LINE 0x1000 #define CSV_MAX_LINE 0x1000
#define SYSFS_MAX_INT 0x20 #define SYSFS_MAX_INT 0x20
#define MAX_STR_LEN 255 #define MAX_STR_LEN 255
#define DEFAULT_POLL_TIMEOUT_SEC 30
#define DEFAULT_ASYNC_TIMEOUT 200000 #define DEFAULT_ASYNC_TIMEOUT 200000
struct dict { struct dict {
...@@ -88,7 +88,6 @@ struct loopback_test { ...@@ -88,7 +88,6 @@ struct loopback_test {
int list_devices; int list_devices;
int use_async; int use_async;
int async_timeout; int async_timeout;
int poll_timeout;
int async_outstanding_operations; int async_outstanding_operations;
int us_wait; int us_wait;
int file_output; int file_output;
...@@ -96,6 +95,7 @@ struct loopback_test { ...@@ -96,6 +95,7 @@ struct loopback_test {
char test_name[MAX_STR_LEN]; char test_name[MAX_STR_LEN];
char sysfs_prefix[MAX_SYSFS_PATH]; char sysfs_prefix[MAX_SYSFS_PATH];
char debugfs_prefix[MAX_SYSFS_PATH]; char debugfs_prefix[MAX_SYSFS_PATH];
struct timespec poll_timeout;
struct loopback_device devices[MAX_NUM_DEVICES]; struct loopback_device devices[MAX_NUM_DEVICES];
struct loopback_results aggregate_results; struct loopback_results aggregate_results;
struct pollfd fds[MAX_NUM_DEVICES]; struct pollfd fds[MAX_NUM_DEVICES];
...@@ -706,22 +706,51 @@ static int is_complete(struct loopback_test *t) ...@@ -706,22 +706,51 @@ static int is_complete(struct loopback_test *t)
return 1; return 1;
} }
static void stop_tests(struct loopback_test *t)
{
int i;
for (i = 0; i < t->device_count; i++) {
if (!device_enabled(t, i))
continue;
write_sysfs_val(t->devices[i].sysfs_entry, "type", 0);
}
}
static void handler(int sig) { /* do nothing */ }
static int wait_for_complete(struct loopback_test *t) static int wait_for_complete(struct loopback_test *t)
{ {
int number_of_events = 0; int number_of_events = 0;
char dummy; char dummy;
int ret; int ret;
int i; int i;
struct timespec *ts = NULL;
struct sigaction sa;
sigset_t mask_old, mask;
sigemptyset(&mask);
sigemptyset(&mask_old);
sigaddset(&mask, SIGINT);
sigprocmask(SIG_BLOCK, &mask, &mask_old);
sa.sa_handler = handler;
sa.sa_flags = 0;
sigemptyset(&sa.sa_mask);
if (sigaction(SIGINT, &sa, NULL) == -1) {
fprintf(stderr, "sigaction error\n");
return -1;
}
if (t->poll_timeout.tv_sec != 0)
ts = &t->poll_timeout;
while (1) { while (1) {
ret = poll(t->fds, t->poll_count, t->poll_timeout * 1000);
if (ret == 0) {
fprintf(stderr, "Poll timmed out!\n");
return -1;
}
if (ret < 0) { ret = ppoll(t->fds, t->poll_count, ts, &mask_old);
fprintf(stderr, "Poll Error!\n"); if (ret <= 0) {
stop_tests(t);
fprintf(stderr, "Poll exit with errno %d\n", errno);
return -1; return -1;
} }
...@@ -861,6 +890,7 @@ static int sanity_check(struct loopback_test *t) ...@@ -861,6 +890,7 @@ static int sanity_check(struct loopback_test *t)
return 0; return 0;
} }
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
int o, ret; int o, ret;
...@@ -915,7 +945,7 @@ int main(int argc, char *argv[]) ...@@ -915,7 +945,7 @@ int main(int argc, char *argv[])
t.async_timeout = atoi(optarg); t.async_timeout = atoi(optarg);
break; break;
case 'O': case 'O':
t.poll_timeout = atoi(optarg); t.poll_timeout.tv_sec = atoi(optarg);
break; break;
case 'c': case 'c':
t.async_outstanding_operations = atoi(optarg); t.async_outstanding_operations = atoi(optarg);
...@@ -955,9 +985,6 @@ int main(int argc, char *argv[]) ...@@ -955,9 +985,6 @@ int main(int argc, char *argv[])
if (t.async_timeout == 0) if (t.async_timeout == 0)
t.async_timeout = DEFAULT_ASYNC_TIMEOUT; t.async_timeout = DEFAULT_ASYNC_TIMEOUT;
if (t.poll_timeout == 0)
t.poll_timeout = DEFAULT_POLL_TIMEOUT_SEC;
loopback_run(&t); loopback_run(&t);
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment