summaryrefslogtreecommitdiff
path: root/tests/prime_self_import.c
diff options
context:
space:
mode:
authorDerek Morton <derek.j.morton@intel.com>2015-12-14 09:59:17 +0000
committerDaniel Vetter <daniel.vetter@ffwll.ch>2015-12-16 10:21:14 +0100
commit3953d2dd22ea1c87aa77e3a9415aaf767d2ec3ed (patch)
tree5d12d427bfa4543d7ed445f082a0b1e984716e16 /tests/prime_self_import.c
parent5a8d063e42c7b5843a0f069d4c2216f8f4fb81fe (diff)
gem_flink_race/prime_self_import: Improve test reliability
gem_flink_race and prime_self_import have subtests which read the number of open gem objects from debugfs to determine if objects have leaked during the test. However the test can fail sporadically if the number of gem objects changes due to other process activity. This patch introduces a change to check the number of gem objects several times to filter out any fluctuations. v2: Moved the common code to a library and made the loop android specific (Daniel Vetter) v3: Renamed get_stable_obj_count -> igt_get_stable_obj_count Signed-off-by: Derek Morton <derek.j.morton@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@intel.com>
Diffstat (limited to 'tests/prime_self_import.c')
-rw-r--r--tests/prime_self_import.c31
1 files changed, 6 insertions, 25 deletions
diff --git a/tests/prime_self_import.c b/tests/prime_self_import.c
index 91fe231e..992334d4 100644
--- a/tests/prime_self_import.c
+++ b/tests/prime_self_import.c
@@ -47,7 +47,7 @@
#include "drm.h"
IGT_TEST_DESCRIPTION("Check whether prime import/export works on the same"
- " device.");
+ " device... but with different fds.");
#define BO_SIZE (16*1024)
@@ -157,7 +157,7 @@ static void test_with_one_bo_two_files(void)
dma_buf_fd2 = prime_handle_to_fd(fd2, handle_open);
handle_import = prime_fd_to_handle(fd2, dma_buf_fd2);
- /* dma-buf selfimporting an flink bo should give the same handle */
+ /* dma-buf self importing an flink bo should give the same handle */
igt_assert_eq_u32(handle_import, handle_open);
close(fd1);
@@ -211,21 +211,6 @@ static void test_with_one_bo(void)
check_bo(fd2, handle_import1, fd2, handle_import1);
}
-static int get_object_count(void)
-{
- FILE *file;
- int ret, scanned;
-
- igt_drop_caches_set(DROP_RETIRE | DROP_ACTIVE);
-
- file = igt_debugfs_fopen("i915_gem_objects", "r");
-
- scanned = fscanf(file, "%i objects", &ret);
- igt_assert_eq(scanned, 1);
-
- return ret;
-}
-
static void *thread_fn_reimport_vs_close(void *p)
{
struct drm_gem_close close_bo;
@@ -258,8 +243,7 @@ static void test_reimport_close_race(void)
* up the counts */
fake = drm_open_driver(DRIVER_INTEL);
- gem_quiescent_gpu(fake);
- obj_count = get_object_count();
+ obj_count = igt_get_stable_obj_count(fake);
num_threads = sysconf(_SC_NPROCESSORS_ONLN);
@@ -290,8 +274,7 @@ static void test_reimport_close_race(void)
close(fds[0]);
close(fds[1]);
- gem_quiescent_gpu(fake);
- obj_count = get_object_count() - obj_count;
+ obj_count = igt_get_stable_obj_count(fake) - obj_count;
igt_info("leaked %i objects\n", obj_count);
@@ -350,8 +333,7 @@ static void test_export_close_race(void)
* up the counts */
fake = drm_open_driver(DRIVER_INTEL);
- gem_quiescent_gpu(fake);
- obj_count = get_object_count();
+ obj_count = igt_get_stable_obj_count(fake);
fd = drm_open_driver(DRIVER_INTEL);
@@ -373,8 +355,7 @@ static void test_export_close_race(void)
close(fd);
- gem_quiescent_gpu(fake);
- obj_count = get_object_count() - obj_count;
+ obj_count = igt_get_stable_obj_count(fake) - obj_count;
igt_info("leaked %i objects\n", obj_count);