mirror of
https://github.com/tiagovignatti/intel-gpu-tools.git
synced 2025-06-08 16:36:14 +00:00
lib/ioctl_wrappers: Add gem_has_softpin
We can move it from softpin test into lib, and since softpin support is highly unlikely to go away in-between getparam ioctl calls, let's just do a single call and store the value. v2: rebase Signed-off-by: Michał Winiarski <michal.winiarski@intel.com> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
parent
52b5d5016e
commit
e6ca4bd7cd
@ -1242,6 +1242,35 @@ uint64_t gem_mappable_aperture_size(void)
|
|||||||
return pci_dev->regions[bar].size;
|
return pci_dev->regions[bar].size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define LOCAL_I915_PARAM_HAS_EXEC_SOFTPIN 37
|
||||||
|
/**
|
||||||
|
* gem_has_softpin:
|
||||||
|
* @fd: open i915 drm file descriptor
|
||||||
|
*
|
||||||
|
* Feature test macro to query whether the softpinning functionality is
|
||||||
|
* supported.
|
||||||
|
*
|
||||||
|
* Returns: Whether softpin support is available
|
||||||
|
*/
|
||||||
|
bool gem_has_softpin(int fd)
|
||||||
|
{
|
||||||
|
static int has_softpin = -1;
|
||||||
|
|
||||||
|
if (has_softpin < 0) {
|
||||||
|
struct drm_i915_getparam gp;
|
||||||
|
|
||||||
|
memset(&gp, 0, sizeof(gp));
|
||||||
|
gp.param = LOCAL_I915_PARAM_HAS_EXEC_SOFTPIN;
|
||||||
|
gp.value = &has_softpin;
|
||||||
|
|
||||||
|
has_softpin = 0;
|
||||||
|
ioctl(fd, DRM_IOCTL_I915_GETPARAM, &gp, sizeof(gp));
|
||||||
|
errno = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return has_softpin;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* gem_require_caching:
|
* gem_require_caching:
|
||||||
* @fd: open i915 drm file descriptor
|
* @fd: open i915 drm file descriptor
|
||||||
|
@ -132,6 +132,7 @@ int gem_available_fences(int fd);
|
|||||||
uint64_t gem_available_aperture_size(int fd);
|
uint64_t gem_available_aperture_size(int fd);
|
||||||
uint64_t gem_aperture_size(int fd);
|
uint64_t gem_aperture_size(int fd);
|
||||||
uint64_t gem_mappable_aperture_size(void);
|
uint64_t gem_mappable_aperture_size(void);
|
||||||
|
bool gem_has_softpin(int fd);
|
||||||
|
|
||||||
/* check functions which auto-skip tests by calling igt_skip() */
|
/* check functions which auto-skip tests by calling igt_skip() */
|
||||||
void gem_require_caching(int fd);
|
void gem_require_caching(int fd);
|
||||||
|
@ -31,26 +31,6 @@
|
|||||||
#define EXEC_OBJECT_PINNED (1<<4)
|
#define EXEC_OBJECT_PINNED (1<<4)
|
||||||
#define EXEC_OBJECT_SUPPORTS_48B_ADDRESS (1<<3)
|
#define EXEC_OBJECT_SUPPORTS_48B_ADDRESS (1<<3)
|
||||||
|
|
||||||
/* has_softpin_support
|
|
||||||
* Finds if softpin feature is supported
|
|
||||||
* @fd DRM fd
|
|
||||||
*/
|
|
||||||
static bool has_softpin_support(int fd)
|
|
||||||
{
|
|
||||||
struct drm_i915_getparam gp;
|
|
||||||
int val = 0;
|
|
||||||
|
|
||||||
memset(&gp, 0, sizeof(gp));
|
|
||||||
gp.param = 37; /* I915_PARAM_HAS_EXEC_SOFTPIN */
|
|
||||||
gp.value = &val;
|
|
||||||
|
|
||||||
if (drmIoctl(fd, DRM_IOCTL_I915_GETPARAM, &gp))
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
errno = 0;
|
|
||||||
return (val == 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* gen8_canonical_addr
|
/* gen8_canonical_addr
|
||||||
* Used to convert any address into canonical form, i.e. [63:48] == [47].
|
* Used to convert any address into canonical form, i.e. [63:48] == [47].
|
||||||
* Based on kernel's sign_extend64 implementation.
|
* Based on kernel's sign_extend64 implementation.
|
||||||
@ -494,7 +474,7 @@ igt_main
|
|||||||
|
|
||||||
igt_fixture {
|
igt_fixture {
|
||||||
fd = drm_open_driver_master(DRIVER_INTEL);
|
fd = drm_open_driver_master(DRIVER_INTEL);
|
||||||
igt_require(has_softpin_support(fd));
|
igt_require(gem_has_softpin(fd));
|
||||||
}
|
}
|
||||||
|
|
||||||
igt_subtest("invalid")
|
igt_subtest("invalid")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user