Re: [PATCH i-g-t 1/2] lib: Open debugfs files for the given DRM device

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



I've only found a very minor nitpick in intel_watermark.c,
other than that this patch does not apply cleanly on upstream/master,
so I've run no compilation or runtime tests.

When it applies to trunk, feel free to add my r-b.

On 2017-03-08 08:29 AM, Tomeu Vizoso wrote:
> When opening a DRM debugfs file, locate the right path based on the
> given DRM device FD.
>
> This is needed so, in setups with more than one DRM device, any
> operations on debugfs files affect the expected DRM device.
>
> Signed-off-by: Tomeu Vizoso <tomeu.vizoso@xxxxxxxxxxxxx>
>
> ---
>
> Guess we could be more conservative and just rename the existing
> functions to have a _legacy postfix and have the new ones accept a FD
> param. Then existing i915-specific code could keep opening the first
> debugfs dir that contains i915-prefixed files and only the generic tests
> would need to be changed to pass the DRM fd.
>
> But the "right" thing to do is to not assume that there's only one DRM
> device on the system, so maybe we want to do the changes in this patch.
> ---
>  benchmarks/gem_latency.c          |   2 +-
>  lib/drmtest.c                     |   2 +-
> lib/igt_debugfs.c | 181 +++++++++++++++++++++++---------------
>  lib/igt_debugfs.h                 |  28 +++---
>  lib/igt_gt.c                      |  12 +--
>  lib/igt_gt.h                      |   4 +-
>  lib/igt_kms.c                     |  10 +--
>  lib/igt_kms.h                     |   4 +-
>  lib/intel_io.h                    |   2 +-
>  lib/intel_mmio.c                  |   4 +-
>  tests/drv_hangman.c               |   4 +-
>  tests/drv_missed_irq.c            |  37 ++++----
>  tests/drv_suspend.c               |   8 +-
>  tests/gem_eio.c                   |   2 +-
>  tests/gem_exec_latency.c          |   2 +-
>  tests/gem_exec_parse.c            |   2 +-
>  tests/gem_exec_whisper.c          |   6 +-
>  tests/gem_mocs_settings.c         |  14 +--
>  tests/gem_persistent_relocs.c     |   2 +-
>  tests/gem_ppgtt.c                 |  10 +--
>  tests/gem_reloc_vs_gpu.c          |   2 +-
>  tests/gem_seqno_wrap.c            |  24 ++---
>  tests/gem_tiled_swapping.c        |   6 +-
>  tests/gem_workarounds.c           |   4 +-
>  tests/kms_atomic_transition.c     |   2 +-
>  tests/kms_ccs.c                   |   4 +-
>  tests/kms_chv_cursor_fail.c       |   4 +-
>  tests/kms_crtc_background_color.c |   4 +-
>  tests/kms_cursor_crc.c            |   4 +-
>  tests/kms_cursor_legacy.c         |   4 +-
>  tests/kms_draw_crc.c              |   2 +-
>  tests/kms_fbc_crc.c               |   8 +-
>  tests/kms_fbcon_fbt.c             |  44 ++++-----
>  tests/kms_flip_tiling.c           |   8 +-
>  tests/kms_frontbuffer_tracking.c  |  26 +++---
>  tests/kms_invalid_dotclock.c      |   6 +-
>  tests/kms_mmap_write_crc.c        |   4 +-
>  tests/kms_mmio_vs_cs_flip.c       |   6 +-
>  tests/kms_pipe_color.c            |   5 +-
>  tests/kms_pipe_crc_basic.c        |  12 +--
>  tests/kms_plane.c                 |   4 +-
>  tests/kms_plane_lowres.c          |  14 ++-
>  tests/kms_plane_multiple.c        |   4 +-
>  tests/kms_plane_scaling.c         |   4 +-
>  tests/kms_psr_sink_crc.c          |   6 +-
>  tests/kms_pwrite_crc.c            |   4 +-
>  tests/kms_rotation_crc.c          |   4 +-
>  tests/kms_sink_crc_basic.c        |   8 +-
>  tests/kms_universal_plane.c       |  12 +--
>  tests/perf.c                      |  16 ++--
>  tests/pm_lpsp.c                   |   2 +-
>  tests/pm_rpm.c                    |   6 +-
>  tests/pm_sseu.c                   |  28 +++---
>  tests/prime_mmap_kms.c            |   2 +-
>  tools/intel_display_crc.c         |   2 +-
>  tools/intel_display_poller.c      |   8 +-
>  tools/intel_dp_compliance.c       |   6 +-
>  tools/intel_forcewaked.c          |  10 ++-
>  tools/intel_gpu_top.c             |   8 +-
>  tools/intel_guc_logger.c          |  10 ++-
>  tools/intel_infoframes.c          |   7 +-
>  tools/intel_l3_parity.c           |   2 +-
>  tools/intel_panel_fitter.c        |   9 +-
>  tools/intel_perf_counters.c       |   2 +-
>  tools/intel_reg.c                 |  12 ++-
>  tools/intel_watermark.c           |  23 +++--
>  66 files changed, 405 insertions(+), 323 deletions(-)
>
> diff --git a/benchmarks/gem_latency.c b/benchmarks/gem_latency.c
> index 7be78f20358f..fc875f1acb0a 100644
> --- a/benchmarks/gem_latency.c
> +++ b/benchmarks/gem_latency.c
> @@ -470,7 +470,7 @@ static int run(int seconds,
>  	if (gen < 6)
>  		return IGT_EXIT_SKIP; /* Needs BCS timestamp */
>
> -	intel_register_access_init(intel_get_pci_device(), false);
> +	intel_register_access_init(intel_get_pci_device(), false, fd);
>
>  	if (gen == 6)
>  		timestamp_reg = REG(RCS_TIMESTAMP);
> diff --git a/lib/drmtest.c b/lib/drmtest.c
> index 065ab1198e79..35f71c0d4f45 100644
> --- a/lib/drmtest.c
> +++ b/lib/drmtest.c
> @@ -183,7 +183,7 @@ void gem_quiescent_gpu(int fd)
>  	gem_sync(fd, obj.handle);
>  	gem_close(fd, obj.handle);
>
> -	igt_drop_caches_set(DROP_RETIRE | DROP_FREED);
> +	igt_drop_caches_set(fd, DROP_RETIRE | DROP_FREED);
>  }
>
>  /**
> diff --git a/lib/igt_debugfs.c b/lib/igt_debugfs.c
> index e64d001b71cf..80a48d2dec81 100644
> --- a/lib/igt_debugfs.c
> +++ b/lib/igt_debugfs.c
> @@ -131,39 +131,34 @@ const char *igt_debugfs_mount(void)
>  	return "/sys/kernel/debug";
>  }
>
> -static bool __igt_debugfs_init(igt_debugfs_t *debugfs)
> +static char *
> +igt_get_debugfs_path(int fd)
>  {
>  	struct stat st;
> -	int n;
> -
> -	strcpy(debugfs->root, igt_debugfs_mount());
> -	for (n = 0; n < 16; n++) {
> -		int len = sprintf(debugfs->dri_path, "%s/dri/%d", debugfs->root, n);
> -		sprintf(debugfs->dri_path + len, "/i915_error_state");
> -		if (stat(debugfs->dri_path, &st) == 0) {
> -			debugfs->dri_path[len] = '\0';
> -			return true;
> -		}
> -	}
> +	const char *debugfs_root;
> +	char *debugfs_dri_path;
> +	int len;
>
> -	debugfs->dri_path[0] = '\0';
> -	return false;
> -}
> -
> -static igt_debugfs_t *__igt_debugfs_singleton(void)
> -{
> -	static igt_debugfs_t singleton;
> -	static bool init_done = false;
> -
> -	if (init_done)
> -		return &singleton;
> +	if (fstat(fd, &st)) {
> +		igt_debug("Couldn't stat FD for DRM device: %s\n", strerror(errno));
> +		return NULL;
> +	}
>
> -	if (__igt_debugfs_init(&singleton)) {
> -		init_done = true;
> -		return &singleton;
> -	} else {
> +	if (!S_ISCHR(st.st_mode)) {
> +		igt_debug("FD for DRM device not a char device!\n");
>  		return NULL;
>  	}
> +
> +	debugfs_root = igt_debugfs_mount();
> +	debugfs_dri_path = calloc(1, strlen(debugfs_root) + 100);
> + len = sprintf(debugfs_dri_path, "%s/dri/%d", debugfs_root, major(st.st_rdev));
> +	sprintf(debugfs_dri_path + len, "/name");
> +	if (stat(debugfs_dri_path, &st) == 0) {
> +		debugfs_dri_path[len] = '\0';
> +		return debugfs_dri_path;
> +	}
> +
> +	return NULL;
>  }
>
>  /**
> @@ -177,15 +172,19 @@ static igt_debugfs_t *__igt_debugfs_singleton(void)
>   * Returns:
> * The Unix file descriptor for the debugfs file or -1 if that didn't work out.
>   */
> -int igt_debugfs_open(const char *filename, int mode)
> +int igt_debugfs_open(int fd, const char *filename, int mode)
>  {
>  	char buf[1024];
> -	igt_debugfs_t *debugfs = __igt_debugfs_singleton();
> +	char *debugfs_dri_path;
>
> -	if (!debugfs)
> +	debugfs_dri_path = igt_get_debugfs_path(fd);
> +	if (!debugfs_dri_path)
>  		return -1;
>
> -	sprintf(buf, "%s/%s", debugfs->dri_path, filename);
> +	sprintf(buf, "%s/%s", debugfs_dri_path, filename);
> +
> +	free(debugfs_dri_path);
> +
>  	return open(buf, mode);
>  }
>
> @@ -200,17 +199,21 @@ int igt_debugfs_open(const char *filename, int mode)
>   * Returns:
> * The libc FILE pointer for the debugfs file or NULL if that didn't work out.
>   */
> -FILE *igt_debugfs_fopen(const char *filename,
> +FILE *igt_debugfs_fopen(int fd,
> +			const char *filename,
>  			const char *mode)
>  {
>  	char buf[1024];
> +	char *debugfs_dri_path;
>
> -	igt_debugfs_t *debugfs = __igt_debugfs_singleton();
> -
> -	if (!debugfs)
> +	debugfs_dri_path = igt_get_debugfs_path(fd);
> +	if (!debugfs_dri_path)
>  		return NULL;
>
> -	sprintf(buf, "%s/%s", debugfs->dri_path, filename);
> +	sprintf(buf, "%s/%s", debugfs_dri_path, filename);
> +
> +	free(debugfs_dri_path);
> +
>  	return fopen(buf, mode);
>  }
>
> @@ -224,12 +227,12 @@ FILE *igt_debugfs_fopen(const char *filename,
> * provided buffer, then closes the file. Users should make sure that the buffer
>   * provided is big enough to fit the whole file, plus one byte.
>   */
> -void __igt_debugfs_read(const char *filename, char *buf, int buf_size)
> +void __igt_debugfs_read(int fd, const char *filename, char *buf, int buf_size)
>  {
>  	FILE *file;
>  	size_t n_read;
>
> -	file = igt_debugfs_fopen(filename, "r");
> +	file = igt_debugfs_fopen(fd, filename, "r");
>  	igt_assert(file);
>
>  	n_read = fread(buf, 1, buf_size - 1, file);
> @@ -250,14 +253,14 @@ void __igt_debugfs_read(const char *filename, char *buf, int buf_size)
>   *
>   * Returns: True if the @substring is found to occur in @filename
>   */
> -bool igt_debugfs_search(const char *filename, const char *substring)
> +bool igt_debugfs_search(int fd, const char *filename, const char *substring)
>  {
>  	FILE *file;
>  	size_t n = 0;
>  	char *line = NULL;
>  	bool matched = false;
>
> -	file = igt_debugfs_fopen(filename, "r");
> +	file = igt_debugfs_fopen(fd, filename, "r");
>  	igt_assert(file);
>
>  	while (getline(&line, &n, file) >= 0) {
> @@ -322,6 +325,7 @@ char *igt_crc_to_string(igt_crc_t *crc)
>  #define LEGACY_LINE_LEN       (6 * 8 + 5 + 1)
>
>  struct _igt_pipe_crc {
> +	int fd;
>  	int ctl_fd;
>  	int crc_fd;
>  	int flags;
> @@ -370,7 +374,7 @@ static bool igt_pipe_crc_do_start(igt_pipe_crc_t *pipe_crc)
>  	if (!pipe_crc->is_legacy) {
>  		sprintf(buf, "crtc-%d/crc/data", pipe_crc->pipe);
>  		errno = 0;
> -		pipe_crc->crc_fd = igt_debugfs_open(buf, pipe_crc->flags);
> + pipe_crc->crc_fd = igt_debugfs_open(pipe_crc->fd, buf, pipe_crc->flags);
>  		if (pipe_crc->crc_fd == -1 && errno == EINVAL)
>  			return false;
>  		igt_assert_eq(errno, 0);
> @@ -387,23 +391,27 @@ static void igt_pipe_crc_pipe_off(int fd, enum pipe pipe)
>  	igt_assert_eq(write(fd, buf, strlen(buf)), strlen(buf));
>  }
>
> -static void igt_pipe_crc_reset(void)
> +static void igt_pipe_crc_reset(int drm_fd)
>  {
> -	igt_debugfs_t *debugfs = __igt_debugfs_singleton();
>  	int fd;
>  	struct dirent *dirent;
>  	char buf[128];
>  	const char *cmd = "none";
>  	bool done = false;
>  	DIR *dir;
> +	char *debugfs_dri_path;
> +
> +	debugfs_dri_path = igt_get_debugfs_path(drm_fd);
> +	if (!debugfs_dri_path)
> +		return;
>
> -	dir = opendir(debugfs->dri_path);
> +	dir = opendir(debugfs_dri_path);
>  	if (dir) {
>  		while ((dirent = readdir(dir))) {
>  			if (strcmp(dirent->d_name, "crtc-") != 0)
>  				continue;
>
> -			sprintf(buf, "%s/%s/crc/control", debugfs->dri_path,
> +			sprintf(buf, "%s/%s/crc/control", debugfs_dri_path,
>  				dirent->d_name);
>  			fd = open(buf, O_WRONLY);
>  			if (fd == -1)
> @@ -416,11 +424,12 @@ static void igt_pipe_crc_reset(void)
>  		}
>  		closedir(dir);
>  	}
> +	free(debugfs_dri_path);
>
>  	if (done)
>  		return;
>
> -	fd = igt_debugfs_open("i915_display_crc_ctl", O_WRONLY);
> +	fd = igt_debugfs_open(drm_fd, "i915_display_crc_ctl", O_WRONLY);
>  	if (fd != -1) {
>  		igt_pipe_crc_pipe_off(fd, PIPE_A);
>  		igt_pipe_crc_pipe_off(fd, PIPE_B);
> @@ -432,7 +441,32 @@ static void igt_pipe_crc_reset(void)
>
>  static void pipe_crc_exit_handler(int sig)
>  {
> -	igt_pipe_crc_reset();
> +	struct dirent *dirent;
> +	char buf[128];
> +	DIR *dir;
> +	int fd;
> +
> +	dir = opendir("/dev/dri");
> +	if (!dir)
> +		return;
> +
> +	/*
> +	 * Try to reset CRC capture for all DRM devices, this is only needed
> +	 * for the legacy CRC ABI and can be completely removed once the
> +	 * legacy codepaths are removed.
> +	 */
> +	while ((dirent = readdir(dir))) {
> +		if (strncmp(dirent->d_name, "card", 4) != 0)
> +			continue;
> +
> +		sprintf(buf, "/dev/dri/%s", dirent->d_name);
> +		fd = open(buf, O_WRONLY);
> +
> +		igt_pipe_crc_reset(fd);
> +
> +		close(fd);
> +	}
> +	closedir(dir);
>  }
>
>  /**
> @@ -442,16 +476,16 @@ static void pipe_crc_exit_handler(int sig)
> * kernel. Uses igt_skip to automatically skip the test/subtest if this isn't
>   * the case.
>   */
> -void igt_require_pipe_crc(void)
> +void igt_require_pipe_crc(int fd)
>  {
>  	const char *cmd = "pipe A none";
>  	FILE *ctl;
>  	size_t written;
>  	int ret;
>
> -	ctl = igt_debugfs_fopen("crtc-0/crc/control", "r+");
> +	ctl = igt_debugfs_fopen(fd, "crtc-0/crc/control", "r+");
>  	if (!ctl) {
> -		ctl = igt_debugfs_fopen("i915_display_crc_ctl", "r+");
> +		ctl = igt_debugfs_fopen(fd, "i915_display_crc_ctl", "r+");
>  		igt_require_f(ctl,
>  			      "No display_crc_ctl found, kernel too old\n");
>  		written = fwrite(cmd, 1, strlen(cmd), ctl);
> @@ -477,9 +511,9 @@ void igt_require_pipe_crc(void)
>   *
>   * See: https://01.org/linuxgraphics/gfx-docs/drm/gpu/i915.html#hotplug
>   */
> -void igt_hpd_storm_set_threshold(unsigned int threshold)
> +void igt_hpd_storm_set_threshold(int drm_fd, unsigned int threshold)
>  {
> -	int fd = igt_debugfs_open("i915_hpd_storm_ctl", O_WRONLY);
> +	int fd = igt_debugfs_open(drm_fd, "i915_hpd_storm_ctl", O_WRONLY);
>  	char buf[16];
>
>  	if (fd < 0)
> @@ -506,9 +540,9 @@ void igt_hpd_storm_set_threshold(unsigned int threshold)
>   *
>   * See: https://01.org/linuxgraphics/gfx-docs/drm/gpu/i915.html#hotplug
>   */
> -void igt_hpd_storm_reset(void)
> +void igt_hpd_storm_reset(int drm_fd)
>  {
> -	int fd = igt_debugfs_open("i915_hpd_storm_ctl", O_WRONLY);
> +	int fd = igt_debugfs_open(drm_fd, "i915_hpd_storm_ctl", O_WRONLY);
>  	const char *buf = "reset";
>
>  	if (fd < 0)
> @@ -533,9 +567,9 @@ void igt_hpd_storm_reset(void)
>   *
>   * Returns: Whether or not an HPD storm has been detected.
>   */
> -bool igt_hpd_storm_detected(void)
> +bool igt_hpd_storm_detected(int drm_fd)
>  {
> -	int fd = igt_debugfs_open("i915_hpd_storm_ctl", O_RDONLY);
> +	int fd = igt_debugfs_open(drm_fd, "i915_hpd_storm_ctl", O_RDONLY);
>  	char *start_loc;
>  	char buf[32] = {0}, detected_str[4];
>  	bool ret;
> @@ -566,16 +600,16 @@ bool igt_hpd_storm_detected(void)
>   *
>   * See: https://01.org/linuxgraphics/gfx-docs/drm/gpu/i915.html#hotplug
>   */
> -void igt_require_hpd_storm_ctl(void)
> +void igt_require_hpd_storm_ctl(int drm_fd)
>  {
> -	int fd = igt_debugfs_open("i915_hpd_storm_ctl", O_RDONLY);
> +	int fd = igt_debugfs_open(drm_fd, "i915_hpd_storm_ctl", O_RDONLY);
>
>  	igt_require_f(fd > 0, "No i915_hpd_storm_ctl found in debugfs\n");
>  	close(fd);
>  }
>
>  static igt_pipe_crc_t *
> -pipe_crc_new(enum pipe pipe, enum intel_pipe_crc_source source, int flags) > +pipe_crc_new(int fd, enum pipe pipe, enum intel_pipe_crc_source source, int flags)
>  {
>  	igt_pipe_crc_t *pipe_crc;
>  	char buf[128];
> @@ -585,9 +619,9 @@ pipe_crc_new(enum pipe pipe, enum intel_pipe_crc_source source, int flags)
>  	pipe_crc = calloc(1, sizeof(struct _igt_pipe_crc));
>
>  	sprintf(buf, "crtc-%d/crc/control", pipe);
> -	pipe_crc->ctl_fd = igt_debugfs_open(buf, O_WRONLY);
> +	pipe_crc->ctl_fd = igt_debugfs_open(fd, buf, O_WRONLY);
>  	if (pipe_crc->ctl_fd == -1) {
> -		pipe_crc->ctl_fd = igt_debugfs_open("i915_display_crc_ctl",
> +		pipe_crc->ctl_fd = igt_debugfs_open(fd, "i915_display_crc_ctl",
>  						    O_WRONLY);
>  		igt_assert(pipe_crc->ctl_fd != -1);
>  		pipe_crc->is_legacy = true;
> @@ -595,7 +629,7 @@ pipe_crc_new(enum pipe pipe, enum intel_pipe_crc_source source, int flags)
>
>  	if (pipe_crc->is_legacy) {
>  		sprintf(buf, "i915_pipe_%s_crc", kmstest_pipe_name(pipe));
> -		pipe_crc->crc_fd = igt_debugfs_open(buf, flags);
> +		pipe_crc->crc_fd = igt_debugfs_open(fd, buf, flags);
>  		igt_assert(pipe_crc->crc_fd != -1);
>  		igt_debug("Using legacy frame CRC ABI\n");
>  	} else {
> @@ -603,6 +637,7 @@ pipe_crc_new(enum pipe pipe, enum intel_pipe_crc_source source, int flags)
>  		igt_debug("Using generic frame CRC ABI\n");
>  	}
>
> +	pipe_crc->fd = fd;
>  	pipe_crc->pipe = pipe;
>  	pipe_crc->source = source;
>  	pipe_crc->flags = flags;
> @@ -623,9 +658,9 @@ pipe_crc_new(enum pipe pipe, enum intel_pipe_crc_source source, int flags)
>   * least INTEL_PIPE_CRC_SOURCE_AUTO everywhere.
>   */
>  igt_pipe_crc_t *
> -igt_pipe_crc_new(enum pipe pipe, enum intel_pipe_crc_source source)
> +igt_pipe_crc_new(int fd, enum pipe pipe, enum intel_pipe_crc_source source)
>  {
> -	return pipe_crc_new(pipe, source, O_RDONLY);
> +	return pipe_crc_new(fd, pipe, source, O_RDONLY);
>  }
>
>  /**
> @@ -641,9 +676,9 @@ igt_pipe_crc_new(enum pipe pipe, enum intel_pipe_crc_source source)
>   * least INTEL_PIPE_CRC_SOURCE_AUTO everywhere.
>   */
>  igt_pipe_crc_t *
> -igt_pipe_crc_new_nonblock(enum pipe pipe, enum intel_pipe_crc_source source) > +igt_pipe_crc_new_nonblock(int fd, enum pipe pipe, enum intel_pipe_crc_source source)
>  {
> -	return pipe_crc_new(pipe, source, O_RDONLY | O_NONBLOCK);
> +	return pipe_crc_new(fd, pipe, source, O_RDONLY | O_NONBLOCK);
>  }
>
>  /**
> @@ -879,7 +914,7 @@ void igt_pipe_crc_collect_crc(igt_pipe_crc_t *pipe_crc, igt_crc_t *out_crc) > * This calls the debugfs interface the drm/i915 GEM driver exposes to drop or
>   * evict certain classes of gem buffer objects.
>   */
> -void igt_drop_caches_set(uint64_t val)
> +void igt_drop_caches_set(int drm_fd, uint64_t val)
>  {
>  	int fd;
>  	char data[19];
> @@ -887,7 +922,7 @@ void igt_drop_caches_set(uint64_t val)
>
>  	sprintf(data, "0x%" PRIx64, val);
>
> -	fd = igt_debugfs_open("i915_gem_drop_caches", O_WRONLY);
> +	fd = igt_debugfs_open(drm_fd, "i915_gem_drop_caches", O_WRONLY);
>
>  	igt_assert(fd >= 0);
>  	do {
> @@ -953,14 +988,14 @@ void igt_enable_prefault(void)
>  	igt_prefault_control(true);
>  }
>
> -static int get_object_count(void)
> +static int get_object_count(int fd)
>  {
>  	FILE *file;
>  	int ret, scanned;
>
> -	igt_drop_caches_set(DROP_RETIRE | DROP_ACTIVE | DROP_FREED);
> +	igt_drop_caches_set(fd, DROP_RETIRE | DROP_ACTIVE | DROP_FREED);
>
> -	file = igt_debugfs_fopen("i915_gem_objects", "r");
> +	file = igt_debugfs_fopen(fd, "i915_gem_objects", "r");
>
>  	scanned = fscanf(file, "%i objects", &ret);
>  	igt_assert_eq(scanned, 1);
> @@ -980,7 +1015,7 @@ int igt_get_stable_obj_count(int driver)
>  {
>  	int obj_count;
>  	gem_quiescent_gpu(driver);
> -	obj_count = get_object_count();
> +	obj_count = get_object_count(driver);
>  	/* The test relies on the system being in the same state before and
>  	 * after the test so any difference in the object count is a result of
>  	 * leaks during the test. gem_quiescent_gpu() mostly achieves this but
> @@ -994,7 +1029,7 @@ int igt_get_stable_obj_count(int driver)
>  		while (loop_count < 4) {
>  			usleep(200000);
>  			gem_quiescent_gpu(driver);
> -			obj_count = get_object_count();
> +			obj_count = get_object_count(driver);
>  			if (obj_count == prev_obj_count) {
>  				loop_count++;
>  			} else {
> diff --git a/lib/igt_debugfs.h b/lib/igt_debugfs.h
> index 5587ad40b3b8..9bede52f517b 100644
> --- a/lib/igt_debugfs.h
> +++ b/lib/igt_debugfs.h
> @@ -33,11 +33,11 @@ enum pipe;
>
>  const char *igt_debugfs_mount(void);
>
> -int igt_debugfs_open(const char *filename, int mode);
> -FILE *igt_debugfs_fopen(const char *filename,
> +int igt_debugfs_open(int fd, const char *filename, int mode);
> +FILE *igt_debugfs_fopen(int fd, const char *filename,
>  			const char *mode);
> -void __igt_debugfs_read(const char *filename, char *buf, int buf_size);
> -bool igt_debugfs_search(const char *filename, const char *substring);
> +void __igt_debugfs_read(int fd, const char *filename, char *buf, int buf_size); > +bool igt_debugfs_search(int fd, const char *filename, const char *substring);
>
>  /**
>   * igt_debugfs_read:
> @@ -47,8 +47,8 @@ bool igt_debugfs_search(const char *filename, const char *substring);
>   * This is just a convenience wrapper for __igt_debugfs_read. See its
>   * documentation.
>   */
> -#define igt_debugfs_read(filename, buf) \
> -		__igt_debugfs_read((filename), (buf), sizeof(buf))
> +#define igt_debugfs_read(fd, filename, buf) \
> +		__igt_debugfs_read(fd, (filename), (buf), sizeof(buf))
>
>  /*
>   * Pipe CRC
> @@ -116,11 +116,11 @@ enum intel_pipe_crc_source {
>  void igt_assert_crc_equal(const igt_crc_t *a, const igt_crc_t *b);
>  char *igt_crc_to_string(igt_crc_t *crc);
>
> -void igt_require_pipe_crc(void);
> +void igt_require_pipe_crc(int fd);
>  igt_pipe_crc_t *
> -igt_pipe_crc_new(enum pipe pipe, enum intel_pipe_crc_source source);
> +igt_pipe_crc_new(int fd, enum pipe pipe, enum intel_pipe_crc_source source);
>  igt_pipe_crc_t *
> -igt_pipe_crc_new_nonblock(enum pipe pipe, enum intel_pipe_crc_source source); > +igt_pipe_crc_new_nonblock(int fd, enum pipe pipe, enum intel_pipe_crc_source source);
>  void igt_pipe_crc_free(igt_pipe_crc_t *pipe_crc);
>  void igt_pipe_crc_start(igt_pipe_crc_t *pipe_crc);
>  void igt_pipe_crc_stop(igt_pipe_crc_t *pipe_crc);
> @@ -129,10 +129,10 @@ int igt_pipe_crc_get_crcs(igt_pipe_crc_t *pipe_crc, int n_crcs,
>  			  igt_crc_t **out_crcs);
> void igt_pipe_crc_collect_crc(igt_pipe_crc_t *pipe_crc, igt_crc_t *out_crc);
>
> -void igt_hpd_storm_set_threshold(unsigned int threshold);
> -void igt_hpd_storm_reset(void);
> -bool igt_hpd_storm_detected(void);
> -void igt_require_hpd_storm_ctl(void);
> +void igt_hpd_storm_set_threshold(int fd, unsigned int threshold);
> +void igt_hpd_storm_reset(int fd);
> +bool igt_hpd_storm_detected(int fd);
> +void igt_require_hpd_storm_ctl(int fd);
>
>  /*
>   * Drop caches
> @@ -180,7 +180,7 @@ void igt_require_hpd_storm_ctl(void);
>  		  DROP_ACTIVE | \
>  		  DROP_FREED)
>
> -void igt_drop_caches_set(uint64_t val);
> +void igt_drop_caches_set(int fd, uint64_t val);
>
>  /*
>   * Prefault control
> diff --git a/lib/igt_gt.c b/lib/igt_gt.c
> index 3bfaf2e4d849..e47d9a4cd5f7 100644
> --- a/lib/igt_gt.c
> +++ b/lib/igt_gt.c
> @@ -362,13 +362,13 @@ void igt_post_hang_ring(int fd, igt_hang_t arg)
> * stuck, either because the test manually disabled gpu resets or because the
>   * test hit an hangcheck bug
>   */
> -void igt_force_gpu_reset(void)
> +void igt_force_gpu_reset(int drm_fd)
>  {
>  	int fd, ret;
>
>  	igt_debug("Triggering GPU reset\n");
>
> -	fd = igt_debugfs_open("i915_wedged", O_RDWR);
> +	fd = igt_debugfs_open(drm_fd, "i915_wedged", O_RDWR);
>  	igt_require(fd >= 0);
>
>  	ret = write(fd, "-1\n", 3);
> @@ -443,11 +443,11 @@ void igt_stop_hang_helper(void)
>   * Returns:
> * The file descriptor of the forcewake handle or -1 if that didn't work out.
>   */
> -int igt_open_forcewake_handle(void)
> +int igt_open_forcewake_handle(int fd)
>  {
>  	if (getenv("IGT_NO_FORCEWAKE"))
>  		return -1;
> -	return igt_debugfs_open("i915_forcewake_user", O_WRONLY);
> +	return igt_debugfs_open(fd, "i915_forcewake_user", O_WRONLY);
>  }
>
>  #if defined(__x86_64__) || defined(__i386__)
> @@ -535,13 +535,13 @@ unsigned intel_detect_and_clear_missed_interrupts(int fd)
>
>  	gem_quiescent_gpu(fd);
>
> -	file = igt_debugfs_fopen("i915_ring_missed_irq", "r");
> +	file = igt_debugfs_fopen(fd, "i915_ring_missed_irq", "r");
>  	if (file) {
>  		igt_assert(fscanf(file, "%x", &missed) == 1);
>  		fclose(file);
>  	}
>  	if (missed) {
> -		file = igt_debugfs_fopen("i915_ring_missed_irq", "w");
> +		file = igt_debugfs_fopen(fd, "i915_ring_missed_irq", "w");
>  		if (file) {
>  			fwrite("0\n", 1, 2, file);
>  			fclose(file);
> diff --git a/lib/igt_gt.h b/lib/igt_gt.h
> index e44b6db1b961..1ed833d2fbcc 100644
> --- a/lib/igt_gt.h
> +++ b/lib/igt_gt.h
> @@ -51,12 +51,12 @@ igt_hang_t igt_hang_ctx(int fd,
>  igt_hang_t igt_hang_ring(int fd, int ring);
>  void igt_post_hang_ring(int fd, igt_hang_t arg);
>
> -void igt_force_gpu_reset(void);
> +void igt_force_gpu_reset(int fd);
>
>  void igt_fork_hang_helper(void);
>  void igt_stop_hang_helper(void);
>
> -int igt_open_forcewake_handle(void);
> +int igt_open_forcewake_handle(int fd);
>
>  int igt_setup_clflush(void);
>  void igt_clflush_range(void *addr, int size);
> diff --git a/lib/igt_kms.c b/lib/igt_kms.c
> index 8751c97f7a06..6b7f4fb9711e 100644
> --- a/lib/igt_kms.c
> +++ b/lib/igt_kms.c
> @@ -747,7 +747,7 @@ void kmstest_force_edid(int drm_fd, drmModeConnector *connector,
>
> igt_assert_neq(asprintf(&path, "%s-%d/edid_override", kmstest_connector_type_str(connector->connector_type), connector->connector_type_id),
>  		       -1);
> -	debugfs_fd = igt_debugfs_open(path, O_WRONLY | O_TRUNC);
> +	debugfs_fd = igt_debugfs_open(drm_fd, path, O_WRONLY | O_TRUNC);
>  	free(path);
>
>  	igt_assert(debugfs_fd != -1);
> @@ -1324,7 +1324,7 @@ static void parse_crtc(char *info, struct kmstest_crtc *crtc)
>  	igt_assert_eq(ret, 2);
>  }
>
> -void kmstest_get_crtc(enum pipe pipe, struct kmstest_crtc *crtc)
> +void kmstest_get_crtc(int fd, enum pipe pipe, struct kmstest_crtc *crtc)
>  {
>  	char tmp[256];
>  	FILE *fid;
> @@ -1333,7 +1333,7 @@ void kmstest_get_crtc(enum pipe pipe, struct kmstest_crtc *crtc)
>  	int line;
>  	long int n;
>
> -	fid = igt_debugfs_fopen("i915_display_info", mode);
> +	fid = igt_debugfs_fopen(fd, "i915_display_info", mode);
>
>  	igt_skip_on(fid == NULL);
>
> @@ -1370,13 +1370,13 @@ void kmstest_get_crtc(enum pipe pipe, struct kmstest_crtc *crtc)
>  	igt_skip_on(ncrtc == 0);
>  }
>
> -void igt_assert_plane_visible(enum pipe pipe, bool visibility)
> +void igt_assert_plane_visible(int fd, enum pipe pipe, bool visibility)
>  {
>  	struct kmstest_crtc crtc;
>  	int i;
>  	bool visible;
>
> -	kmstest_get_crtc(pipe, &crtc);
> +	kmstest_get_crtc(fd, pipe, &crtc);
>
>  	visible = true;
>  	for (i = 0; i < crtc.n_planes; i++) {
> diff --git a/lib/igt_kms.h b/lib/igt_kms.h
> index 6754d00e0a3a..5efce0049b08 100644
> --- a/lib/igt_kms.h
> +++ b/lib/igt_kms.h
> @@ -215,8 +215,8 @@ uint32_t kmstest_dumb_create(int fd, int width, int height, int bpp,
>  void *kmstest_dumb_map_buffer(int fd, uint32_t handle, uint64_t size,
>  			      unsigned prot);
>  unsigned int kmstest_get_vblank(int fd, int pipe, unsigned int flags);
> -void kmstest_get_crtc(enum pipe pipe, struct kmstest_crtc *crtc);
> -void igt_assert_plane_visible(enum pipe pipe, bool visibility);
> +void kmstest_get_crtc(int fd, enum pipe pipe, struct kmstest_crtc *crtc);
> +void igt_assert_plane_visible(int fd, enum pipe pipe, bool visibility);
>
>  /*
>   * A small modeset API
> diff --git a/lib/intel_io.h b/lib/intel_io.h
> index e2d6b4705be3..6014c4855cab 100644
> --- a/lib/intel_io.h
> +++ b/lib/intel_io.h
> @@ -36,7 +36,7 @@ extern void *igt_global_mmio;
>  void intel_mmio_use_pci_bar(struct pci_device *pci_dev);
>  void intel_mmio_use_dump_file(char *file);
>
> -int intel_register_access_init(struct pci_device *pci_dev, int safe);
> +int intel_register_access_init(struct pci_device *pci_dev, int safe, int fd);
>  void intel_register_access_fini(void);
>  uint32_t intel_register_read(uint32_t reg);
>  void intel_register_write(uint32_t reg, uint32_t val);
> diff --git a/lib/intel_mmio.c b/lib/intel_mmio.c
> index 4981daf911c9..07b9ed1471b7 100644
> --- a/lib/intel_mmio.c
> +++ b/lib/intel_mmio.c
> @@ -165,7 +165,7 @@ release_forcewake_lock(int fd)
>   * @pci_dev can be obtained from intel_get_pci_device().
>   */
>  int
> -intel_register_access_init(struct pci_device *pci_dev, int safe)
> +intel_register_access_init(struct pci_device *pci_dev, int safe, int fd)
>  {
>  	int ret;
>
> @@ -187,7 +187,7 @@ intel_register_access_init(struct pci_device *pci_dev, int safe)
>  	/* Find where the forcewake lock is. Forcewake doesn't exist
>  	 * gen < 6, but the debugfs should do the right things for us.
>  	 */
> -	ret = igt_open_forcewake_handle();
> +	ret = igt_open_forcewake_handle(fd);
>  	if (ret == -1)
>  		mmio_data.key = FAKEKEY;
>  	else
> diff --git a/tests/drv_hangman.c b/tests/drv_hangman.c
> index 51bdbdaaa98a..ee03c0a1abec 100644
> --- a/tests/drv_hangman.c
> +++ b/tests/drv_hangman.c
> @@ -88,7 +88,7 @@ static void test_error_state_basic(void)
>  	assert_error_state_clear();
>
>  	/* Manually trigger a hang by request a reset */
> -	fd = igt_debugfs_open("i915_wedged", O_WRONLY);
> +	fd = igt_debugfs_open(device, "i915_wedged", O_WRONLY);
>  	igt_ignore_warn(write(fd, "1\n", 2));
>  	close(fd);
>
> @@ -227,7 +227,7 @@ static void hangcheck_unterminated(void)
>  	gem_execbuf(device, &execbuf);
>  	if (gem_wait(device, handle, &timeout_ns) != 0) {
>  		/* need to manually trigger an hang to clean before failing */
> -		igt_force_gpu_reset();
> +		igt_force_gpu_reset(device);
>  		igt_assert_f(0, "unterminated batch did not trigger an hang!");
>  	}
>  }
> diff --git a/tests/drv_missed_irq.c b/tests/drv_missed_irq.c
> index 3b789a6c7ecf..eaf565ea545f 100644
> --- a/tests/drv_missed_irq.c
> +++ b/tests/drv_missed_irq.c
> @@ -29,6 +29,8 @@
>
> IGT_TEST_DESCRIPTION("Inject missed interrupts and make sure they are caught");
>
> +static int drm_fd;
> +
>  static void trigger_missed_interrupt(int fd, unsigned ring)
>  {
>  	const int gen = intel_gen(intel_get_drm_devid(fd));
> @@ -116,16 +118,16 @@ static uint32_t engine_mask(void)
>  	uint32_t mask;
>  	FILE *file;
>
> -	file = igt_debugfs_fopen("i915_ring_test_irq", "w");
> +	file = igt_debugfs_fopen(drm_fd, "i915_ring_test_irq", "w");
>  	fprintf(file, "0x%x", -1);
>  	fclose(file);
>
>  	mask = -1;
> -	file = igt_debugfs_fopen("i915_ring_test_irq", "r");
> +	file = igt_debugfs_fopen(drm_fd, "i915_ring_test_irq", "r");
>  	igt_ignore_warn(fscanf(file, "%x", &mask));
>  	fclose(file);
>
> -	file = igt_debugfs_fopen("i915_ring_test_irq", "w");
> +	file = igt_debugfs_fopen(drm_fd, "i915_ring_test_irq", "w");
>  	fprintf(file, "0");
>  	fclose(file);
>
> @@ -136,7 +138,7 @@ static void enable_missed_irq(void)
>  {
>  	FILE *file;
>
> -	file = igt_debugfs_fopen("i915_ring_test_irq", "w");
> +	file = igt_debugfs_fopen(drm_fd, "i915_ring_test_irq", "w");
>  	fprintf(file, "0x%x", -1);
>  	fclose(file);
>  }
> @@ -146,11 +148,11 @@ static uint32_t disable_missed_irq(void)
>  	FILE *file;
>  	uint32_t mask = 0;
>
> -	file = igt_debugfs_fopen("i915_ring_test_irq", "r");
> +	file = igt_debugfs_fopen(drm_fd, "i915_ring_test_irq", "r");
>  	igt_ignore_warn(fscanf(file, "%x", &mask));
>  	fclose(file);
>
> -	file = igt_debugfs_fopen("i915_ring_test_irq", "w");
> +	file = igt_debugfs_fopen(drm_fd, "i915_ring_test_irq", "w");
>  	fprintf(file, "0");
>  	fclose(file);
>
> @@ -163,20 +165,19 @@ igt_simple_main
>  	unsigned expect_rings;
>  	unsigned missed_rings;
>  	unsigned check_rings;
> -	int fd;
>
>  	igt_skip_on_simulation();
>  	bind_to_cpu(0);
>
> -	fd = drm_open_driver(DRIVER_INTEL);
> -	igt_require_gem(fd);
> -	gem_require_mmap_wc(fd);
> -	igt_fork_hang_detector(fd);
> +	drm_fd = drm_open_driver(DRIVER_INTEL);
> +	igt_require_gem(drm_fd);
> +	gem_require_mmap_wc(drm_fd);
> +	igt_fork_hang_detector(drm_fd);
>
>  	expect_rings = engine_mask();
>
>  	igt_debug("Clearing rings %x\n", expect_rings);
> -	intel_detect_and_clear_missed_interrupts(fd);
> +	intel_detect_and_clear_missed_interrupts(drm_fd);
>  	for (e = intel_execution_engines; e->name; e++) {
>  		if (expect_rings == -1 && e->exec_id)
>  			continue;
> @@ -186,14 +187,14 @@ igt_simple_main
>
>  		igt_debug("Clearing ring %s [%x]\n",
>  			  e->name, e->exec_id | e->flags);
> -		trigger_missed_interrupt(fd, e->exec_id | e->flags);
> +		trigger_missed_interrupt(drm_fd, e->exec_id | e->flags);
>  	}
> -	igt_assert_eq(intel_detect_and_clear_missed_interrupts(fd), 0);
> +	igt_assert_eq(intel_detect_and_clear_missed_interrupts(drm_fd), 0);
>
>  	igt_debug("Testing rings %x\n", expect_rings);
>  	enable_missed_irq();
>
> -	intel_detect_and_clear_missed_interrupts(fd);
> +	intel_detect_and_clear_missed_interrupts(drm_fd);
>  	for (e = intel_execution_engines; e->name; e++) {
>  		if (expect_rings == -1 && e->exec_id)
>  			continue;
> @@ -203,9 +204,9 @@ igt_simple_main
>
>  		igt_debug("Executing on ring %s [%x]\n",
>  			  e->name, e->exec_id | e->flags);
> -		trigger_missed_interrupt(fd, e->exec_id | e->flags);
> +		trigger_missed_interrupt(drm_fd, e->exec_id | e->flags);
>  	}
> -	missed_rings = intel_detect_and_clear_missed_interrupts(fd);
> +	missed_rings = intel_detect_and_clear_missed_interrupts(drm_fd);
>
>  	check_rings = disable_missed_irq();
>  	igt_assert_eq_u32(check_rings, expect_rings);
> @@ -216,5 +217,5 @@ igt_simple_main
>  		igt_assert_eq_u32(missed_rings, expect_rings);
>
>  	igt_stop_hang_detector();
> -	close(fd);
> +	close(drm_fd);
>  }
> diff --git a/tests/drv_suspend.c b/tests/drv_suspend.c
> index 1d7cc1f8200b..2e39f20ae26c 100644
> --- a/tests/drv_suspend.c
> +++ b/tests/drv_suspend.c
> @@ -161,11 +161,11 @@ test_sysfs_reader(bool hibernate)
>  }
>
>  static void
> -test_forcewake(bool hibernate)
> +test_forcewake(int fd, bool hibernate)
>  {
>  	int fw_fd;
>
> -	fw_fd = igt_open_forcewake_handle();
> +	fw_fd = igt_open_forcewake_handle(fd);
>  	igt_assert_lte(0, fw_fd);
>
>  	if (hibernate)
> @@ -200,7 +200,7 @@ igt_main
>  		test_sysfs_reader(false);
>
>  	igt_subtest("forcewake")
> -		test_forcewake(false);
> +		test_forcewake(fd, false);
>
>  	igt_subtest("fence-restore-tiled2untiled-hibernate")
>  		test_fence_restore(fd, true, true);
> @@ -215,7 +215,7 @@ igt_main
>  		test_sysfs_reader(true);
>
>  	igt_subtest("forcewake-hibernate")
> -		test_forcewake(true);
> +		test_forcewake(fd, true);
>
>  	igt_fixture
>  		close(fd);
> diff --git a/tests/gem_eio.c b/tests/gem_eio.c
> index 22fcf439f09f..fc94ffef924d 100644
> --- a/tests/gem_eio.c
> +++ b/tests/gem_eio.c
> @@ -61,7 +61,7 @@ static bool i915_reset_control(bool enable)
>
>  static void trigger_reset(int fd)
>  {
> -	igt_force_gpu_reset();
> +	igt_force_gpu_reset(fd);
>
>  	/* And just check the gpu is indeed running again */
>  	igt_debug("Checking that the GPU recovered\n");
> diff --git a/tests/gem_exec_latency.c b/tests/gem_exec_latency.c
> index c3ebc20ab3c0..dd6703f43a38 100644
> --- a/tests/gem_exec_latency.c
> +++ b/tests/gem_exec_latency.c
> @@ -442,9 +442,9 @@ igt_main
>  	int device = -1;
>
>  	igt_fixture {
> -		intel_register_access_init(intel_get_pci_device(), false);
>  		device = drm_open_driver(DRIVER_INTEL);
>  		igt_require_gem(device);
> +		intel_register_access_init(intel_get_pci_device(), false, device);
>  		print_welcome(device);
>
>  		ring_size = measure_ring_size(device);
> diff --git a/tests/gem_exec_parse.c b/tests/gem_exec_parse.c
> index ff438b2519b9..4e6d85e58113 100644
> --- a/tests/gem_exec_parse.c
> +++ b/tests/gem_exec_parse.c
> @@ -521,7 +521,7 @@ igt_main
>  #undef REG
>
>  		igt_fixture {
> -			intel_register_access_init(intel_get_pci_device(), 0);
> +			intel_register_access_init(intel_get_pci_device(), 0, fd);
>  		}
>
>  		for (int i = 0; i < ARRAY_SIZE(lris); i++) {
> diff --git a/tests/gem_exec_whisper.c b/tests/gem_exec_whisper.c
> index cac3fedd21db..04ccc7f0e4d0 100644
> --- a/tests/gem_exec_whisper.c
> +++ b/tests/gem_exec_whisper.c
> @@ -41,12 +41,12 @@
>
>  #define VERIFY 0
>
> -static void write_seqno(unsigned offset)
> +static void write_seqno(int fd, unsigned offset)
>  {
>  	uint32_t seqno = UINT32_MAX - offset;
>  	FILE *file;
>
> -	file = igt_debugfs_fopen("i915_next_seqno", "w");
> +	file = igt_debugfs_fopen(fd, "i915_next_seqno", "w");
>  	igt_assert(file);
>
>  	igt_assert(fprintf(file, "0x%x", seqno) > 0);
> @@ -337,7 +337,7 @@ static void whisper(int fd, unsigned engine, unsigned flags)
>  				uint64_t offset;
>
>  				if (!(flags & FORKED))
> -					write_seqno(pass);
> +					write_seqno(fd, pass);
>
>  				if (flags & HANG)
>  					submit_hang(&hang, engines, nengine);
> diff --git a/tests/gem_mocs_settings.c b/tests/gem_mocs_settings.c
> index 9faf6c5492af..a96aa66d26a0 100644
> --- a/tests/gem_mocs_settings.c
> +++ b/tests/gem_mocs_settings.c
> @@ -383,7 +383,7 @@ static void default_context_tests(unsigned mode)
>
>  	switch (mode) {
>  	case NONE:	break;
> -	case RESET:	igt_force_gpu_reset();	break;
> +	case RESET:	igt_force_gpu_reset(fd);	break;
>  	case SUSPEND:	igt_system_suspend_autoresume(SUSPEND_STATE_MEM,
>  						      SUSPEND_TEST_NONE); break;
>  	case HIBERNATE:	igt_system_suspend_autoresume(SUSPEND_STATE_DISK,
> @@ -424,7 +424,7 @@ static void default_dirty_tests(unsigned mode)
>
>  	switch (mode) {
>  	case NONE:	break;
> -	case RESET:	igt_force_gpu_reset();	break;
> +	case RESET:	igt_force_gpu_reset(fd);	break;
>  	case SUSPEND:	igt_system_suspend_autoresume(SUSPEND_STATE_MEM,
>  						      SUSPEND_TEST_NONE); break;
>  	case HIBERNATE:	igt_system_suspend_autoresume(SUSPEND_STATE_DISK,
> @@ -449,7 +449,7 @@ static void context_save_restore_test(unsigned mode)
>
>  	switch (mode) {
>  	case NONE:	break;
> -	case RESET:	igt_force_gpu_reset();	break;
> +	case RESET:	igt_force_gpu_reset(fd);	break;
>  	case SUSPEND:	igt_system_suspend_autoresume(SUSPEND_STATE_MEM,
>  						      SUSPEND_TEST_NONE); break;
>  	case HIBERNATE:	igt_system_suspend_autoresume(SUSPEND_STATE_DISK,
> @@ -494,7 +494,7 @@ static void context_dirty_test(unsigned mode)
>
>  	switch (mode) {
>  	case NONE:	break;
> -	case RESET:	igt_force_gpu_reset();	break;
> +	case RESET:	igt_force_gpu_reset(fd);	break;
>  	case SUSPEND:	igt_system_suspend_autoresume(SUSPEND_STATE_MEM,
>  						      SUSPEND_TEST_NONE); break;
>  	case HIBERNATE:	igt_system_suspend_autoresume(SUSPEND_STATE_DISK,
> @@ -514,10 +514,14 @@ static void context_dirty_test(unsigned mode)
>  static void run_tests(unsigned mode)
>  {
>  	struct pci_device *pci_dev;
> +	int fd;
>
>  	pci_dev = intel_get_pci_device();
>  	igt_require(pci_dev);
> -	intel_register_access_init(pci_dev, 0);
> +
> +	fd = drm_open_driver_master(DRIVER_INTEL);
> +	intel_register_access_init(pci_dev, 0, fd);
> +	close(fd);
>
>  	default_context_tests(mode);
>  	default_dirty_tests(mode);
> diff --git a/tests/gem_persistent_relocs.c b/tests/gem_persistent_relocs.c
> index 9c885307df63..e51420e1672a 100644
> --- a/tests/gem_persistent_relocs.c
> +++ b/tests/gem_persistent_relocs.c
> @@ -288,7 +288,7 @@ static void do_forked_test(int fd, unsigned flags)
>  		igt_fork_helper(&thrasher) {
>  			while (1) {
>  				usleep(1000);
> -				igt_drop_caches_set(val);
> +				igt_drop_caches_set(fd, val);
>  			}
>  		}
>  	}
> diff --git a/tests/gem_ppgtt.c b/tests/gem_ppgtt.c
> index a64d6d4f056d..37d601ced843 100644
> --- a/tests/gem_ppgtt.c
> +++ b/tests/gem_ppgtt.c
> @@ -236,7 +236,7 @@ static void flink_and_close(void)
>  	gem_sync(fd2, flinked_bo);
>  	gem_close(fd2, flinked_bo);
>
> -	igt_drop_caches_set(DROP_RETIRE);
> +	igt_drop_caches_set(fd, DROP_RETIRE);
>
>  	/* the flinked bo VMA should have been cleared now, so a new bo of the
>  	 * same size should get the same offset
> @@ -269,12 +269,12 @@ static void flink_and_exit(void)
>  	flinked_bo = gem_open(fd2, name);
>
>  	/* Verify VMA is not there yet. */
> -	igt_assert(!igt_debugfs_search("i915_gem_gtt", match));
> +	igt_assert(!igt_debugfs_search(fd, "i915_gem_gtt", match));
>
>  	exec_and_get_offset(fd2, flinked_bo);
>
>  	/* Verify VMA has been created. */
> -	igt_assert(igt_debugfs_search("i915_gem_gtt", match));
> +	igt_assert(igt_debugfs_search(fd, "i915_gem_gtt", match));
>
>  	/* Close the context. */
>  	close(fd2);
> @@ -286,8 +286,8 @@ static void flink_and_exit(void)
>  	exec_and_get_offset(fd3, gem_create(fd3, 4096));
>  	close(fd3);
>
> -	igt_drop_caches_set(DROP_ACTIVE | DROP_RETIRE);
> -	igt_assert(!igt_debugfs_search("i915_gem_gtt", match));
> +	igt_drop_caches_set(fd, DROP_ACTIVE | DROP_RETIRE);
> +	igt_assert(!igt_debugfs_search(fd, "i915_gem_gtt", match));
>
>  	close(fd);
>  }
> diff --git a/tests/gem_reloc_vs_gpu.c b/tests/gem_reloc_vs_gpu.c
> index fa4d9aa36d80..afc31328fdc2 100644
> --- a/tests/gem_reloc_vs_gpu.c
> +++ b/tests/gem_reloc_vs_gpu.c
> @@ -265,7 +265,7 @@ static void do_forked_test(int fd, unsigned flags)
>  		igt_fork_helper(&thrasher) {
>  			while (1) {
>  				usleep(1000);
> -				igt_drop_caches_set(val);
> +				igt_drop_caches_set(fd, val);
>  			}
>  		}
>  	}
> diff --git a/tests/gem_seqno_wrap.c b/tests/gem_seqno_wrap.c
> index 3b0cc3a866b7..2270dfa22f93 100644
> --- a/tests/gem_seqno_wrap.c
> +++ b/tests/gem_seqno_wrap.c
> @@ -47,6 +47,7 @@
> IGT_TEST_DESCRIPTION("Runs blitcopy -> rendercopy with multiple buffers over"
>  		     " wrap boundary.");
>
> +static int drm_fd;
>  static int devid;
>  static int card_index = 0;
>  static uint32_t last_seqno = 0;
> @@ -174,26 +175,25 @@ static void run_sync_test(int num_buffers, bool verify)
>  	int max;
>  	drm_intel_bo **src, **dst1, **dst2;
>  	int width = 128, height = 128;
> -	int fd;
>  	int i;
>  	unsigned int *p_dst1, *p_dst2;
>  	struct igt_buf *s_src, *s_dst;
>
> -	fd = drm_open_driver(DRIVER_INTEL);
> +	drm_fd = drm_open_driver(DRIVER_INTEL);
>
> -	gem_quiescent_gpu(fd);
> +	gem_quiescent_gpu(drm_fd);
>
> -	devid = intel_get_drm_devid(fd);
> +	devid = intel_get_drm_devid(drm_fd);
>
> -	max = gem_aperture_size (fd) / (1024 * 1024) / 2;
> +	max = gem_aperture_size (drm_fd) / (1024 * 1024) / 2;
>  	if (num_buffers > max)
>  		num_buffers = max;
>
> -	bufmgr = drm_intel_bufmgr_gem_init(fd, 4096);
> +	bufmgr = drm_intel_bufmgr_gem_init(drm_fd, 4096);
>  	drm_intel_bufmgr_gem_enable_reuse(bufmgr);
> -	batch_blt = intel_batchbuffer_alloc(bufmgr, intel_get_drm_devid(fd));
> + batch_blt = intel_batchbuffer_alloc(bufmgr, intel_get_drm_devid(drm_fd));
>  	igt_assert(batch_blt);
> -	batch_3d = intel_batchbuffer_alloc(bufmgr, intel_get_drm_devid(fd));
> + batch_3d = intel_batchbuffer_alloc(bufmgr, intel_get_drm_devid(drm_fd));
>  	igt_assert(batch_3d);
>
>  	src = malloc(num_buffers * sizeof(*src));
> @@ -265,9 +265,9 @@ static void run_sync_test(int num_buffers, bool verify)
>  	free(dst1);
>  	free(src);
>
> -	gem_quiescent_gpu(fd);
> +	gem_quiescent_gpu(drm_fd);
>
> -	close(fd);
> +	close(drm_fd);
>  }
>
>  static int __read_seqno(uint32_t *seqno)
> @@ -278,7 +278,7 @@ static int __read_seqno(uint32_t *seqno)
>  	char *p;
>  	unsigned long int tmp;
>
> -	fh = igt_debugfs_open("i915_next_seqno", O_RDONLY);
> +	fh = igt_debugfs_open(drm_fd, "i915_next_seqno", O_RDONLY);
>
>  	r = read(fh, buf, sizeof(buf) - 1);
>  	close(fh);
> @@ -332,7 +332,7 @@ static void write_seqno(uint32_t seqno)
>  	if (options.dontwrap)
>  		return;
>
> -	fd = igt_debugfs_open("i915_next_seqno", O_RDWR);
> +	fd = igt_debugfs_open(drm_fd, "i915_next_seqno", O_RDWR);
>  	len = snprintf(buf, sizeof(buf), "0x%x", seqno);
>  	igt_assert(write(fd, buf, len) == len);
>  	close(fd);
> diff --git a/tests/gem_tiled_swapping.c b/tests/gem_tiled_swapping.c
> index b5849bc1a5ee..dacbb6900099 100644
> --- a/tests/gem_tiled_swapping.c
> +++ b/tests/gem_tiled_swapping.c
> @@ -155,9 +155,9 @@ static void thread_fini(struct thread *t)
>  	free(t->idx_arr);
>  }
>
> -static void check_memory_layout(void)
> +static void check_memory_layout(int fd)
>  {
> -	igt_skip_on_f(igt_debugfs_search("i915_swizzle_info", "L-shaped"),
> +	igt_skip_on_f(igt_debugfs_search(fd, "i915_swizzle_info", "L-shaped"),
>  		      "L-shaped memory configuration detected\n");
>
>  	igt_debug("normal memory configuration detected, continuing\n");
> @@ -177,7 +177,7 @@ igt_main
>
>  		fd = drm_open_driver(DRIVER_INTEL);
>
> -		check_memory_layout();
> +		check_memory_layout(fd);
>
>  		/* lock RAM, leaving only 512MB available */
>  		lock_size = max(0, intel_get_total_ram_mb() - AVAIL_RAM);
> diff --git a/tests/gem_workarounds.c b/tests/gem_workarounds.c
> index e512dd3d5d8a..08a1d09af451 100644
> --- a/tests/gem_workarounds.c
> +++ b/tests/gem_workarounds.c
> @@ -133,9 +133,9 @@ igt_main
>  		pci_dev = intel_get_pci_device();
>  		igt_require(pci_dev);
>
> -		intel_register_access_init(pci_dev, 0);
> +		intel_register_access_init(pci_dev, 0, fd);
>
> -		file = igt_debugfs_fopen("i915_wa_registers", "r");
> +		file = igt_debugfs_fopen(fd, "i915_wa_registers", "r");
>  		igt_assert(getline(&line, &line_size, file) > 0);
>  		igt_debug("i915_wa_registers: %s", line);
>  		sscanf(line, "Workarounds applied: %d", &num_wa_regs);
> diff --git a/tests/kms_atomic_transition.c b/tests/kms_atomic_transition.c
> index a8ab1b7b4d7a..70bff203ff3c 100644
> --- a/tests/kms_atomic_transition.c
> +++ b/tests/kms_atomic_transition.c
> @@ -675,7 +675,7 @@ static void run_modeset_tests(igt_display_t *display, int howmany, bool nonblock
>  		drmModeModeInfo *mode = NULL;
>
>  		if (is_i915_device(display->drm_fd))
> -			pipe_crcs[i] = igt_pipe_crc_new(i, INTEL_PIPE_CRC_SOURCE_AUTO);
> + pipe_crcs[i] = igt_pipe_crc_new(display->drm_fd, i, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  		for_each_valid_output_on_pipe(display, i, output) {
>  			if (output->pending_crtc_idx_mask)
> diff --git a/tests/kms_ccs.c b/tests/kms_ccs.c
> index 11acda89c3d6..d8291520c8a6 100644
> --- a/tests/kms_ccs.c
> +++ b/tests/kms_ccs.c
> @@ -212,7 +212,7 @@ static void test_output(data_t *data)
>  	igt_output_set_pipe(data->output, data->pipe);
>
>  	if (data->flags & TEST_CRC) {
> -		pipe_crc = igt_pipe_crc_new(data->pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + pipe_crc = igt_pipe_crc_new(data->drm_fd, data->pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  		display_fb(data, TEST_COMPRESSED);
>  		igt_pipe_crc_collect_crc(pipe_crc, &ref_crc);
> @@ -276,7 +276,7 @@ igt_main
>
>  		igt_require(intel_gen(intel_get_drm_devid(data.drm_fd)) >= 9);
>  		kmstest_set_vt_graphics_mode();
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>
>  		igt_display_init(&data.display, data.drm_fd);
>  	}
> diff --git a/tests/kms_chv_cursor_fail.c b/tests/kms_chv_cursor_fail.c
> index ce6e8df69400..3e74df1142da 100644
> --- a/tests/kms_chv_cursor_fail.c
> +++ b/tests/kms_chv_cursor_fail.c
> @@ -254,7 +254,7 @@ static void prepare_crtc(data_t *data)
>  	if (data->pipe_crc)
>  		igt_pipe_crc_free(data->pipe_crc);
>
> -	data->pipe_crc = igt_pipe_crc_new_nonblock(data->pipe,
> +	data->pipe_crc = igt_pipe_crc_new_nonblock(data->drm_fd, data->pipe,
>  						   INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	/* make sure cursor is disabled */
> @@ -374,7 +374,7 @@ int main(int argc, char **argv)
>
>  		kmstest_set_vt_graphics_mode();
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>
>  		igt_display_init(&data.display, data.drm_fd);
>  	}
> diff --git a/tests/kms_crtc_background_color.c b/tests/kms_crtc_background_color.c
> index d6dd8d9098ea..e12e163449f8 100644
> --- a/tests/kms_crtc_background_color.c
> +++ b/tests/kms_crtc_background_color.c
> @@ -85,7 +85,7 @@ static void prepare_crtc(data_t *data, igt_output_t *output, enum pipe pipe,
>
>  	/* create the pipe_crc object for this pipe */
>  	igt_pipe_crc_free(data->pipe_crc);
> -	data->pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + data->pipe_crc = igt_pipe_crc_new(data->gfx_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	mode = igt_output_get_mode(output);
>
> @@ -179,7 +179,7 @@ igt_simple_main
>  	igt_skip_on_simulation();
>
>  	data.gfx_fd = drm_open_driver(DRIVER_INTEL);
> -	igt_require_pipe_crc();
> +	igt_require_pipe_crc(data.gfx_fd);
>  	igt_display_init(&data.display, data.gfx_fd);
>
>  	test_crtc_background(&data);
> diff --git a/tests/kms_cursor_crc.c b/tests/kms_cursor_crc.c
> index 4851e18f457d..206f85268c9e 100644
> --- a/tests/kms_cursor_crc.c
> +++ b/tests/kms_cursor_crc.c
> @@ -310,7 +310,7 @@ static void prepare_crtc(data_t *data, igt_output_t *output,
>  	if (data->pipe_crc)
>  		igt_pipe_crc_free(data->pipe_crc);
>
> -	data->pipe_crc = igt_pipe_crc_new(data->pipe,
> +	data->pipe_crc = igt_pipe_crc_new(data->drm_fd, data->pipe,
>  					  INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	/* x/y position where the cursor is still fully visible */
> @@ -602,7 +602,7 @@ igt_main
>
>  		kmstest_set_vt_graphics_mode();
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>
>  		igt_display_init(&data.display, data.drm_fd);
>  	}
> diff --git a/tests/kms_cursor_legacy.c b/tests/kms_cursor_legacy.c
> index c7083a070f27..92f8e5f304ce 100644
> --- a/tests/kms_cursor_legacy.c
> +++ b/tests/kms_cursor_legacy.c
> @@ -1264,7 +1264,7 @@ static void flip_vs_cursor_crc(igt_display_t *display, bool atomic)
>
> igt_display_commit2(display, display->is_atomic ? COMMIT_ATOMIC : COMMIT_LEGACY);
>
> -	pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + pipe_crc = igt_pipe_crc_new(display->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	set_cursor_on_pipe(display, pipe, &cursor_fb);
>  	igt_display_commit2(display, COMMIT_UNIVERSAL);
> @@ -1326,7 +1326,7 @@ static void flip_vs_cursor_busy_crc(igt_display_t *display, bool atomic)
>
> igt_display_commit2(display, display->is_atomic ? COMMIT_ATOMIC : COMMIT_LEGACY);
>
> -	pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + pipe_crc = igt_pipe_crc_new(display->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	set_cursor_on_pipe(display, pipe, &cursor_fb);
>  	igt_display_commit2(display, COMMIT_UNIVERSAL);
> diff --git a/tests/kms_draw_crc.c b/tests/kms_draw_crc.c
> index e1639810ba3a..c57d3a35b6b8 100644
> --- a/tests/kms_draw_crc.c
> +++ b/tests/kms_draw_crc.c
> @@ -232,7 +232,7 @@ static void setup_environment(void)
>  	drm_intel_bufmgr_gem_enable_reuse(bufmgr);
>
>  	find_modeset_params();
> -	pipe_crc = igt_pipe_crc_new(kmstest_get_crtc_idx(drm_res, ms.crtc_id),
> + pipe_crc = igt_pipe_crc_new(drm_fd, kmstest_get_crtc_idx(drm_res, ms.crtc_id),
>  				    INTEL_PIPE_CRC_SOURCE_AUTO);
>  }
>
> diff --git a/tests/kms_fbc_crc.c b/tests/kms_fbc_crc.c
> index 96af06a04869..7964e052862b 100644
> --- a/tests/kms_fbc_crc.c
> +++ b/tests/kms_fbc_crc.c
> @@ -211,7 +211,7 @@ static bool fbc_enabled(data_t *data)
>  {
>  	char str[128] = {};
>
> -	igt_debugfs_read("i915_fbc_status", str);
> +	igt_debugfs_read(data->drm_fd, "i915_fbc_status", str);
>  	return strstr(str, "FBC enabled") != NULL;
>  }
>
> @@ -378,7 +378,7 @@ static bool prepare_test(data_t *data, enum test_mode test_mode)
>
>  	igt_pipe_crc_free(data->pipe_crc);
>  	data->pipe_crc = NULL;
> -	pipe_crc = igt_pipe_crc_new(data->pipe,
> +	pipe_crc = igt_pipe_crc_new(data->drm_fd, data->pipe,
>  				    INTEL_PIPE_CRC_SOURCE_AUTO);
>  	data->pipe_crc = pipe_crc;
>
> @@ -530,9 +530,9 @@ igt_main
>
>  		data.devid = intel_get_drm_devid(data.drm_fd);
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>
> -		igt_debugfs_read("i915_fbc_status", buf);
> +		igt_debugfs_read(data.drm_fd, "i915_fbc_status", buf);
>  		igt_require_f(!strstr(buf, "unsupported on this chipset"),
>  			      "FBC not supported\n");
>
> diff --git a/tests/kms_fbcon_fbt.c b/tests/kms_fbcon_fbt.c
> index 6342289f765b..d0090912694e 100644
> --- a/tests/kms_fbcon_fbt.c
> +++ b/tests/kms_fbcon_fbt.c
> @@ -82,11 +82,11 @@ static void teardown_drm(struct drm_info *drm)
>  	igt_assert(close(drm->fd) == 0);
>  }
>
> -static bool fbc_supported_on_chipset(void)
> +static bool fbc_supported_on_chipset(int fd)
>  {
>  	char buf[128];
>
> -	igt_debugfs_read("i915_fbc_status", buf);
> +	igt_debugfs_read(fd, "i915_fbc_status", buf);
>  	return !strstr(buf, "FBC unsupported on this chipset\n");
>  }
>
> @@ -95,17 +95,17 @@ static bool connector_can_fbc(drmModeConnectorPtr connector)
>  	return true;
>  }
>
> -static bool fbc_is_enabled(void)
> +static bool fbc_is_enabled(int fd)
>  {
>  	char buf[128];
>
> -	igt_debugfs_read("i915_fbc_status", buf);
> +	igt_debugfs_read(fd, "i915_fbc_status", buf);
>  	return strstr(buf, "FBC enabled\n");
>  }
>
> -static bool fbc_wait_until_enabled(void)
> +static bool fbc_wait_until_enabled(int fd)
>  {
> -	return igt_wait(fbc_is_enabled(), 5000, 1);
> +	return igt_wait(fbc_is_enabled(fd), 5000, 1);
>  }
>
>  typedef bool (*connector_possible_fn)(drmModeConnectorPtr connector);
> @@ -147,11 +147,11 @@ static void set_mode_for_one_screen(struct drm_info *drm, struct igt_fb *fb,
>  	igt_assert_eq(rc, 0);
>  }
>
> -static bool psr_supported_on_chipset(void)
> +static bool psr_supported_on_chipset(int fd)
>  {
>  	char buf[256];
>
> -	igt_debugfs_read("i915_edp_psr_status", buf);
> +	igt_debugfs_read(fd, "i915_edp_psr_status", buf);
>  	return strstr(buf, "Sink_Support: yes\n");
>  }
>
> @@ -160,22 +160,22 @@ static bool connector_can_psr(drmModeConnectorPtr connector)
>  	return (connector->connector_type == DRM_MODE_CONNECTOR_eDP);
>  }
>
> -static bool psr_is_enabled(void)
> +static bool psr_is_enabled(int fd)
>  {
>  	char buf[256];
>
> -	igt_debugfs_read("i915_edp_psr_status", buf);
> +	igt_debugfs_read(fd, "i915_edp_psr_status", buf);
>  	return strstr(buf, "\nActive: yes\n");
>  }
>
> -static bool psr_wait_until_enabled(void)
> +static bool psr_wait_until_enabled(int fd)
>  {
> -	return igt_wait(psr_is_enabled(), 5000, 1);
> +	return igt_wait(psr_is_enabled(fd), 5000, 1);
>  }
>
>  struct feature {
> -	bool (*supported_on_chipset)(void);
> -	bool (*wait_until_enabled)(void);
> +	bool (*supported_on_chipset)(int fd);
> +	bool (*wait_until_enabled)(int fd);
>  	bool (*connector_possible_fn)(drmModeConnectorPtr connector);
>  	const char *param_name;
>  } fbc = {
> @@ -201,26 +201,26 @@ static void subtest(struct feature *feature, bool suspend)
>  	struct drm_info drm;
>  	struct igt_fb fb;
>
> -	igt_require(feature->supported_on_chipset());
> +	setup_drm(&drm);
> +
> +	igt_require(feature->supported_on_chipset(drm.fd));
>
>  	disable_features();
>  	igt_set_module_param_int(feature->param_name, 1);
>
> -	setup_drm(&drm);
> -
>  	kmstest_unset_all_crtcs(drm.fd, drm.res);
>  	wait_user("Modes unset.");
> -	igt_assert(!feature->wait_until_enabled());
> +	igt_assert(!feature->wait_until_enabled(drm.fd));
>
>  	set_mode_for_one_screen(&drm, &fb, feature->connector_possible_fn);
>  	wait_user("Screen set.");
> -	igt_assert(feature->wait_until_enabled());
> +	igt_assert(feature->wait_until_enabled(drm.fd));
>
>  	if (suspend) {
>  		igt_system_suspend_autoresume(SUSPEND_STATE_MEM,
>  					      SUSPEND_TEST_NONE);
>  		sleep(5);
> -		igt_assert(feature->wait_until_enabled());
> +		igt_assert(feature->wait_until_enabled(drm.fd));
>  	}
>
>  	igt_remove_fb(drm.fd, &fb);
> @@ -230,13 +230,13 @@ static void subtest(struct feature *feature, bool suspend)
>  	sleep(3);
>
>  	wait_user("Back to fbcon.");
> -	igt_assert(!feature->wait_until_enabled());
> +	igt_assert(!feature->wait_until_enabled(drm.fd));
>
>  	if (suspend) {
>  		igt_system_suspend_autoresume(SUSPEND_STATE_MEM,
>  					      SUSPEND_TEST_NONE);
>  		sleep(5);
> -		igt_assert(!feature->wait_until_enabled());
> +		igt_assert(!feature->wait_until_enabled(drm.fd));
>  	}
>  }
>
> diff --git a/tests/kms_flip_tiling.c b/tests/kms_flip_tiling.c
> index cd2f510f1d45..143be198abe6 100644
> --- a/tests/kms_flip_tiling.c
> +++ b/tests/kms_flip_tiling.c
> @@ -41,14 +41,14 @@ typedef struct {
>
>  static igt_pipe_crc_t *_pipe_crc;
>
> -static igt_pipe_crc_t *pipe_crc_new(int pipe)
> +static igt_pipe_crc_t *pipe_crc_new(data_t *data, int pipe)
>  {
>  	if (_pipe_crc) {
>  		igt_pipe_crc_free(_pipe_crc);
>  		_pipe_crc = NULL;
>  	}
>
> -	_pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + _pipe_crc = igt_pipe_crc_new(data->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>  	igt_assert(_pipe_crc);
>
>  	return _pipe_crc;
> @@ -89,7 +89,7 @@ test_flip_tiling(data_t *data, enum pipe pipe, igt_output_t *output, uint64_t ti
>  	igt_crc_t reference_crc, crc;
>  	int fb_id, ret, width;
>
> -	pipe_crc = pipe_crc_new(pipe);
> +	pipe_crc = pipe_crc_new(data, pipe);
>  	igt_output_set_pipe(output, pipe);
>
>  	mode = igt_output_get_mode(output);
> @@ -168,7 +168,7 @@ igt_main
>
>  		kmstest_set_vt_graphics_mode();
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>  		igt_display_init(&data.display, data.drm_fd);
>  	}
>
> diff --git a/tests/kms_frontbuffer_tracking.c b/tests/kms_frontbuffer_tracking.c
> index 03c77107eccd..28e4b5b1abec 100644
> --- a/tests/kms_frontbuffer_tracking.c
> +++ b/tests/kms_frontbuffer_tracking.c
> @@ -781,7 +781,7 @@ static bool fbc_is_enabled(void)
>  {
>  	char buf[128];
>
> -	igt_debugfs_read("i915_fbc_status", buf);
> +	igt_debugfs_read(drm.fd, "i915_fbc_status", buf);
>  	return strstr(buf, "FBC enabled\n");
>  }
>
> @@ -789,7 +789,7 @@ static void fbc_print_status(void)
>  {
>  	char buf[128];
>
> -	igt_debugfs_read("i915_fbc_status", buf);
> +	igt_debugfs_read(drm.fd, "i915_fbc_status", buf);
>  	igt_info("FBC status:\n%s\n", buf);
>  }
>
> @@ -797,7 +797,7 @@ static bool psr_is_enabled(void)
>  {
>  	char buf[256];
>
> -	igt_debugfs_read("i915_edp_psr_status", buf);
> +	igt_debugfs_read(drm.fd, "i915_edp_psr_status", buf);
>  	return strstr(buf, "\nActive: yes\n") &&
>  	       strstr(buf, "\nHW Enabled & Active bit: yes\n");
>  }
> @@ -806,7 +806,7 @@ static void psr_print_status(void)
>  {
>  	char buf[256];
>
> -	igt_debugfs_read("i915_edp_psr_status", buf);
> +	igt_debugfs_read(drm.fd, "i915_edp_psr_status", buf);
>  	igt_info("PSR status:\n%s\n", buf);
>  }
>
> @@ -817,7 +817,7 @@ static struct timespec fbc_get_last_action(void)
>  	char *action;
>  	ssize_t n_read;
>
> -	igt_debugfs_read("i915_fbc_status", buf);
> +	igt_debugfs_read(drm.fd, "i915_fbc_status", buf);
>
>  	action = strstr(buf, "\nLast action:");
>  	igt_assert(action);
> @@ -866,7 +866,7 @@ static void fbc_setup_last_action(void)
>  	char buf[128];
>  	char *action;
>
> -	igt_debugfs_read("i915_fbc_status", buf);
> +	igt_debugfs_read(drm.fd, "i915_fbc_status", buf);
>
>  	action = strstr(buf, "\nLast action:");
>  	if (!action) {
> @@ -885,7 +885,7 @@ static bool fbc_is_compressing(void)
>  {
>  	char buf[128];
>
> -	igt_debugfs_read("i915_fbc_status", buf);
> +	igt_debugfs_read(drm.fd, "i915_fbc_status", buf);
>  	return strstr(buf, "\nCompressing: yes\n") != NULL;
>  }
>
> @@ -898,7 +898,7 @@ static bool fbc_not_enough_stolen(void)
>  {
>  	char buf[128];
>
> -	igt_debugfs_read("i915_fbc_status", buf);
> +	igt_debugfs_read(drm.fd, "i915_fbc_status", buf);
>  	return strstr(buf, "FBC disabled: not enough stolen memory\n");
>  }
>
> @@ -906,7 +906,7 @@ static bool fbc_stride_not_supported(void)
>  {
>  	char buf[128];
>
> -	igt_debugfs_read("i915_fbc_status", buf);
> +	igt_debugfs_read(drm.fd, "i915_fbc_status", buf);
>  	return strstr(buf, "FBC disabled: framebuffer stride not supported\n");
>  }
>
> @@ -1420,7 +1420,7 @@ static void setup_sink_crc(void)
>  	fill_fb_region(&prim_mode_params.fb, COLOR_PRIM_BG);
>  	set_mode_for_params(&prim_mode_params);
>
> -	sink_crc.fd = igt_debugfs_open("i915_sink_crc_eDP1", O_RDONLY);
> +	sink_crc.fd = igt_debugfs_open(drm.fd, "i915_sink_crc_eDP1", O_RDONLY);
>  	igt_assert_lte(0, sink_crc.fd);
>
>  	/* Do a first read to try to detect if it's supported. */
> @@ -1432,7 +1432,7 @@ static void setup_crcs(void)
>  	enum pixel_format f;
>  	int crtc_idx = kmstest_get_crtc_idx(drm.res, prim_mode_params.crtc_id);
>
> -	pipe_crc = igt_pipe_crc_new(crtc_idx, INTEL_PIPE_CRC_SOURCE_AUTO);
> + pipe_crc = igt_pipe_crc_new(drm.fd, crtc_idx, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	setup_sink_crc();
>
> @@ -1497,7 +1497,7 @@ static bool fbc_supported_on_chipset(void)
>  {
>  	char buf[128];
>
> -	igt_debugfs_read("i915_fbc_status", buf);
> +	igt_debugfs_read(drm.fd, "i915_fbc_status", buf);
>  	return !strstr(buf, "FBC unsupported on this chipset\n");
>  }
>
> @@ -1533,7 +1533,7 @@ static bool psr_sink_has_support(void)
>  {
>  	char buf[256];
>
> -	igt_debugfs_read("i915_edp_psr_status", buf);
> +	igt_debugfs_read(drm.fd, "i915_edp_psr_status", buf);
>  	return strstr(buf, "Sink_Support: yes\n");
>  }
>
> diff --git a/tests/kms_invalid_dotclock.c b/tests/kms_invalid_dotclock.c
> index 43f768fd26ea..e6e72f528d85 100644
> --- a/tests/kms_invalid_dotclock.c
> +++ b/tests/kms_invalid_dotclock.c
> @@ -104,13 +104,13 @@ static void test(data_t *data)
>  	igt_require_f(valid_connectors, "No suitable connectors found\n");
>  }
>
> -static int i915_max_dotclock(void)
> +static int i915_max_dotclock(data_t *data)
>  {
>  	char buf[4096];
>  	char *s;
>  	int max_dotclock = 0;
>
> -	igt_debugfs_read("i915_frequency_info", buf);
> +	igt_debugfs_read(data->drm_fd, "i915_frequency_info", buf);
>  	s = strstr(buf, "Max pixel clock frequency:");
>  	igt_assert(s);
> igt_assert_eq(sscanf(s, "Max pixel clock frequency: %d kHz", &max_dotclock), 1);
> @@ -137,7 +137,7 @@ igt_simple_main
>  	data.res = drmModeGetResources(data.drm_fd);
>  	kmstest_unset_all_crtcs(data.drm_fd, data.res);
>
> -	data.max_dotclock = i915_max_dotclock();
> +	data.max_dotclock = i915_max_dotclock(&data);
>  	igt_info("Max dotclock: %d kHz\n", data.max_dotclock);
>
>  	test(&data);
> diff --git a/tests/kms_mmap_write_crc.c b/tests/kms_mmap_write_crc.c
> index 8a1331ccfbcd..e5f089f6b78f 100644
> --- a/tests/kms_mmap_write_crc.c
> +++ b/tests/kms_mmap_write_crc.c
> @@ -185,7 +185,7 @@ static void prepare_crtc(data_t *data)
>  	if (data->pipe_crc)
>  		igt_pipe_crc_free(data->pipe_crc);
>
> -	data->pipe_crc = igt_pipe_crc_new(data->pipe,
> +	data->pipe_crc = igt_pipe_crc_new(data->drm_fd, data->pipe,
>  					  INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	/* get reference crc for the white fb */
> @@ -277,7 +277,7 @@ int main(int argc, char **argv)
>
>  		kmstest_set_vt_graphics_mode();
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>
>  		igt_display_init(&data.display, data.drm_fd);
>
> diff --git a/tests/kms_mmio_vs_cs_flip.c b/tests/kms_mmio_vs_cs_flip.c
> index 09217b310f26..96a9dec3d656 100644
> --- a/tests/kms_mmio_vs_cs_flip.c
> +++ b/tests/kms_mmio_vs_cs_flip.c
> @@ -235,7 +235,7 @@ test_plane(data_t *data, igt_output_t *output, enum pipe pipe, int plane)
>
>  	if (data->pipe_crc)
>  		igt_pipe_crc_free(data->pipe_crc);
> -	data->pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + data->pipe_crc = igt_pipe_crc_new(data->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	/* set red fb and grab reference crc */
>  	igt_plane_set_fb(primary, &red_fb);
> @@ -374,7 +374,7 @@ test_crtc(data_t *data, igt_output_t *output, enum pipe pipe)
>
>  	if (data->pipe_crc)
>  		igt_pipe_crc_free(data->pipe_crc);
> -	data->pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + data->pipe_crc = igt_pipe_crc_new(data->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	/* set red fb and grab reference crc */
>  	igt_plane_set_fb(primary, &red_fb);
> @@ -497,7 +497,7 @@ igt_main
>
>  		data.devid = intel_get_drm_devid(data.drm_fd);
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>  		igt_display_init(&data.display, data.drm_fd);
>
>  		data.bufmgr = drm_intel_bufmgr_gem_init(data.drm_fd, 4096);
> diff --git a/tests/kms_pipe_color.c b/tests/kms_pipe_color.c
> index c7a5d2f1a81e..fd58ac8118c2 100644
> --- a/tests/kms_pipe_color.c
> +++ b/tests/kms_pipe_color.c
> @@ -852,7 +852,7 @@ run_tests_for_pipe(data_t *data, enum pipe p)
>  	igt_fixture {
>  		int valid_tests = 0;
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data->drm_fd);
>
>  		igt_require(p < data->display.n_pipes);
>
> @@ -861,7 +861,8 @@ run_tests_for_pipe(data_t *data, enum pipe p)
>
>  		primary = igt_pipe_get_plane_type(pipe, DRM_PLANE_TYPE_PRIMARY);
>
> -		data->pipe_crc = igt_pipe_crc_new(primary->pipe->pipe,
> +		data->pipe_crc = igt_pipe_crc_new(data->drm_fd,
> +						  primary->pipe->pipe,
>  						  INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  		igt_require(igt_pipe_get_property(&data->display.pipes[p],
> diff --git a/tests/kms_pipe_crc_basic.c b/tests/kms_pipe_crc_basic.c
> index dd2ad3c366bc..d0dc2a1b58cf 100644
> --- a/tests/kms_pipe_crc_basic.c
> +++ b/tests/kms_pipe_crc_basic.c
> @@ -48,7 +48,7 @@ static void test_bad_command(data_t *data, const char *cmd)
>  	FILE *ctl;
>  	size_t written;
>
> -	ctl = igt_debugfs_fopen("i915_display_crc_ctl", "r+");
> +	ctl = igt_debugfs_fopen(data->drm_fd, "i915_display_crc_ctl", "r+");
>  	igt_require(ctl);
>
>  	written = fwrite(cmd, 1, strlen(cmd), ctl);
> @@ -66,7 +66,7 @@ static void test_bad_source(data_t *data)
>  	size_t written;
>  	const char *source = "foo";
>
> -	f = igt_debugfs_fopen("crtc-0/crc/control", "w");
> +	f = igt_debugfs_fopen(data->drm_fd, "crtc-0/crc/control", "w");
>  	if (!f) {
>  		test_bad_command(data, "pipe A foo");
>  		return;
> @@ -79,7 +79,7 @@ static void test_bad_source(data_t *data)
>  	igt_assert(!errno);
>  	fclose(f);
>
> -	f = igt_debugfs_fopen("crtc-0/crc/data", "w");
> +	f = igt_debugfs_fopen(data->drm_fd, "crtc-0/crc/data", "w");
>  	igt_assert(!f);
>  	igt_assert_eq(errno, EINVAL);
>  }
> @@ -125,9 +125,9 @@ test_read_crc_for_output(data_t *data, int pipe, igt_output_t *output,
>  		igt_display_commit(display);
>
>  		if (flags & TEST_NONBLOCK)
> - pipe_crc = igt_pipe_crc_new_nonblock(pipe, INTEL_PIPE_CRC_SOURCE_AUTO); > + pipe_crc = igt_pipe_crc_new_nonblock(data->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>  		else
> -			pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + pipe_crc = igt_pipe_crc_new(data->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  		igt_pipe_crc_start(pipe_crc);
>
> @@ -210,7 +210,7 @@ igt_main
>
>  		kmstest_set_vt_graphics_mode();
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>
>  		igt_display_init(&data.display, data.drm_fd);
>  	}
> diff --git a/tests/kms_plane.c b/tests/kms_plane.c
> index d0de0f52fce4..e1bd467bb97d 100644
> --- a/tests/kms_plane.c
> +++ b/tests/kms_plane.c
> @@ -52,7 +52,7 @@ static color_t blue  = { 0.0f, 0.0f, 1.0f };
>   */
>  static void test_init(data_t *data, enum pipe pipe)
>  {
> -	data->pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + data->pipe_crc = igt_pipe_crc_new(data->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>  }
>
>  static void test_fini(data_t *data)
> @@ -430,7 +430,7 @@ igt_main
>
>  		kmstest_set_vt_graphics_mode();
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>  		igt_display_init(&data.display, data.drm_fd);
>  	}
>
> diff --git a/tests/kms_plane_lowres.c b/tests/kms_plane_lowres.c
> index 689c248ed309..6f1596015d76 100644
> --- a/tests/kms_plane_lowres.c
> +++ b/tests/kms_plane_lowres.c
> @@ -112,7 +112,7 @@ get_lowres_mode(int drmfd, drmModeModeInfo *mode_default)
>  static void
>  test_init(data_t *data, enum pipe pipe)
>  {
> -	data->pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + data->pipe_crc = igt_pipe_crc_new(data->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO); > data->plane = calloc(data->display.pipes[pipe].n_planes, sizeof(data->plane));\
>  	igt_assert_f(data->plane, "Failed to allocate memory for %d planes\n",
>  	             data->display.pipes[pipe].n_planes);
> @@ -189,11 +189,9 @@ test_setup(data_t *data, enum pipe pipe, uint64_t modifier, int flags,
>  	int size;
>  	int i, x, y;
>
> - crtc.planes = calloc(sizeof(struct kmstest_plane), data->display.pipes[pipe].n_planes); > - igt_assert_f(crtc.planes, "Failed to allocate memory for %d planes\n", data->display.pipes[pipe].n_planes);
>  	igt_output_set_pipe(output, pipe);
>
> -	kmstest_get_crtc(pipe, &crtc);
> +	kmstest_get_crtc(data->drm_fd, pipe, &crtc);
>  	igt_skip_on(crtc.n_planes > data->display.pipes[pipe].n_planes);
>  	igt_skip_on(crtc.n_planes == 0);
>
> @@ -263,7 +261,7 @@ test_plane_position_with_output(data_t *data, enum pipe pipe,
>  	n = igt_pipe_crc_get_crcs(data->pipe_crc, 1, &crc_hires1);
>  	igt_assert_eq(1, n);
>
> -	igt_assert_plane_visible(pipe, true);
> +	igt_assert_plane_visible(data->drm_fd, pipe, true);
>
>  	/* switch to lower resolution */
>  	igt_output_override_mode(output, &mode_lowres);
> @@ -275,7 +273,7 @@ test_plane_position_with_output(data_t *data, enum pipe pipe,
>
>  	display_commit_mode(data, pipe, flags, crc_lowres);
>
> -	igt_assert_plane_visible(pipe, false);
> +	igt_assert_plane_visible(data->drm_fd, pipe, false);
>
>  	/* switch back to higher resolution */
>  	igt_output_override_mode(output, NULL);
> @@ -287,7 +285,7 @@ test_plane_position_with_output(data_t *data, enum pipe pipe,
>
>  	display_commit_mode(data, pipe, flags, crc_hires2);
>
> -	igt_assert_plane_visible(pipe, true);
> +	igt_assert_plane_visible(data->drm_fd, pipe, true);
>
>  	igt_pipe_crc_stop(data->pipe_crc);
>
> @@ -348,7 +346,7 @@ igt_main
>
>  		kmstest_set_vt_graphics_mode();
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>  		igt_display_init(&data.display, data.drm_fd);
>  	}
>
> diff --git a/tests/kms_plane_multiple.c b/tests/kms_plane_multiple.c
> index 4930286c9190..93dce6b02340 100644
> --- a/tests/kms_plane_multiple.c
> +++ b/tests/kms_plane_multiple.c
> @@ -72,7 +72,7 @@ struct {
>   */
>  static void test_init(data_t *data, enum pipe pipe, int n_planes)
>  {
> -	data->pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + data->pipe_crc = igt_pipe_crc_new(data->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	data->plane = calloc(n_planes, sizeof(data->plane));
> igt_assert_f(data->plane != NULL, "Failed to allocate memory for planes\n");
> @@ -508,7 +508,7 @@ int main(int argc, char *argv[])
>  	igt_fixture {
>  		data.drm_fd = drm_open_driver_master(DRIVER_INTEL);
>  		kmstest_set_vt_graphics_mode();
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>  		igt_display_init(&data.display, data.drm_fd);
>  		igt_require(data.display.n_pipes > 0);
>  	}
> diff --git a/tests/kms_plane_scaling.c b/tests/kms_plane_scaling.c
> index 18ba86c9182e..1457894aaa10 100644
> --- a/tests/kms_plane_scaling.c
> +++ b/tests/kms_plane_scaling.c
> @@ -64,7 +64,7 @@ static void prepare_crtc(data_t *data, igt_output_t *output, enum pipe pipe,
>
>  	/* create the pipe_crc object for this pipe */
>  	igt_pipe_crc_free(data->pipe_crc);
> -	data->pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + data->pipe_crc = igt_pipe_crc_new(data->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	/* before allocating, free if any older fb */
>  	if (data->fb_id1) {
> @@ -318,7 +318,7 @@ igt_simple_main
>
>
>  	data.drm_fd = drm_open_driver(DRIVER_INTEL);
> -	igt_require_pipe_crc();
> +	igt_require_pipe_crc(data.drm_fd);
>  	igt_display_init(&data.display, data.drm_fd);
>  	data.devid = intel_get_drm_devid(data.drm_fd);
>
> diff --git a/tests/kms_psr_sink_crc.c b/tests/kms_psr_sink_crc.c
> index 8f6bdc0d254e..f66a7543ccb6 100644
> --- a/tests/kms_psr_sink_crc.c
> +++ b/tests/kms_psr_sink_crc.c
> @@ -195,7 +195,7 @@ static bool psr_possible(data_t *data)
>  {
>  	char buf[512];
>
> -	igt_debugfs_read("i915_edp_psr_status", buf);
> +	igt_debugfs_read(data->drm_fd, "i915_edp_psr_status", buf);
>
>  	return running_with_psr_disabled ||
>  		strstr(buf, "Sink_Support: yes\n");
> @@ -205,7 +205,7 @@ static bool psr_active(data_t *data)
>  {
>  	char buf[512];
>
> -	igt_debugfs_read("i915_edp_psr_status", buf);
> +	igt_debugfs_read(data->drm_fd, "i915_edp_psr_status", buf);
>
>  	return running_with_psr_disabled ||
>  		strstr(buf, "HW Enabled & Active bit: yes\n");
> @@ -229,7 +229,7 @@ static void get_sink_crc(data_t *data, char *crc) {
>  	if (igt_interactive_debug)
>  		return;
>
> -	file = igt_debugfs_fopen("i915_sink_crc_eDP1", "r");
> +	file = igt_debugfs_fopen(data->drm_fd, "i915_sink_crc_eDP1", "r");
>  	igt_require(file);
>
>  	ret = fscanf(file, "%s\n", crc);
> diff --git a/tests/kms_pwrite_crc.c b/tests/kms_pwrite_crc.c
> index 1e62637596ee..ee895db63fe2 100644
> --- a/tests/kms_pwrite_crc.c
> +++ b/tests/kms_pwrite_crc.c
> @@ -124,7 +124,7 @@ static void prepare_crtc(data_t *data)
>  	if (data->pipe_crc)
>  		igt_pipe_crc_free(data->pipe_crc);
>
> -	data->pipe_crc = igt_pipe_crc_new(data->pipe,
> +	data->pipe_crc = igt_pipe_crc_new(data->drm_fd, data->pipe,
>  					  INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	/* get reference crc for the white fb */
> @@ -183,7 +183,7 @@ igt_simple_main
>
>  		kmstest_set_vt_graphics_mode();
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>
>  		igt_display_init(&data.display, data.drm_fd);
>  	}
> diff --git a/tests/kms_rotation_crc.c b/tests/kms_rotation_crc.c
> index 9bfcde3324f5..43478849505f 100644
> --- a/tests/kms_rotation_crc.c
> +++ b/tests/kms_rotation_crc.c
> @@ -139,7 +139,7 @@ static void prepare_crtc(data_t *data, igt_output_t *output, enum pipe pipe,
>
>  	/* create the pipe_crc object for this pipe */
>  	igt_pipe_crc_free(data->pipe_crc);
> -	data->pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + data->pipe_crc = igt_pipe_crc_new(data->gfx_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	mode = igt_output_get_mode(output);
>
> @@ -517,7 +517,7 @@ igt_main
>
>  		kmstest_set_vt_graphics_mode();
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.gfx_fd);
>
>  		igt_display_init(&data.display, data.gfx_fd);
>  	}
> diff --git a/tests/kms_sink_crc_basic.c b/tests/kms_sink_crc_basic.c
> index 953ead10adf9..f8f814f21442 100644
> --- a/tests/kms_sink_crc_basic.c
> +++ b/tests/kms_sink_crc_basic.c
> @@ -46,11 +46,11 @@ typedef struct {
>  	igt_plane_t *primary;
>  } data_t;
>
> -static void get_crc(char *crc) {
> +static void get_crc(data_t *data, char *crc) {
>  	int ret;
>  	FILE *file;
>
> -	file = igt_debugfs_fopen("i915_sink_crc_eDP1", "r");
> +	file = igt_debugfs_fopen(data->drm_fd, "i915_sink_crc_eDP1", "r");
>  	igt_require(file);
>
>  	ret = fscanf(file, "%s\n", crc);
> @@ -95,7 +95,7 @@ static void basic_sink_crc_check(data_t *data)
>  	igt_display_commit(&data->display);
>
>  	/* It should be Green */
> -	get_crc(crc);
> +	get_crc(data, crc);
>  	assert_color(crc, GREEN);
>
>  	/* Go Red */
> @@ -103,7 +103,7 @@ static void basic_sink_crc_check(data_t *data)
>  	igt_display_commit(&data->display);
>
>  	/* It should be Red */
> -	get_crc(crc);
> +	get_crc(data, crc);
>  	assert_color(crc, RED);
>  }
>
> diff --git a/tests/kms_universal_plane.c b/tests/kms_universal_plane.c
> index a2fe1cc1be38..991204ceb8a1 100644
> --- a/tests/kms_universal_plane.c
> +++ b/tests/kms_universal_plane.c
> @@ -67,7 +67,7 @@ functional_test_init(functional_test_t *test, igt_output_t *output, enum pipe pi
>  	data_t *data = test->data;
>  	drmModeModeInfo *mode;
>
> -	test->pipe_crc = igt_pipe_crc_new(pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + test->pipe_crc = igt_pipe_crc_new(data->drm_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	igt_output_set_pipe(output, pipe);
>
> @@ -545,13 +545,13 @@ cursor_leak_test_fini(data_t *data,
>  }
>
>  static int
> -i915_gem_fb_count(void)
> +i915_gem_fb_count(data_t *data)
>  {
>  	char buf[1024];
>  	FILE *fp;
>  	int count = 0;
>
> -	fp = igt_debugfs_fopen("i915_gem_framebuffer", "r");
> +	fp = igt_debugfs_fopen(data->drm_fd, "i915_gem_framebuffer", "r");
>  	igt_require(fp);
>  	while (fgets(buf, sizeof(buf), fp) != NULL)
>  		count++;
> @@ -579,7 +579,7 @@ cursor_leak_test_pipe(data_t *data, enum pipe pipe, igt_output_t *output)
>  	mode = igt_output_get_mode(output);
>
>  	/* Count GEM framebuffers before creating our cursor FB's */
> -	count1 = i915_gem_fb_count();
> +	count1 = i915_gem_fb_count(data);
>
>  	/* Black background FB */
>  	igt_create_color_fb(data->drm_fd, mode->hdisplay, mode->vdisplay,
> @@ -637,7 +637,7 @@ cursor_leak_test_pipe(data_t *data, enum pipe pipe, igt_output_t *output)
>  	cursor_leak_test_fini(data, output, &background_fb, cursor_fb);
>
> /* We should be back to the same framebuffer count as when we started */
> -	count2 = i915_gem_fb_count();
> +	count2 = i915_gem_fb_count(data);
>
>  	igt_assert_eq(count1, count2);
>  }
> @@ -791,7 +791,7 @@ igt_main
>
>  		kmstest_set_vt_graphics_mode();
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(data.drm_fd);
>  		igt_display_init(&data.display, data.drm_fd);
>  	}
>
> diff --git a/tests/perf.c b/tests/perf.c
> index c9c5c57ede90..17925eea72dd 100644
> --- a/tests/perf.c
> +++ b/tests/perf.c
> @@ -297,7 +297,7 @@ sysfs_write(const char *file, uint64_t val)
>  }
>
>  static char *
> -read_debugfs_record(const char *file, const char *key)
> +read_debugfs_record(int fd, const char *file, const char *key)
>  {
>  	FILE *fp;
>  	char *line = NULL;
> @@ -306,7 +306,7 @@ read_debugfs_record(const char *file, const char *key)
>  	int key_len = strlen(key);
>  	char *value = NULL;
>
> -	fp = igt_debugfs_fopen(file, "r");
> +	fp = igt_debugfs_fopen(fd, file, "r");
>  	igt_require(fp);
>
>  	while ((len = getline(&line, &line_buf_size, fp)) > 0) {
> @@ -332,9 +332,9 @@ done:
>  }
>
>  static uint64_t
> -read_debugfs_u64_record(const char *file, const char *key)
> +read_debugfs_u64_record(int fd, const char *file, const char *key)
>  {
> -	char *str_val = read_debugfs_record(file, key);
> +	char *str_val = read_debugfs_record(fd, file, key);
>  	uint64_t val;
>
>  	igt_require(str_val);
> @@ -2137,25 +2137,25 @@ test_rc6_disable(void)
>  		.properties_ptr = to_user_pointer(properties),
>  	};
>  	int stream_fd = __perf_open(drm_fd, &param);
> -	uint64_t n_events_start = read_debugfs_u64_record("i915_drpc_info",
> + uint64_t n_events_start = read_debugfs_u64_record(drm_fd, "i915_drpc_info",
>  							  "RC6 residency since boot");
>  	uint64_t n_events_end;
>
> nanosleep(&(struct timespec){ .tv_sec = 0, .tv_nsec = 500000000 }, NULL);
>
> -	n_events_end = read_debugfs_u64_record("i915_drpc_info",
> +	n_events_end = read_debugfs_u64_record(drm_fd, "i915_drpc_info",
>  					       "RC6 residency since boot");
>
>  	igt_assert_eq(n_events_end - n_events_start, 0);
>
>  	close(stream_fd);
>
> -	n_events_start = read_debugfs_u64_record("i915_drpc_info",
> +	n_events_start = read_debugfs_u64_record(drm_fd, "i915_drpc_info",
>  						 "RC6 residency since boot");
>
> nanosleep(&(struct timespec){ .tv_sec = 0, .tv_nsec = 500000000 }, NULL);
>
> -	n_events_end = read_debugfs_u64_record("i915_drpc_info",
> +	n_events_end = read_debugfs_u64_record(drm_fd, "i915_drpc_info",
>  					       "RC6 residency since boot");
>
>  	igt_assert_neq(n_events_end - n_events_start, 0);
> diff --git a/tests/pm_lpsp.c b/tests/pm_lpsp.c
> index bfe5828893d6..a741cb78b007 100644
> --- a/tests/pm_lpsp.c
> +++ b/tests/pm_lpsp.c
> @@ -209,7 +209,7 @@ igt_main
>
>  		igt_require(supports_lpsp(devid));
>
> -		intel_register_access_init(intel_get_pci_device(), 0);
> +		intel_register_access_init(intel_get_pci_device(), 0, drm_fd);
>
>  		kmstest_set_vt_graphics_mode();
>  	}
> diff --git a/tests/pm_rpm.c b/tests/pm_rpm.c
> index d0600d59dd6b..e5475c911a2f 100644
> --- a/tests/pm_rpm.c
> +++ b/tests/pm_rpm.c
> @@ -657,9 +657,9 @@ static void setup_pc8(void)
>  	if (!supports_pc8_plus_residencies())
>  		return;
>
> -	pc8_status_fd = igt_debugfs_open("i915_pc8_status", O_RDONLY);
> +	pc8_status_fd = igt_debugfs_open(drm_fd, "i915_pc8_status", O_RDONLY);
>  	if (pc8_status_fd == -1)
> -		pc8_status_fd = igt_debugfs_open("i915_runtime_pm_status",
> +		pc8_status_fd = igt_debugfs_open(drm_fd, "i915_runtime_pm_status",
>  						 O_RDONLY);
>  	igt_assert_f(pc8_status_fd >= 0,
>  		     "Can't open /sys/kernel/debug/dri/0/i915_runtime_pm_status");
> @@ -919,7 +919,7 @@ static void debugfs_forcewake_user_subtest(void)
>
>  	disable_all_screens_and_wait(&ms_data);
>
> -	fd = igt_open_forcewake_handle();
> +	fd = igt_open_forcewake_handle(drm_fd);
>  	igt_require(fd >= 0);
>
>  	if (has_runtime_pm) {
> diff --git a/tests/pm_sseu.c b/tests/pm_sseu.c
> index 3e60a5f86a7b..317bb261ee74 100644
> --- a/tests/pm_sseu.c
> +++ b/tests/pm_sseu.c
> @@ -35,6 +35,19 @@
>
> IGT_TEST_DESCRIPTION("Tests slice/subslice/EU power gating functionality.\n");
>
> +struct {
> +	int init;
> +	int drm_fd;
> +	int devid;
> +	int gen;
> +	int has_ppgtt;
> +	drm_intel_bufmgr *bufmgr;
> +	struct intel_batchbuffer *batch;
> +	igt_media_spinfunc_t spinfunc;
> +	struct igt_buf buf;
> +	uint32_t spins_per_msec;
> +} gem;
> +
>  static double
>  to_dt(const struct timespec *start, const struct timespec *end)
>  {
> @@ -174,7 +187,7 @@ dbg_get_status(struct status *stat)
>  static void
>  dbg_init(void)
>  {
> -	dbg.status_fd = igt_debugfs_open("i915_sseu_status", O_RDONLY);
> + dbg.status_fd = igt_debugfs_open(gem.drm_fd, "i915_sseu_status", O_RDONLY);
>  	igt_skip_on_f(dbg.status_fd == -1,
>  		      "debugfs entry 'i915_sseu_status' not found\n");
>  	dbg.init = 1;
> @@ -190,19 +203,6 @@ dbg_deinit(void)
>  	}
>  }
>
> -struct {
> -	int init;
> -	int drm_fd;
> -	int devid;
> -	int gen;
> -	int has_ppgtt;
> -	drm_intel_bufmgr *bufmgr;
> -	struct intel_batchbuffer *batch;
> -	igt_media_spinfunc_t spinfunc;
> -	struct igt_buf buf;
> -	uint32_t spins_per_msec;
> -} gem;
> -
>  static void
>  gem_check_spin(uint32_t spins)
>  {
> diff --git a/tests/prime_mmap_kms.c b/tests/prime_mmap_kms.c
> index e7cca54c8029..faace4afd478 100644
> --- a/tests/prime_mmap_kms.c
> +++ b/tests/prime_mmap_kms.c
> @@ -246,7 +246,7 @@ igt_main
>  		igt_skip_on((check_for_dma_buf_mmap(gpu.drm_fd) != 0));
>  		kmstest_set_vt_graphics_mode();
>
> -		igt_require_pipe_crc();
> +		igt_require_pipe_crc(gpu.drm_fd);
>
>  		igt_display_init(&gpu.display, gpu.drm_fd);
>  	}
> diff --git a/tools/intel_display_crc.c b/tools/intel_display_crc.c
> index ba9ec5baeb79..d1b28ea77371 100644
> --- a/tools/intel_display_crc.c
> +++ b/tools/intel_display_crc.c
> @@ -67,7 +67,7 @@ static void print_crcs(display_crc_t *ctx)
>  	char *crc_str;
>  	int i;
>
> -	pipe_crc = igt_pipe_crc_new(ctx->pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
> + pipe_crc = igt_pipe_crc_new(ctx->fd, ctx->pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
>
>  	for (i = 0; i < ctx->n_crcs; i++) {
>  		igt_pipe_crc_collect_crc(pipe_crc, &crc);
> diff --git a/tools/intel_display_poller.c b/tools/intel_display_poller.c
> index 63c930fb08a0..c501c79d6367 100644
> --- a/tools/intel_display_poller.c
> +++ b/tools/intel_display_poller.c
> @@ -965,6 +965,7 @@ int main(int argc, char *argv[])
>  	int pipe = 0, bit = 0, target_scanline = 0, target_fuzz = 1;
>  	bool test_pixelcount = false;
>  	uint32_t devid;
> +	int drm_fd;
>  	uint32_t min[2*128] = {};
>  	uint32_t max[2*128] = {};
>  	uint32_t a, b;
> @@ -1186,7 +1187,10 @@ int main(int argc, char *argv[])
>  		break;
>  	}
>
> -	intel_register_access_init(intel_get_pci_device(), 0);
> +	/* Just to make sure we open the right debugfs files */
> +	drm_fd = drm_open_driver_master(DRIVER_INTEL);
> +
> +	intel_register_access_init(intel_get_pci_device(), 0, drm_fd);
>
>  	printf("%s?\n", test_name(test, pipe, bit, test_pixelcount));
>
> @@ -1263,6 +1267,8 @@ int main(int argc, char *argv[])
>
>  	intel_register_access_fini();
>
> +	close(drm_fd);
> +
>  	if (quit)
>  		return 0;
>
> diff --git a/tools/intel_dp_compliance.c b/tools/intel_dp_compliance.c
> index 1b2c1d38490d..4b4d255daf16 100644
> --- a/tools/intel_dp_compliance.c
> +++ b/tools/intel_dp_compliance.c
> @@ -229,13 +229,13 @@ static void clear_test_active(void)
>
>  static void setup_debugfs_files(void)
>  {
> -	test_type_fp = igt_debugfs_fopen(INTEL_DP_TEST_TYPE_FILE, "r");
> +	test_type_fp = igt_debugfs_fopen(drm_fd, INTEL_DP_TEST_TYPE_FILE, "r");
>  	igt_require(test_type_fp);
>
> -	test_data_fp = igt_debugfs_fopen(INTEL_DP_TEST_DATA_FILE, "r");
> +	test_data_fp = igt_debugfs_fopen(drm_fd, INTEL_DP_TEST_DATA_FILE, "r");
>  	igt_require(test_data_fp);
>
> -	test_active_fp = igt_debugfs_fopen(INTEL_DP_TEST_ACTIVE_FILE, "w+");
> + test_active_fp = igt_debugfs_fopen(drm_fd, INTEL_DP_TEST_ACTIVE_FILE, "w+");
>  	igt_require(test_active_fp);
>
>  	/* Reset the active flag for safety */
> diff --git a/tools/intel_forcewaked.c b/tools/intel_forcewaked.c
> index 01ca02530d10..aa8e3f8b1cf4 100644
> --- a/tools/intel_forcewaked.c
> +++ b/tools/intel_forcewaked.c
> @@ -36,6 +36,7 @@
>  #include <unistd.h>
>  #include "intel_io.h"
>  #include "intel_chipset.h"
> +#include "drmtest.h"
>
>  bool daemonized;
>
> @@ -63,6 +64,7 @@ is_alive(void) {
>
>  int main(int argc, char *argv[])
>  {
> +	int drm_fd;
>  	int ret;
>
>  	if (argc > 2 || (argc == 2 && !strncmp(argv[1], "-h", 2))) {
> @@ -79,7 +81,10 @@ int main(int argc, char *argv[])
>  		INFO_PRINT("started daemon");
>  	}
>
> -	ret = intel_register_access_init(intel_get_pci_device(), 1);
> +	/* Just to make sure we open the right debugfs files */
> +	drm_fd = drm_open_driver_master(DRIVER_INTEL);
> +
> +	ret = intel_register_access_init(intel_get_pci_device(), 1, drm_fd);
>  	if (ret) {
>  		INFO_PRINT("Couldn't init register access\n");
>  		exit(1);
> @@ -90,13 +95,14 @@ int main(int argc, char *argv[])
>  		if (!is_alive()) {
>  			INFO_PRINT("gpu reset? restarting daemon\n");
>  			intel_register_access_fini();
> -			ret = intel_register_access_init(intel_get_pci_device(), 1);
> +			ret = intel_register_access_init(intel_get_pci_device(), 1, drm_fd);
>  			if (ret)
>  				INFO_PRINT("Reg access init fail\n");
>  		}
>  		sleep(1);
>  	}
>  	intel_register_access_fini();
> +	close(drm_fd);
>  	INFO_PRINT("Forcewake unlock\n");
>
>  	if (daemonized) {
> diff --git a/tools/intel_gpu_top.c b/tools/intel_gpu_top.c
> index 4f327c6daf6b..7848876476b6 100644
> --- a/tools/intel_gpu_top.c
> +++ b/tools/intel_gpu_top.c
> @@ -46,6 +46,7 @@
>  #include "instdone.h"
>  #include "intel_reg.h"
>  #include "intel_chipset.h"
> +#include "drmtest.h"
>
>  #define  FORCEWAKE	    0xA18C
>  #define  FORCEWAKE_ACK	    0x130090
> @@ -410,6 +411,7 @@ usage(const char *appname)
>  int main(int argc, char **argv)
>  {
>  	uint32_t devid;
> +	int drm_fd;
>  	struct pci_device *pci_dev;
>  	struct ring render_ring = {
>  		.name = "render",
> @@ -510,8 +512,11 @@ int main(int argc, char **argv)
>  		top_bits_sorted[i] = &top_bits[i];
>  	}
>
> +	/* Just to make sure we open the right debugfs files */
> +	drm_fd = drm_open_driver_master(DRIVER_INTEL);
> +
>  	/* Grab access to the registers */
> -	intel_register_access_init(pci_dev, 0);
> +	intel_register_access_init(pci_dev, 0, drm_fd);
>
>  	ring_init(&render_ring);
>  	if (IS_GEN4(devid) || IS_GEN5(devid))
> @@ -714,5 +719,6 @@ int main(int argc, char **argv)
>  	fclose(output);
>
>  	intel_register_access_fini();
> +	close(drm_fd);
>  	return 0;
>  }
> diff --git a/tools/intel_guc_logger.c b/tools/intel_guc_logger.c
> index c9ea60d054bb..3079878e1191 100644
> --- a/tools/intel_guc_logger.c
> +++ b/tools/intel_guc_logger.c
> @@ -47,7 +47,7 @@ int verbosity_level = 3; /* by default capture logs at max verbosity */
>  uint32_t produced, consumed;
>  uint64_t total_bytes_written;
>  int num_buffers = NUM_SUBBUFS;
> -int relay_fd, outfile_fd = -1;
> +int relay_fd, drm_fd, outfile_fd = -1;
>  uint32_t test_duration, max_filesize;
>  pthread_cond_t underflow_cond, overflow_cond;
>  bool stop_logging, discard_oldlogs, capturing_stopped;
> @@ -59,7 +59,7 @@ static void guc_log_control(bool enable_logging)
>  	uint64_t val;
>  	int ret;
>
> -	control_fd = igt_debugfs_open(CONTROL_FILE_NAME, O_WRONLY);
> +	control_fd = igt_debugfs_open(drm_fd, CONTROL_FILE_NAME, O_WRONLY);
> igt_assert_f(control_fd >= 0, "couldn't open the guc log control file\n");
>
>  	val = enable_logging ? ((verbosity_level << 4) | 0x1) : 0;
> @@ -228,7 +228,7 @@ static void init_flusher_thread(void)
>
>  static void open_relay_file(void)
>  {
> -	relay_fd = igt_debugfs_open(RELAY_FILE_NAME, O_RDONLY);
> +	relay_fd = igt_debugfs_open(drm_fd, RELAY_FILE_NAME, O_RDONLY);
>  	igt_assert_f(relay_fd >= 0, "couldn't open the guc log file\n");
>
>  	/* Purge the old/boot-time logs from the relay buffer.
> @@ -374,6 +374,9 @@ int main(int argc, char **argv)
>
>  	process_command_line(argc, argv);
>
> +	/* Just to make sure we open the right debugfs files */
> +	drm_fd = drm_open_driver_master(DRIVER_INTEL);
> +
>  	init_main_thread();
>
>  	/* Use a separate thread for flushing the logs to a file on disk.
> @@ -434,5 +437,6 @@ int main(int argc, char **argv)
>  	free(read_buffer);
>  	close(relay_fd);
>  	close(outfile_fd);
> +	close(drm_fd);
>  	igt_exit();
>  }
> diff --git a/tools/intel_infoframes.c b/tools/intel_infoframes.c
> index e03cb2c06a52..813430c985e7 100644
> --- a/tools/intel_infoframes.c
> +++ b/tools/intel_infoframes.c
> @@ -1081,6 +1081,7 @@ printf("Options:\n"
>  int main(int argc, char *argv[])
>  {
>  	int opt;
> +	int drm_fd;
>  	int ret = 0;
>  	Transcoder transcoder = TRANSC_INVALID;
>  	DipType dip = DIP_INVALID;
> @@ -1107,8 +1108,11 @@ int main(int argc, char *argv[])
> printf("WARNING: This is just a debugging tool! Don't expect it to work"
>  	       " perfectly: the Kernel might undo our changes.\n");
>
> +	/* Just to make sure we open the right debugfs files */
> +	drm_fd = drm_open_driver_master(DRIVER_INTEL);
> +
>  	pci_dev = intel_get_pci_device();
> -	intel_register_access_init(pci_dev, 0);
> +	intel_register_access_init(pci_dev, 0, drm_fd);
>  	intel_check_pch();
>
>  	if (IS_GEN4(pci_dev->device_id))
> @@ -1257,5 +1261,6 @@ int main(int argc, char *argv[])
>
>  out:
>  	intel_register_access_fini();
> +	close(drm_fd);
>  	return ret;
>  }
> diff --git a/tools/intel_l3_parity.c b/tools/intel_l3_parity.c
> index 8692bef870b7..dce7f3207051 100644
> --- a/tools/intel_l3_parity.c
> +++ b/tools/intel_l3_parity.c
> @@ -194,7 +194,7 @@ int main(int argc, char *argv[])
>  	if (intel_gen(devid) < 7 || IS_VALLEYVIEW(devid))
>  		exit(77);
>
> -	assert(intel_register_access_init(intel_get_pci_device(), 0) == 0);
> + assert(intel_register_access_init(intel_get_pci_device(), 0, device) == 0);
>
>  	dir = igt_sysfs_open(device, NULL);
>
> diff --git a/tools/intel_panel_fitter.c b/tools/intel_panel_fitter.c
> index 5519361e6c8c..48b2fd891497 100644
> --- a/tools/intel_panel_fitter.c
> +++ b/tools/intel_panel_fitter.c
> @@ -33,6 +33,7 @@
>  #include "intel_io.h"
>  #include "intel_chipset.h"
>  #include "intel_reg.h"
> +#include "drmtest.h"
>
>  int gen;
>
> @@ -265,7 +266,7 @@ static void print_usage(void)
>
>  int main (int argc, char *argv[])
>  {
> -	int opt;
> +	int opt, drm_fd;
>  	int ret = 0;
>  	char intel_pipe = '\0';
>  	int x = 0, y = 0;
> @@ -278,8 +279,11 @@ int main (int argc, char *argv[])
>  	       "with overscan compensation properties: it is just a temporary "
> "solution that may or may not work. Use it at your own risk.\n");
>
> +	/* Just to make sure we open the right debugfs files */
> +	drm_fd = drm_open_driver_master(DRIVER_INTEL);
> +
>  	pci_dev = intel_get_pci_device();
> -	intel_register_access_init(pci_dev, 0);
> +	intel_register_access_init(pci_dev, 0, drm_fd);
>  	devid = pci_dev->device_id;
>
>  	if (!HAS_PCH_SPLIT(devid)) {
> @@ -342,5 +346,6 @@ int main (int argc, char *argv[])
>
>  out:
>  	intel_register_access_fini();
> +	close(drm_fd);
>  	return ret;
>  }
> diff --git a/tools/intel_perf_counters.c b/tools/intel_perf_counters.c
> index 04a6aba97808..50c4bce61ff7 100644
> --- a/tools/intel_perf_counters.c
> +++ b/tools/intel_perf_counters.c
> @@ -483,7 +483,7 @@ main(int argc, char **argv)
>
>  	if (oacontrol) {
>  		/* Forcewake */
> -		intel_register_access_init(intel_get_pci_device(), 0);
> +		intel_register_access_init(intel_get_pci_device(), 0, fd);
>
>  		/* Enable performance counters */
>  		intel_register_write(OACONTROL,
> diff --git a/tools/intel_reg.c b/tools/intel_reg.c
> index 01a3671e97dd..7b58d0b869f8 100644
> --- a/tools/intel_reg.c
> +++ b/tools/intel_reg.c
> @@ -32,6 +32,7 @@
>  #include <sys/types.h>
>  #include <unistd.h>
>
> +#include "igt.h"
>  #include "intel_io.h"
>  #include "intel_chipset.h"
>
> @@ -57,6 +58,7 @@ struct config {
>  	struct pci_device *pci_dev;
>  	char *mmiofile;
>  	uint32_t devid;
> +	int drm_fd;
>
>  	/* read: number of registers to read */
>  	uint32_t count;
> @@ -409,7 +411,7 @@ static int intel_reg_read(struct config *config, int argc, char *argv[])
>  	if (config->mmiofile)
>  		intel_mmio_use_dump_file(config->mmiofile);
>  	else
> -		intel_register_access_init(config->pci_dev, 0);
> +		intel_register_access_init(config->pci_dev, 0, config->drm_fd);
>
>  	for (i = 1; i < argc; i++) {
>  		struct reg reg;
> @@ -439,7 +441,7 @@ static int intel_reg_write(struct config *config, int argc, char *argv[])
>  		return EXIT_FAILURE;
>  	}
>
> -	intel_register_access_init(config->pci_dev, 0);
> +	intel_register_access_init(config->pci_dev, 0, config->drm_fd);
>
>  	for (i = 1; i < argc; i += 2) {
>  		struct reg reg;
> @@ -477,7 +479,7 @@ static int intel_reg_dump(struct config *config, int argc, char *argv[])
>  	if (config->mmiofile)
>  		intel_mmio_use_dump_file(config->mmiofile);
>  	else
> -		intel_register_access_init(config->pci_dev, 0);
> +		intel_register_access_init(config->pci_dev, 0, config->drm_fd);
>
>  	for (i = 0; i < config->regcount; i++) {
>  		reg = &config->regs[i];
> @@ -877,6 +879,9 @@ int main(int argc, char *argv[])
>  		config.devid = config.pci_dev->device_id;
>  	}
>
> +	/* Just to make sure we open the right debugfs files */
> +	config.drm_fd = drm_open_driver_master(DRIVER_INTEL);
> +
>  	if (read_reg_spec(&config) < 0) {
>  		return EXIT_FAILURE;
>  	}
> @@ -895,6 +900,7 @@ int main(int argc, char *argv[])
>
>  	ret = command->function(&config, argc, argv);
>
> +	close(config.drm_fd);
>  	free(config.mmiofile);
>
>  	return ret;
> diff --git a/tools/intel_watermark.c b/tools/intel_watermark.c
> index e9a2b057b821..d98ef19b0abd 100644
> --- a/tools/intel_watermark.c
> +++ b/tools/intel_watermark.c
> @@ -30,11 +30,11 @@
>  #include <string.h>
>  #include "intel_io.h"
>  #include "intel_chipset.h"
> +#include "drmtest.h"
>
>  static uint32_t display_base;
>  static uint32_t devid;
> -
> -#define ARRAY_SIZE(a) (sizeof(a)/sizeof((a)[0]))

Nit: Maybe this should be a seperate commit.

> +static int drm_fd;
>
>  static uint32_t read_reg(uint32_t addr)
>  {
> @@ -143,7 +143,7 @@ static void ilk_wm_dump(void)
>  	int num_pipes = is_gen7_plus(devid) ? 3 : 2;
>  	struct ilk_wm wm = {};
>
> -	intel_register_access_init(intel_get_pci_device(), 0);
> +	intel_register_access_init(intel_get_pci_device(), 0, drm_fd);
>
>  	for (i = 0; i < num_pipes; i++) {
>  		dspcntr[i] = read_reg(0x70180 + i * 0x1000);
> @@ -291,7 +291,7 @@ static void vlv_wm_dump(void)
>  	uint32_t dsp_ss_pm, ddr_setup2;
>  	struct gmch_wm wms[MAX_PLANE] = {};
>
> -	intel_register_access_init(intel_get_pci_device(), 0);
> +	intel_register_access_init(intel_get_pci_device(), 0, drm_fd);
>
>  	dsparb = read_reg(0x70030);
>  	dsparb2 = read_reg(0x70060);
> @@ -507,7 +507,7 @@ static void g4x_wm_dump(void)
>  	uint32_t mi_arb_state;
>  	struct gmch_wm wms[MAX_PLANE] = {};
>
> -	intel_register_access_init(intel_get_pci_device(), 0);
> +	intel_register_access_init(intel_get_pci_device(), 0, drm_fd);
>
>  	dspacntr = read_reg(0x70180);
>  	dspbcntr = read_reg(0x71180);
> @@ -593,7 +593,7 @@ static void gen4_wm_dump(void)
>  	uint32_t mi_arb_state;
>  	struct gmch_wm wms[MAX_PLANE] = {};
>
> -	intel_register_access_init(intel_get_pci_device(), 0);
> +	intel_register_access_init(intel_get_pci_device(), 0, drm_fd);
>
>  	dsparb = read_reg(0x70030);
>  	fw1 = read_reg(0x70034);
> @@ -664,7 +664,7 @@ static void pnv_wm_dump(void)
>  	uint32_t cbr;
>  	struct gmch_wm wms[MAX_PLANE] = {};
>
> -	intel_register_access_init(intel_get_pci_device(), 0);
> +	intel_register_access_init(intel_get_pci_device(), 0, drm_fd);
>
>  	dsparb = read_reg(0x70030);
>  	fw1 = read_reg(0x70034);
> @@ -754,7 +754,7 @@ static void gen3_wm_dump(void)
>  	uint32_t mi_arb_state;
>  	struct gmch_wm wms[MAX_PLANE] = {};
>
> -	intel_register_access_init(intel_get_pci_device(), 0);
> +	intel_register_access_init(intel_get_pci_device(), 0, drm_fd);
>
>  	dsparb = read_reg(0x70030);
>  	instpm = read_reg(0x20c0);
> @@ -823,7 +823,7 @@ static void gen2_wm_dump(void)
>  	uint32_t mi_state;
>  	struct gmch_wm wms[MAX_PLANE] = {};
>
> -	intel_register_access_init(intel_get_pci_device(), 0);
> +	intel_register_access_init(intel_get_pci_device(), 0, drm_fd);
>
>  	dsparb = read_reg(0x70030);
>  	mem_mode = read_reg(0x20cc);
> @@ -900,6 +900,9 @@ int main(int argc, char *argv[])
>  {
>  	devid = intel_get_pci_device()->device_id;
>
> +	/* Just to make sure we open the right debugfs files */
> +	drm_fd = drm_open_driver_master(DRIVER_INTEL);
> +
>  	if (IS_VALLEYVIEW(devid) || IS_CHERRYVIEW(devid)) {
>  		display_base = 0x180000;
>  		vlv_wm_dump();
> @@ -920,5 +923,7 @@ int main(int argc, char *argv[])
>  		return 1;
>  	}
>
> +	close(drm_fd);
> +
>  	return 0;
>  }
>
_______________________________________________
Intel-gfx mailing list
Intel-gfx@xxxxxxxxxxxxxxxxxxxxx
https://lists.freedesktop.org/mailman/listinfo/intel-gfx




[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]
  Powered by Linux