xref: /linux/drivers/gpu/drm/i915/gem/selftests/mock_context.c (revision 15a1fbdcfb519c2bd291ed01c6c94e0b89537a77)
1 /*
2  * SPDX-License-Identifier: MIT
3  *
4  * Copyright © 2016 Intel Corporation
5  */
6 
7 #include "mock_context.h"
8 #include "selftests/mock_drm.h"
9 #include "selftests/mock_gtt.h"
10 
11 struct i915_gem_context *
12 mock_context(struct drm_i915_private *i915,
13 	     const char *name)
14 {
15 	struct i915_gem_context *ctx;
16 	struct i915_gem_engines *e;
17 
18 	ctx = kzalloc(sizeof(*ctx), GFP_KERNEL);
19 	if (!ctx)
20 		return NULL;
21 
22 	kref_init(&ctx->ref);
23 	INIT_LIST_HEAD(&ctx->link);
24 	ctx->i915 = i915;
25 
26 	i915_gem_context_set_persistence(ctx);
27 
28 	mutex_init(&ctx->engines_mutex);
29 	e = default_engines(ctx);
30 	if (IS_ERR(e))
31 		goto err_free;
32 	RCU_INIT_POINTER(ctx->engines, e);
33 
34 	INIT_RADIX_TREE(&ctx->handles_vma, GFP_KERNEL);
35 	mutex_init(&ctx->mutex);
36 
37 	if (name) {
38 		struct i915_ppgtt *ppgtt;
39 
40 		strncpy(ctx->name, name, sizeof(ctx->name) - 1);
41 
42 		ppgtt = mock_ppgtt(i915, name);
43 		if (!ppgtt)
44 			goto err_put;
45 
46 		mutex_lock(&ctx->mutex);
47 		__set_ppgtt(ctx, &ppgtt->vm);
48 		mutex_unlock(&ctx->mutex);
49 
50 		i915_vm_put(&ppgtt->vm);
51 	}
52 
53 	return ctx;
54 
55 err_free:
56 	kfree(ctx);
57 	return NULL;
58 
59 err_put:
60 	i915_gem_context_set_closed(ctx);
61 	i915_gem_context_put(ctx);
62 	return NULL;
63 }
64 
65 void mock_context_close(struct i915_gem_context *ctx)
66 {
67 	context_close(ctx);
68 }
69 
70 void mock_init_contexts(struct drm_i915_private *i915)
71 {
72 	init_contexts(&i915->gem.contexts);
73 }
74 
75 struct i915_gem_context *
76 live_context(struct drm_i915_private *i915, struct file *file)
77 {
78 	struct i915_gem_context *ctx;
79 	int err;
80 	u32 id;
81 
82 	ctx = i915_gem_create_context(i915, 0);
83 	if (IS_ERR(ctx))
84 		return ctx;
85 
86 	i915_gem_context_set_no_error_capture(ctx);
87 
88 	err = gem_context_register(ctx, to_drm_file(file)->driver_priv, &id);
89 	if (err < 0)
90 		goto err_ctx;
91 
92 	return ctx;
93 
94 err_ctx:
95 	context_close(ctx);
96 	return ERR_PTR(err);
97 }
98 
99 struct i915_gem_context *
100 kernel_context(struct drm_i915_private *i915)
101 {
102 	struct i915_gem_context *ctx;
103 
104 	ctx = i915_gem_create_context(i915, 0);
105 	if (IS_ERR(ctx))
106 		return ctx;
107 
108 	i915_gem_context_clear_bannable(ctx);
109 	i915_gem_context_set_persistence(ctx);
110 	i915_gem_context_set_no_error_capture(ctx);
111 
112 	return ctx;
113 }
114 
115 void kernel_context_close(struct i915_gem_context *ctx)
116 {
117 	context_close(ctx);
118 }
119