diff options
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/gem_exec_nop.c | 34 | ||||
| -rw-r--r-- | tests/gem_exec_schedule.c | 47 | ||||
| -rw-r--r-- | tests/gem_exec_whisper.c | 22 | ||||
| -rw-r--r-- | tests/gem_sync.c | 34 | 
4 files changed, 15 insertions, 122 deletions
| diff --git a/tests/gem_exec_nop.c b/tests/gem_exec_nop.c index feb89ee3..8fd31e83 100644 --- a/tests/gem_exec_nop.c +++ b/tests/gem_exec_nop.c @@ -44,8 +44,6 @@  #include <time.h>  #include "drm.h" -#define BIT(x) (1ul << (x)) -  #define LOCAL_I915_EXEC_NO_RELOC (1<<11)  #define LOCAL_I915_EXEC_HANDLE_LUT (1<<12) @@ -54,10 +52,6 @@  #define ENGINE_FLAGS  (I915_EXEC_RING_MASK | LOCAL_I915_EXEC_BSD_MASK) -#define LOCAL_PARAM_HAS_SCHEDULER 41 -#define   HAS_SCHEDULER		BIT(0) -#define   HAS_PRIORITY		BIT(1) -#define   HAS_PREEMPTION	BIT(2)  #define LOCAL_CONTEXT_PARAM_PRIORITY 6  #define   MAX_PRIO 1023  #define   MIN_PRIO -1023 @@ -665,31 +659,9 @@ static void preempt(int fd, uint32_t handle,  		 ring_name, count, elapsed(&start, &now)*1e6 / count);  } -static unsigned int has_scheduler(int fd) -{ -	drm_i915_getparam_t gp; -	unsigned int caps = 0; - -	gp.param = LOCAL_PARAM_HAS_SCHEDULER; -	gp.value = (int *)∩︀ -	drmIoctl(fd, DRM_IOCTL_I915_GETPARAM, &gp); - -	if (!caps) -		return 0; - -	igt_info("Has kernel scheduler\n"); -	if (caps & HAS_PRIORITY) -		igt_info(" - With priority sorting\n"); -	if (caps & HAS_PREEMPTION) -		igt_info(" - With preemption enabled\n"); - -	return caps; -} -  igt_main  {  	const struct intel_execution_engine *e; -	unsigned int sched_caps = 0;  	uint32_t handle = 0;  	int device = -1; @@ -699,7 +671,7 @@ igt_main  		device = drm_open_driver(DRIVER_INTEL);  		igt_require_gem(device);  		gem_show_submission_method(device); -		sched_caps = has_scheduler(device); +		gem_scheduler_print_capability(device);  		handle = gem_create(device, 4096);  		gem_write(device, handle, 0, &bbe, sizeof(bbe)); @@ -746,8 +718,8 @@ igt_main  	igt_subtest_group {  		igt_fixture { -			igt_require(sched_caps & HAS_PRIORITY); -			igt_require(sched_caps & HAS_PREEMPTION); +			igt_require(gem_scheduler_has_ctx_priority(device)); +			igt_require(gem_scheduler_has_preemption(device));  		}  		for (e = intel_execution_engines; e->name; e++) { diff --git a/tests/gem_exec_schedule.c b/tests/gem_exec_schedule.c index f5c849d0..66e24244 100644 --- a/tests/gem_exec_schedule.c +++ b/tests/gem_exec_schedule.c @@ -33,12 +33,6 @@  #include "igt_rand.h"  #include "igt_sysfs.h" -#define BIT(x) (1ul << (x)) - -#define LOCAL_PARAM_HAS_SCHEDULER 41 -#define   HAS_SCHEDULER		BIT(0) -#define   HAS_PRIORITY		BIT(1) -#define   HAS_PREEMPTION	BIT(2)  #define LOCAL_CONTEXT_PARAM_PRIORITY 6  #define LO 0 @@ -70,11 +64,6 @@ static void ctx_set_priority(int fd, uint32_t ctx, int prio)  	igt_assert_eq(__ctx_set_priority(fd, ctx, prio), 0);  } -static void ctx_has_priority(int fd) -{ -	igt_require(__ctx_set_priority(fd, 0, MAX_PRIO) == 0); -} -  static void store_dword(int fd, uint32_t ctx, unsigned ring,  			uint32_t target, uint32_t offset, uint32_t value,  			uint32_t cork, unsigned write_domain) @@ -979,31 +968,9 @@ static void test_pi_ringfull(int fd, unsigned int engine)  	munmap(result, 4096);  } -static unsigned int has_scheduler(int fd) -{ -	drm_i915_getparam_t gp; -	unsigned int caps = 0; - -	gp.param = LOCAL_PARAM_HAS_SCHEDULER; -	gp.value = (int *)∩︀ -	drmIoctl(fd, DRM_IOCTL_I915_GETPARAM, &gp); - -	if (!caps) -		return 0; - -	igt_info("Has kernel scheduler\n"); -	if (caps & HAS_PRIORITY) -		igt_info(" - With priority sorting\n"); -	if (caps & HAS_PREEMPTION) -		igt_info(" - With preemption enabled\n"); - -	return caps; -} -  igt_main  {  	const struct intel_execution_engine *e; -	unsigned int sched_caps = 0;  	int fd = -1;  	igt_skip_on_simulation(); @@ -1011,7 +978,7 @@ igt_main  	igt_fixture {  		fd = drm_open_driver_master(DRIVER_INTEL);  		gem_show_submission_method(fd); -		sched_caps = has_scheduler(fd); +		gem_scheduler_print_capability(fd);  		igt_require_gem(fd);  		gem_require_mmap_wc(fd);  		igt_fork_hang_detector(fd); @@ -1033,8 +1000,8 @@ igt_main  	igt_subtest_group {  		igt_fixture { -			igt_require(sched_caps & HAS_SCHEDULER); -			ctx_has_priority(fd); +			igt_require(gem_scheduler_enabled(fd)); +			igt_require(gem_scheduler_has_ctx_priority(fd));  		}  		igt_subtest("smoketest-all") @@ -1062,7 +1029,7 @@ igt_main  				igt_subtest_group {  					igt_fixture { -						igt_require(sched_caps & HAS_PREEMPTION); +						igt_require(gem_scheduler_has_preemption(fd));  					}  					igt_subtest_f("preempt-%s", e->name) @@ -1095,8 +1062,8 @@ igt_main  	igt_subtest_group {  		igt_fixture { -			igt_require(sched_caps & HAS_SCHEDULER); -			ctx_has_priority(fd); +			igt_require(gem_scheduler_enabled(fd)); +			igt_require(gem_scheduler_has_ctx_priority(fd));  			/* need separate rings */  			igt_require(gem_has_execlists(fd)); @@ -1106,7 +1073,7 @@ igt_main  			igt_subtest_group {  				igt_fixture {  					gem_require_ring(fd, e->exec_id | e->flags); -					igt_require(sched_caps & HAS_PREEMPTION); +					igt_require(gem_scheduler_has_preemption(fd));  				}  				igt_subtest_f("pi-ringfull-%s", e->name) diff --git a/tests/gem_exec_whisper.c b/tests/gem_exec_whisper.c index e7f7b1f1..5ff8f396 100644 --- a/tests/gem_exec_whisper.c +++ b/tests/gem_exec_whisper.c @@ -191,21 +191,8 @@ static void fini_hang(struct hang *h)  	close(h->fd);  } -#define LOCAL_PARAM_HAS_SCHEDULER 41  #define LOCAL_CONTEXT_PARAM_PRIORITY 6 -static bool __has_scheduler(int fd) -{ -	drm_i915_getparam_t gp; -	int has = -1; - -	gp.param = LOCAL_PARAM_HAS_SCHEDULER; -	gp.value = &has; -	drmIoctl(fd, DRM_IOCTL_I915_GETPARAM, &gp); - -	return has > 0; -} -  static int __ctx_set_priority(int fd, uint32_t ctx, int prio)  {  	struct local_i915_gem_context_param param; @@ -250,13 +237,8 @@ static void whisper(int fd, unsigned engine, unsigned flags)  	int debugfs;  	if (flags & PRIORITY) { -		int __fd = drm_open_driver(DRIVER_INTEL); -		bool has_scheduler = __has_scheduler(__fd); -		bool ctx_has_priority = -			__ctx_set_priority(__fd, 0, 1) == 0; -		close(__fd); - -		igt_require(has_scheduler && ctx_has_priority); +		igt_require(gem_scheduler_enabled(fd)); +		igt_require(gem_scheduler_has_ctx_priority(fd));  	}  	debugfs = igt_debugfs_dir(fd); diff --git a/tests/gem_sync.c b/tests/gem_sync.c index f0c5d76f..fda70344 100644 --- a/tests/gem_sync.c +++ b/tests/gem_sync.c @@ -27,18 +27,12 @@  #include "igt.h"  #include "igt_sysfs.h" -#define BIT(x) (1ul << (x)) -  #define LOCAL_I915_EXEC_NO_RELOC (1<<11)  #define LOCAL_I915_EXEC_HANDLE_LUT (1<<12)  #define LOCAL_I915_EXEC_BSD_SHIFT      (13)  #define LOCAL_I915_EXEC_BSD_MASK       (3 << LOCAL_I915_EXEC_BSD_SHIFT) -#define LOCAL_PARAM_HAS_SCHEDULER 41 -#define   HAS_SCHEDULER		BIT(0) -#define   HAS_PRIORITY		BIT(1) -#define   HAS_PREEMPTION	BIT(2)  #define LOCAL_CONTEXT_PARAM_PRIORITY 6  #define   MAX_PRIO 1023  #define   MIN_PRIO -1023 @@ -807,32 +801,10 @@ preempt(int fd, unsigned ring, int num_children, int timeout)  	gem_context_destroy(fd, ctx[0]);  } -static unsigned int has_scheduler(int fd) -{ -	drm_i915_getparam_t gp; -	unsigned int caps = 0; - -	gp.param = LOCAL_PARAM_HAS_SCHEDULER; -	gp.value = (int *)∩︀ -	drmIoctl(fd, DRM_IOCTL_I915_GETPARAM, &gp); - -	if (!caps) -		return 0; - -	igt_info("Has kernel scheduler\n"); -	if (caps & HAS_PRIORITY) -		igt_info(" - With priority sorting\n"); -	if (caps & HAS_PREEMPTION) -		igt_info(" - With preemption enabled\n"); - -	return caps; -} -  igt_main  {  	const struct intel_execution_engine *e;  	const int ncpus = sysconf(_SC_NPROCESSORS_ONLN); -	unsigned int sched_caps = 0;  	int fd = -1;  	igt_skip_on_simulation(); @@ -841,7 +813,7 @@ igt_main  		fd = drm_open_driver(DRIVER_INTEL);  		igt_require_gem(fd);  		gem_show_submission_method(fd); -		sched_caps = has_scheduler(fd); +		gem_scheduler_print_capability(fd);  		igt_fork_hang_detector(fd);  	} @@ -886,8 +858,8 @@ igt_main  	igt_subtest_group {  		igt_fixture { -			igt_require(sched_caps & HAS_PRIORITY); -			igt_require(sched_caps & HAS_PREEMPTION); +			igt_require(gem_scheduler_has_ctx_priority(fd)); +			igt_require(gem_scheduler_has_preemption(fd));  		}  		igt_subtest("preempt-all") | 
