diff options
author | Emilio López <emilio.lopez@collabora.co.uk> | 2016-10-19 08:49:50 -0400 |
---|---|---|
committer | Shuah Khan <shuahkh@osg.samsung.com> | 2016-12-01 20:13:06 -0500 |
commit | 1c5839c6eefbb938052c57bc32f66b6f276431f3 (patch) | |
tree | a714b38df03e95163f81102d89b7c52fc8d5b103 | |
parent | 6a5b7d2c55ca8eca3dc5cc6355885e286ef6df7f (diff) |
selftest: sync: merge tests for sw_sync framework
These tests are based on the libsync test suite from Android.
This commit includes tests for basic merge operations.
Signed-off-by: Emilio López <emilio.lopez@collabora.co.uk>
Signed-off-by: Shuah Khan <shuahkh@osg.samsung.com>
-rw-r--r-- | tools/testing/selftests/sync/Makefile | 1 | ||||
-rw-r--r-- | tools/testing/selftests/sync/sync_merge.c | 60 | ||||
-rw-r--r-- | tools/testing/selftests/sync/sync_test.c | 1 | ||||
-rw-r--r-- | tools/testing/selftests/sync/synctest.h | 3 |
4 files changed, 65 insertions, 0 deletions
diff --git a/tools/testing/selftests/sync/Makefile b/tools/testing/selftests/sync/Makefile index 69e18b34ee1b..a39497d8cb4a 100644 --- a/tools/testing/selftests/sync/Makefile +++ b/tools/testing/selftests/sync/Makefile | |||
@@ -12,6 +12,7 @@ OBJS = sync_test.o sync.o | |||
12 | 12 | ||
13 | TESTS += sync_alloc.o | 13 | TESTS += sync_alloc.o |
14 | TESTS += sync_fence.o | 14 | TESTS += sync_fence.o |
15 | TESTS += sync_merge.o | ||
15 | 16 | ||
16 | sync_test: $(OBJS) $(TESTS) | 17 | sync_test: $(OBJS) $(TESTS) |
17 | 18 | ||
diff --git a/tools/testing/selftests/sync/sync_merge.c b/tools/testing/selftests/sync/sync_merge.c new file mode 100644 index 000000000000..8914d43395c7 --- /dev/null +++ b/tools/testing/selftests/sync/sync_merge.c | |||
@@ -0,0 +1,60 @@ | |||
1 | /* | ||
2 | * sync fence merge tests | ||
3 | * Copyright 2015-2016 Collabora Ltd. | ||
4 | * | ||
5 | * Based on the implementation from the Android Open Source Project, | ||
6 | * | ||
7 | * Copyright 2012 Google, Inc | ||
8 | * | ||
9 | * Permission is hereby granted, free of charge, to any person obtaining a | ||
10 | * copy of this software and associated documentation files (the "Software"), | ||
11 | * to deal in the Software without restriction, including without limitation | ||
12 | * the rights to use, copy, modify, merge, publish, distribute, sublicense, | ||
13 | * and/or sell copies of the Software, and to permit persons to whom the | ||
14 | * Software is furnished to do so, subject to the following conditions: | ||
15 | * | ||
16 | * The above copyright notice and this permission notice shall be included in | ||
17 | * all copies or substantial portions of the Software. | ||
18 | * | ||
19 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
20 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
21 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL | ||
22 | * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR | ||
23 | * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, | ||
24 | * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR | ||
25 | * OTHER DEALINGS IN THE SOFTWARE. | ||
26 | */ | ||
27 | |||
28 | #include "sync.h" | ||
29 | #include "sw_sync.h" | ||
30 | #include "synctest.h" | ||
31 | |||
32 | int test_fence_merge_same_fence(void) | ||
33 | { | ||
34 | int fence, valid, merged; | ||
35 | int timeline = sw_sync_timeline_create(); | ||
36 | |||
37 | valid = sw_sync_timeline_is_valid(timeline); | ||
38 | ASSERT(valid, "Failure allocating timeline\n"); | ||
39 | |||
40 | fence = sw_sync_fence_create(timeline, "allocFence", 5); | ||
41 | valid = sw_sync_fence_is_valid(fence); | ||
42 | ASSERT(valid, "Failure allocating fence\n"); | ||
43 | |||
44 | merged = sync_merge("mergeFence", fence, fence); | ||
45 | valid = sw_sync_fence_is_valid(fence); | ||
46 | ASSERT(valid, "Failure merging fence\n"); | ||
47 | |||
48 | ASSERT(sync_fence_count_with_status(merged, FENCE_STATUS_SIGNALED) == 0, | ||
49 | "fence signaled too early!\n"); | ||
50 | |||
51 | sw_sync_timeline_inc(timeline, 5); | ||
52 | ASSERT(sync_fence_count_with_status(merged, FENCE_STATUS_SIGNALED) == 1, | ||
53 | "fence did not signal!\n"); | ||
54 | |||
55 | sw_sync_fence_destroy(merged); | ||
56 | sw_sync_fence_destroy(fence); | ||
57 | sw_sync_timeline_destroy(timeline); | ||
58 | |||
59 | return 0; | ||
60 | } | ||
diff --git a/tools/testing/selftests/sync/sync_test.c b/tools/testing/selftests/sync/sync_test.c index b442292bdfc9..ab37eee8749a 100644 --- a/tools/testing/selftests/sync/sync_test.c +++ b/tools/testing/selftests/sync/sync_test.c | |||
@@ -64,6 +64,7 @@ int main(void) | |||
64 | 64 | ||
65 | err += RUN_TEST(test_fence_one_timeline_wait); | 65 | err += RUN_TEST(test_fence_one_timeline_wait); |
66 | err += RUN_TEST(test_fence_one_timeline_merge); | 66 | err += RUN_TEST(test_fence_one_timeline_merge); |
67 | err += RUN_TEST(test_fence_merge_same_fence); | ||
67 | 68 | ||
68 | if (err) | 69 | if (err) |
69 | printf("[FAIL]\tsync errors: %d\n", err); | 70 | printf("[FAIL]\tsync errors: %d\n", err); |
diff --git a/tools/testing/selftests/sync/synctest.h b/tools/testing/selftests/sync/synctest.h index 6505c281c7b3..c3b0b5ec4fa8 100644 --- a/tools/testing/selftests/sync/synctest.h +++ b/tools/testing/selftests/sync/synctest.h | |||
@@ -48,4 +48,7 @@ int test_alloc_fence_negative(void); | |||
48 | int test_fence_one_timeline_wait(void); | 48 | int test_fence_one_timeline_wait(void); |
49 | int test_fence_one_timeline_merge(void); | 49 | int test_fence_one_timeline_merge(void); |
50 | 50 | ||
51 | /* Fence merge tests */ | ||
52 | int test_fence_merge_same_fence(void); | ||
53 | |||
51 | #endif | 54 | #endif |