Commit 4996976f authored by Michael Ellerman's avatar Michael Ellerman Committed by Shuah Khan

selftests: sync: Skip the test if kernel support is not found

The "Sync framework" test doesn't work if the kernel has no support,
obviously. Rather than reporting a failure, check for the kernel support
by looking for /sys/kernel/debug/sync/sw_sync, and if not found skip the
test.
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Reviewed-by: default avatarGustavo Padovan <gustavo.padovan@collabora.com>
Signed-off-by: default avatarShuah Khan <shuahkh@osg.samsung.com>
parent eff33cfa
...@@ -29,6 +29,7 @@ ...@@ -29,6 +29,7 @@
#include <unistd.h> #include <unistd.h>
#include <stdlib.h> #include <stdlib.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h>
#include <sys/wait.h> #include <sys/wait.h>
#include "synctest.h" #include "synctest.h"
...@@ -52,10 +53,22 @@ static int run_test(int (*test)(void), char *name) ...@@ -52,10 +53,22 @@ static int run_test(int (*test)(void), char *name)
exit(test()); exit(test());
} }
static int sync_api_supported(void)
{
struct stat sbuf;
return 0 == stat("/sys/kernel/debug/sync/sw_sync", &sbuf);
}
int main(void) int main(void)
{ {
int err = 0; int err = 0;
if (!sync_api_supported()) {
printf("SKIP: Sync framework not supported by kernel\n");
return 0;
}
printf("[RUN]\tTesting sync framework\n"); printf("[RUN]\tTesting sync framework\n");
err += RUN_TEST(test_alloc_timeline); err += RUN_TEST(test_alloc_timeline);
......
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