Commit 78e1fb31 authored by Rodrigo Vivi's avatar Rodrigo Vivi Committed by John Harrison

drm/i915/uapi: Add query for hwconfig blob

In this interface i915 is returning a blob of data which it receives
from the guc software. This blob provides some useful data about the
hardware for drivers. The format of this blob will be documented in
the Programmer Reference Manuals when released.

Cc: Tvrtko Ursulin <tvrtko.ursulin@linux.intel.com>
Cc: Kenneth Graunke <kenneth.w.graunke@intel.com>
Cc: Michal Wajdeczko <michal.wajdeczko@intel.com>
Cc: Slawomir Milczarek <slawomir.milczarek@intel.com>
Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Signed-off-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
Signed-off-by: default avatarJohn Harrison <John.C.Harrison@Intel.com>
Reviewed-by: default avatarMatthew Brost <matthew.brost@intel.com>
Acked-by: default avatarJordan Justen <jordan.l.justen@intel.com>
Tested-by: default avatarJordan Justen <jordan.l.justen@intel.com>
Acked-by: default avatarJon Bloomfield <jon.bloomfield@intel.com>
Signed-off-by: default avatarJohn Harrison <John.C.Harrison@Intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220306232157.1174335-3-jordan.l.justen@intel.com
parent 8781f051
...@@ -479,12 +479,35 @@ static int query_memregion_info(struct drm_i915_private *i915, ...@@ -479,12 +479,35 @@ static int query_memregion_info(struct drm_i915_private *i915,
return total_length; return total_length;
} }
static int query_hwconfig_blob(struct drm_i915_private *i915,
struct drm_i915_query_item *query_item)
{
struct intel_gt *gt = to_gt(i915);
struct intel_hwconfig *hwconfig = &gt->info.hwconfig;
if (!hwconfig->size || !hwconfig->ptr)
return -ENODEV;
if (query_item->length == 0)
return hwconfig->size;
if (query_item->length < hwconfig->size)
return -EINVAL;
if (copy_to_user(u64_to_user_ptr(query_item->data_ptr),
hwconfig->ptr, hwconfig->size))
return -EFAULT;
return hwconfig->size;
}
static int (* const i915_query_funcs[])(struct drm_i915_private *dev_priv, static int (* const i915_query_funcs[])(struct drm_i915_private *dev_priv,
struct drm_i915_query_item *query_item) = { struct drm_i915_query_item *query_item) = {
query_topology_info, query_topology_info,
query_engine_info, query_engine_info,
query_perf_config, query_perf_config,
query_memregion_info, query_memregion_info,
query_hwconfig_blob,
}; };
int i915_query_ioctl(struct drm_device *dev, void *data, struct drm_file *file) int i915_query_ioctl(struct drm_device *dev, void *data, struct drm_file *file)
......
...@@ -2691,6 +2691,7 @@ struct drm_i915_query_item { ...@@ -2691,6 +2691,7 @@ struct drm_i915_query_item {
#define DRM_I915_QUERY_ENGINE_INFO 2 #define DRM_I915_QUERY_ENGINE_INFO 2
#define DRM_I915_QUERY_PERF_CONFIG 3 #define DRM_I915_QUERY_PERF_CONFIG 3
#define DRM_I915_QUERY_MEMORY_REGIONS 4 #define DRM_I915_QUERY_MEMORY_REGIONS 4
#define DRM_I915_QUERY_HWCONFIG_BLOB 5
/* Must be kept compact -- no holes and well documented */ /* Must be kept compact -- no holes and well documented */
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment