[igt-dev] [i-g-t 2/6] lib: Cache xe_device at driver open/close level
Zbigniew Kempczyński
zbigniew.kempczynski at intel.com
Thu May 11 05:30:06 UTC 2023
On Thu, May 04, 2023 at 10:27:22AM +0530, Bhanuprakash Modem wrote:
> Instead of caching the xe_device struct at subtest level, cache
> just after opening the driver. And remove from the cache just
> before closing the driver.
>
> Signed-off-by: Bhanuprakash Modem <bhanuprakash.modem at intel.com>
> ---
> lib/drmtest.c | 9 +++++++++
> 1 file changed, 9 insertions(+)
>
> diff --git a/lib/drmtest.c b/lib/drmtest.c
> index 03b5239b2..f6cd8e500 100644
> --- a/lib/drmtest.c
> +++ b/lib/drmtest.c
> @@ -63,6 +63,7 @@
> #include "intel_reg.h"
> #include "ioctl_wrappers.h"
> #include "igt_dummyload.h"
> +#include "xe/xe_query.h"
>
> /**
> * SECTION:drmtest
> @@ -601,6 +602,10 @@ int drm_open_driver(int chipset)
> }
> }
>
> + /* Cache xe_device struct. */
> + if (is_xe_device(fd))
> + xe_device_get(fd);
> +
> return fd;
> }
>
Imo this should land to __drm_open_driver_another() and
__drm_open_driver_render().
gem_reopen_driver() still requires explicit device get for xe.
--
Zbigniew
> @@ -618,6 +623,10 @@ int drm_close_driver(int fd)
> if (fd < 3)
> return -1;
>
> + /* Remove xe_device from cache. */
> + if (is_xe_device(fd))
> + xe_device_put(fd);
> +
> return close(fd);
> }
>
> --
> 2.40.0
>
More information about the igt-dev
mailing list