diff options
author | Daniel Vetter <daniel.vetter@ffwll.ch> | 2013-08-13 13:20:58 +0200 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2013-08-13 15:15:18 +0200 |
commit | 8f5387eb99b640771812d28a0b949aca729bf296 (patch) | |
tree | 4ccb29a62ff7c4f055cf18fe31c9482ad16ae698 /tests/gem_exec_nop.c | |
parent | 5e25fcc285240353ab15bd4c3a0d0e02d970f45b (diff) |
tests: introduce igt_require
Since igt_skip has funny control flow we can abuse it and make it work
like a special kind of assert which automatically skips tests if a
requirement fails.
Note that in places where we have a less strict test which should
always succeed (e.g. ioctl works or isn't available) the igt_assert
should be place before the igt_require with the more strict
requirements. Otherwise we'll skip a test instead of properly failing
it.
Convert a few users of igt_skip over to igt_require to showcase its
use.
v2: s/gem_check_/gem_require_/ so that we consistently use "require"
to indicate magic check that can call igt_skip. Imo hiding the
igt_require for feature checks is ok, but for more traditional assert
like use cases an explicit igt_require might be better.
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'tests/gem_exec_nop.c')
-rw-r--r-- | tests/gem_exec_nop.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/tests/gem_exec_nop.c b/tests/gem_exec_nop.c index 4cb157ca..47bcf108 100644 --- a/tests/gem_exec_nop.c +++ b/tests/gem_exec_nop.c @@ -92,6 +92,8 @@ static void loop(int fd, uint32_t handle, unsigned ring_id, const char *ring_nam { int count; + gem_require_ring(fd, ring_id); + for (count = 1; count <= SLOW_QUICK(1<<17, 1<<4); count <<= 1) { struct timeval start, end; @@ -103,8 +105,8 @@ static void loop(int fd, uint32_t handle, unsigned ring_id, const char *ring_nam count, elapsed(&start, &end, count), ring_name); fflush(stdout); } - } + int main(int argc, char **argv) { uint32_t batch[2] = {MI_BATCH_BUFFER_END}; @@ -122,16 +124,13 @@ int main(int argc, char **argv) loop(fd, handle, I915_EXEC_RENDER, "render"); igt_subtest("bsd") - if (gem_check_blt(fd)) - loop(fd, handle, I915_EXEC_BSD, "bsd"); + loop(fd, handle, I915_EXEC_BSD, "bsd"); igt_subtest("blt") - if (gem_check_blt(fd)) - loop(fd, handle, I915_EXEC_BLT, "blt"); + loop(fd, handle, I915_EXEC_BLT, "blt"); igt_subtest("vebox") - if (gem_check_vebox(fd)) - loop(fd, handle, LOCAL_I915_EXEC_VEBOX, "vebox"); + loop(fd, handle, LOCAL_I915_EXEC_VEBOX, "vebox"); gem_close(fd, handle); |