summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndi Shyti <andi.shyti@intel.com>2019-04-03 18:48:23 +0300
committerAndi Shyti <andi.shyti@intel.com>2019-05-13 16:27:28 +0300
commitc50504c58f8ba75a31dd24570efe9775f546fd18 (patch)
tree9689b4766960f674f7af676dabdd9ba08b0cf6d2
parent590ab531f8af445e45dc102c857dae0789491c46 (diff)
lib: igt_gt: add execution buffer flags to class helper
we have a "class/instance to eb flags" helper but not the opposite, add it. Suggested-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Signed-off-by: Andi Shyti <andi.shyti@intel.com> Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
-rw-r--r--lib/igt_gt.c18
-rw-r--r--lib/igt_gt.h2
2 files changed, 20 insertions, 0 deletions
diff --git a/lib/igt_gt.c b/lib/igt_gt.c
index a2eaadf5..59b62242 100644
--- a/lib/igt_gt.c
+++ b/lib/igt_gt.c
@@ -41,6 +41,7 @@
#include "intel_reg.h"
#include "intel_chipset.h"
#include "igt_dummyload.h"
+#include "i915/gem_engine_topology.h"
/**
* SECTION:igt_gt
@@ -586,6 +587,23 @@ const struct intel_execution_engine2 intel_execution_engines2[] = {
{ }
};
+int gem_execbuf_flags_to_engine_class(unsigned int flags)
+{
+ switch (flags & 0x3f) {
+ case I915_EXEC_DEFAULT:
+ case I915_EXEC_RENDER:
+ return I915_ENGINE_CLASS_RENDER;
+ case I915_EXEC_BLT:
+ return I915_ENGINE_CLASS_COPY;
+ case I915_EXEC_BSD:
+ return I915_ENGINE_CLASS_VIDEO;
+ case I915_EXEC_VEBOX:
+ return I915_ENGINE_CLASS_VIDEO_ENHANCE;
+ default:
+ igt_assert(0);
+ }
+}
+
unsigned int
gem_class_instance_to_eb_flags(int gem_fd,
enum drm_i915_gem_engine_class class,
diff --git a/lib/igt_gt.h b/lib/igt_gt.h
index 52b2f1ea..8ceed142 100644
--- a/lib/igt_gt.h
+++ b/lib/igt_gt.h
@@ -99,6 +99,8 @@ extern const struct intel_execution_engine2 {
bool is_virtual;
} intel_execution_engines2[];
+int gem_execbuf_flags_to_engine_class(unsigned int flags);
+
unsigned int
gem_class_instance_to_eb_flags(int gem_fd,
enum drm_i915_gem_engine_class class,