summaryrefslogtreecommitdiff
path: root/tests/i915/gem_ctx_engines.c
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2020-02-14 19:18:28 +0000
committerChris Wilson <chris@chris-wilson.co.uk>2020-02-14 21:51:28 +0000
commit3361ad74ca08bb470a9a18cc25db2bef0d1311ff (patch)
tree1c7c673027e50df3e952082ca69e813894d46915 /tests/i915/gem_ctx_engines.c
parent5a3da5ce76718b62e797e1c9fab72734a68f4d3d (diff)
i915/gem_ctx_engines: Exercise 0 engines[]
Setup a context with no engines, and make sure we reject all execution attempts. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Antonio Argenziano <antonio.argenziano@intel.com>
Diffstat (limited to 'tests/i915/gem_ctx_engines.c')
-rw-r--r--tests/i915/gem_ctx_engines.c45
1 files changed, 45 insertions, 0 deletions
diff --git a/tests/i915/gem_ctx_engines.c b/tests/i915/gem_ctx_engines.c
index cb82f08e..063140e0 100644
--- a/tests/i915/gem_ctx_engines.c
+++ b/tests/i915/gem_ctx_engines.c
@@ -242,6 +242,48 @@ static void idempotent(int i915)
gem_context_destroy(i915, p.ctx_id);
}
+static uint32_t batch_create(int i915)
+{
+ const uint32_t bbe = MI_BATCH_BUFFER_END;
+ uint32_t handle = gem_create(i915, 4096);
+
+ gem_write(i915, handle, 0, &bbe, sizeof(bbe));
+ return handle;
+}
+
+static void none(int i915)
+{
+ struct i915_context_param_engines engines = {};
+ struct drm_i915_gem_context_param p = {
+ .ctx_id = gem_context_create(i915),
+ .param = I915_CONTEXT_PARAM_ENGINES,
+ .value = to_user_pointer(&engines),
+ .size = sizeof(engines),
+ };
+
+ gem_context_set_param(i915, &p);
+
+ {
+ struct drm_i915_gem_exec_object2 obj = {
+ .handle = batch_create(i915),
+ };
+ struct drm_i915_gem_execbuffer2 execbuf = {
+ .buffers_ptr = to_user_pointer(&obj),
+ .buffer_count = 1,
+ .rsvd1 = p.ctx_id,
+ };
+
+ for (execbuf.flags = 0;
+ execbuf.flags <= I915_EXEC_RING_MASK;
+ execbuf.flags++)
+ igt_assert_eq(__gem_execbuf(i915, &execbuf), -EINVAL);
+
+ gem_close(i915, obj.handle);
+ }
+
+ gem_context_destroy(i915, p.ctx_id);
+}
+
static void execute_one(int i915)
{
I915_DEFINE_CONTEXT_PARAM_ENGINES(engines , I915_EXEC_RING_MASK + 1);
@@ -527,6 +569,9 @@ igt_main
igt_subtest("idempotent")
idempotent(i915);
+ igt_subtest("none")
+ none(i915);
+
igt_subtest("execute-one")
execute_one(i915);