[igt-dev] [PATCH v18 3/6] lib: igt_gt: add eb flags to class helper
Andi Shyti
andi at etezian.org
Sun Apr 7 22:37:51 UTC 2019
From: Andi Shyti <andi.shyti at intel.com>
we have a "class/instance to eb flags" helper but not the
opposite, add it.
Signed-off-by: Andi Shyti <andi.shyti at intel.com>
---
lib/igt_gt.c | 32 ++++++++++++++++++++++++++++++++
lib/igt_gt.h | 4 ++++
2 files changed, 36 insertions(+)
diff --git a/lib/igt_gt.c b/lib/igt_gt.c
index 5999524326d0..b28fca0387ed 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,37 @@ const struct intel_execution_engine2 intel_execution_engines2[] = {
{ }
};
+int gem_eb_to_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);
+ }
+}
+
+void gem_eb_to_class_instance(int fd, unsigned int flags,
+ struct intel_execution_engine2 *e)
+{
+ e->class = gem_eb_to_class(flags);
+
+ e->instance = ((flags & 0x3f) | I915_EXEC_BSD_RING2) ==
+ (I915_EXEC_BSD | I915_EXEC_BSD_RING2) ?
+ 1 :
+ 0;
+
+ if (!gem_has_engine_topology(fd))
+ e->flags = flags;
+}
+
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 52b2f1ea95a5..970ca22fb134 100644
--- a/lib/igt_gt.h
+++ b/lib/igt_gt.h
@@ -99,6 +99,10 @@ extern const struct intel_execution_engine2 {
bool is_virtual;
} intel_execution_engines2[];
+int gem_eb_to_class(unsigned int flags);
+void gem_eb_to_class_instance(int fd, unsigned int flags,
+ struct intel_execution_engine2 *e);
+
unsigned int
gem_class_instance_to_eb_flags(int gem_fd,
enum drm_i915_gem_engine_class class,
--
2.20.1
More information about the igt-dev
mailing list