diff options
| author | Chris Wilson <chris@chris-wilson.co.uk> | 2017-05-16 21:31:59 +0100 | 
|---|---|---|
| committer | Chris Wilson <chris@chris-wilson.co.uk> | 2017-05-16 21:33:11 +0100 | 
| commit | 3a264fc85fed4c56ffef4958e6dca883cac3e1f5 (patch) | |
| tree | 427ff01f58bf37b5de95802ab656f5280e09801c /tests | |
| parent | 987abfb832cc95c7d3c14070dd7e1ca683bda1a7 (diff) | |
igt/gem_exec_store: Add welcome screen
Print out a little bit of device information on startup to help diagnose
errors.
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/gem_exec_store.c | 31 | 
1 files changed, 29 insertions, 2 deletions
| diff --git a/tests/gem_exec_store.c b/tests/gem_exec_store.c index 1a92c932..3d663ca8 100644 --- a/tests/gem_exec_store.c +++ b/tests/gem_exec_store.c @@ -53,7 +53,7 @@ static void store_dword(int fd, unsigned ring)  	execbuf.buffers_ptr = to_user_pointer(obj);  	execbuf.buffer_count = 2;  	execbuf.flags = ring; -	if (gen < 6) +	if (gen > 3 && gen < 6)  		execbuf.flags |= I915_EXEC_SECURE;  	memset(obj, 0, sizeof(obj)); @@ -213,13 +213,40 @@ static bool can_store_dword_imm(int fd)  	return intel_gen(intel_get_drm_devid(fd)) > 2;  } +static int print_welcome(int fd) +{ +	uint16_t devid = intel_get_drm_devid(fd); +	const struct intel_device_info *info = intel_get_device_info(devid); +	int err; + +	igt_info("Running on %s (pci-id %04x, gen %d)\n", +		 info->codename, devid, ffs(info->gen)); +	igt_info("Can use MI_STORE_DWORD(virtual)? %s\n", +		 can_store_dword_imm(fd) ? "yes" : "no"); + +	err = 0; +	if (drmIoctl(fd, DRM_IOCTL_I915_GEM_THROTTLE, 0)) +		err = -errno; +	igt_info("GPU operation? %s [errno=%d]\n", +		 err == 0 ? "yes" : "no", err); + +	return ffs(info->gen); +} +  igt_main  {  	const struct intel_execution_engine *e;  	int fd;  	igt_fixture { -		fd = drm_open_driver_master(DRIVER_INTEL); +		int gen; + +		fd = drm_open_driver(DRIVER_INTEL); + +		gen = print_welcome(fd); +		if (gen > 3 && gen < 6) /* ctg and ilk need secure batches */ +			igt_require(drmSetMaster(fd) == 0); +  		igt_require_gem(fd);  		igt_require(can_store_dword_imm(fd)); | 
