i915_gem_context.c 29.9 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
/*
 * Copyright © 2011-2012 Intel Corporation
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice (including the next
 * paragraph) shall be included in all copies or substantial portions of the
 * Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 * IN THE SOFTWARE.
 *
 * Authors:
 *    Ben Widawsky <ben@bwidawsk.net>
 *
 */

/*
 * This file implements HW context support. On gen5+ a HW context consists of an
 * opaque GPU object which is referenced at times of context saves and restores.
 * With RC6 enabled, the context is also referenced as the GPU enters and exists
 * from RC6 (GPU has it's own internal power context, except on gen5). Though
 * something like a context does exist for the media ring, the code only
 * supports contexts for the render ring.
 *
 * In software, there is a distinction between contexts created by the user,
 * and the default HW context. The default HW context is used by GPU clients
 * that do not request setup of their own hardware context. The default
 * context's state is never restored to help prevent programming errors. This
 * would happen if a client ran and piggy-backed off another clients GPU state.
 * The default context only exists to give the GPU some offset to load as the
 * current to invoke a save of the context we actually care about. In fact, the
 * code could likely be constructed, albeit in a more complicated fashion, to
 * never use the default context, though that limits the driver's ability to
 * swap out, and/or destroy other contexts.
 *
 * All other contexts are created as a request by the GPU client. These contexts
 * store GPU state, and thus allow GPU clients to not re-emit state (and
 * potentially query certain state) at any time. The kernel driver makes
 * certain that the appropriate commands are inserted.
 *
 * The context life cycle is semi-complicated in that context BOs may live
 * longer than the context itself because of the way the hardware, and object
 * tracking works. Below is a very crude representation of the state machine
 * describing the context life.
 *                                         refcount     pincount     active
 * S0: initial state                          0            0           0
 * S1: context created                        1            0           0
 * S2: context is currently running           2            1           X
 * S3: GPU referenced, but not current        2            0           1
 * S4: context is current, but destroyed      1            1           0
 * S5: like S3, but destroyed                 1            0           1
 *
 * The most common (but not all) transitions:
 * S0->S1: client creates a context
 * S1->S2: client submits execbuf with context
 * S2->S3: other clients submits execbuf with context
 * S3->S1: context object was retired
 * S3->S2: clients submits another execbuf
 * S2->S4: context destroy called with current context
 * S3->S5->S0: destroy path
 * S4->S5->S0: destroy path on current context
 *
 * There are two confusing terms used above:
 *  The "current context" means the context which is currently running on the
D
Damien Lespiau 已提交
76
 *  GPU. The GPU has loaded its state already and has stored away the gtt
77 78 79 80 81 82 83 84 85 86 87
 *  offset of the BO. The GPU is not actively referencing the data at this
 *  offset, but it will on the next context switch. The only way to avoid this
 *  is to do a GPU reset.
 *
 *  An "active context' is one which was previously the "current context" and is
 *  on the active list waiting for the next context switch to occur. Until this
 *  happens, the object must remain at the same gtt offset. It is therefore
 *  possible to destroy a context, but it is still active.
 *
 */

88 89
#include <drm/drmP.h>
#include <drm/i915_drm.h>
90
#include "i915_drv.h"
91
#include "i915_trace.h"
92

93 94
#define ALL_L3_SLICES(dev) (1 << NUM_L3_SLICES(dev)) - 1

95 96 97 98
/* This is a HW constraint. The value below is the largest known requirement
 * I've seen in a spec to date, and that was a workaround for a non-shipping
 * part. It should be safe to decrease this, but it's more future proof as is.
 */
B
Ben Widawsky 已提交
99 100
#define GEN6_CONTEXT_ALIGN (64<<10)
#define GEN7_CONTEXT_ALIGN 4096
101

102
static size_t get_context_alignment(struct drm_i915_private *dev_priv)
B
Ben Widawsky 已提交
103
{
104
	if (IS_GEN6(dev_priv))
B
Ben Widawsky 已提交
105 106 107 108 109
		return GEN6_CONTEXT_ALIGN;

	return GEN7_CONTEXT_ALIGN;
}

110
static int get_context_size(struct drm_i915_private *dev_priv)
111 112 113 114
{
	int ret;
	u32 reg;

115
	switch (INTEL_GEN(dev_priv)) {
116 117 118 119 120
	case 6:
		reg = I915_READ(CXT_SIZE);
		ret = GEN6_CXT_TOTAL_SIZE(reg) * 64;
		break;
	case 7:
B
Ben Widawsky 已提交
121
		reg = I915_READ(GEN7_CXT_SIZE);
122
		if (IS_HASWELL(dev_priv))
123
			ret = HSW_CXT_TOTAL_SIZE;
B
Ben Widawsky 已提交
124 125
		else
			ret = GEN7_CXT_TOTAL_SIZE(reg) * 64;
126
		break;
B
Ben Widawsky 已提交
127 128 129
	case 8:
		ret = GEN8_CXT_TOTAL_SIZE;
		break;
130 131 132 133 134 135 136
	default:
		BUG();
	}

	return ret;
}

137 138 139 140 141
static void i915_gem_context_clean(struct intel_context *ctx)
{
	struct i915_hw_ppgtt *ppgtt = ctx->ppgtt;
	struct i915_vma *vma, *next;

142
	if (!ppgtt)
143 144 145
		return;

	list_for_each_entry_safe(vma, next, &ppgtt->base.inactive_list,
146
				 vm_link) {
147 148 149 150 151
		if (WARN_ON(__i915_vma_unbind_no_wait(vma)))
			break;
	}
}

152
void i915_gem_context_free(struct kref *ctx_ref)
153
{
154
	struct intel_context *ctx = container_of(ctx_ref, typeof(*ctx), ref);
155

156 157
	trace_i915_context_free(ctx);

158
	if (i915.enable_execlists)
159
		intel_lr_context_free(ctx);
B
Ben Widawsky 已提交
160

161 162 163 164 165 166 167
	/*
	 * This context is going away and we need to remove all VMAs still
	 * around. This is to handle imported shared objects for which
	 * destructor did not run when their handles were closed.
	 */
	i915_gem_context_clean(ctx);

168 169
	i915_ppgtt_put(ctx->ppgtt);

170 171
	if (ctx->legacy_hw_ctx.rcs_state)
		drm_gem_object_unreference(&ctx->legacy_hw_ctx.rcs_state->base);
B
Ben Widawsky 已提交
172
	list_del(&ctx->link);
173 174

	ida_simple_remove(&ctx->i915->context_hw_ida, ctx->hw_id);
175 176 177
	kfree(ctx);
}

178
struct drm_i915_gem_object *
179 180 181 182 183
i915_gem_alloc_context_obj(struct drm_device *dev, size_t size)
{
	struct drm_i915_gem_object *obj;
	int ret;

184
	obj = i915_gem_object_create(dev, size);
185 186
	if (IS_ERR(obj))
		return obj;
187 188 189 190 191 192 193 194

	/*
	 * Try to make the context utilize L3 as well as LLC.
	 *
	 * On VLV we don't have L3 controls in the PTEs so we
	 * shouldn't touch the cache level, especially as that
	 * would make the object snooped which might have a
	 * negative performance impact.
195 196 197 198 199 200 201
	 *
	 * Snooping is required on non-llc platforms in execlist
	 * mode, but since all GGTT accesses use PAT entry 0 we
	 * get snooping anyway regardless of cache_level.
	 *
	 * This is only applicable for Ivy Bridge devices since
	 * later platforms don't have L3 control bits in the PTE.
202
	 */
203
	if (IS_IVYBRIDGE(dev)) {
204 205 206 207 208 209 210 211 212 213 214
		ret = i915_gem_object_set_cache_level(obj, I915_CACHE_L3_LLC);
		/* Failure shouldn't ever happen this early */
		if (WARN_ON(ret)) {
			drm_gem_object_unreference(&obj->base);
			return ERR_PTR(ret);
		}
	}

	return obj;
}

215 216 217 218 219 220 221 222 223 224 225
static int assign_hw_id(struct drm_i915_private *dev_priv, unsigned *out)
{
	int ret;

	ret = ida_simple_get(&dev_priv->context_hw_ida,
			     0, MAX_CONTEXT_HW_ID, GFP_KERNEL);
	if (ret < 0) {
		/* Contexts are only released when no longer active.
		 * Flush any pending retires to hopefully release some
		 * stale contexts and try again.
		 */
226
		i915_gem_retire_requests(dev_priv);
227 228 229 230 231 232 233 234 235 236
		ret = ida_simple_get(&dev_priv->context_hw_ida,
				     0, MAX_CONTEXT_HW_ID, GFP_KERNEL);
		if (ret < 0)
			return ret;
	}

	*out = ret;
	return 0;
}

237
static struct intel_context *
238
__create_hw_context(struct drm_device *dev,
239
		    struct drm_i915_file_private *file_priv)
240 241
{
	struct drm_i915_private *dev_priv = dev->dev_private;
242
	struct intel_context *ctx;
T
Tejun Heo 已提交
243
	int ret;
244

245
	ctx = kzalloc(sizeof(*ctx), GFP_KERNEL);
246 247
	if (ctx == NULL)
		return ERR_PTR(-ENOMEM);
248

249 250 251 252 253 254
	ret = assign_hw_id(dev_priv, &ctx->hw_id);
	if (ret) {
		kfree(ctx);
		return ERR_PTR(ret);
	}

255
	kref_init(&ctx->ref);
256
	list_add_tail(&ctx->link, &dev_priv->context_list);
257
	ctx->i915 = dev_priv;
258

259
	if (dev_priv->hw_context_size) {
260 261 262 263
		struct drm_i915_gem_object *obj =
				i915_gem_alloc_context_obj(dev, dev_priv->hw_context_size);
		if (IS_ERR(obj)) {
			ret = PTR_ERR(obj);
264
			goto err_out;
265
		}
266
		ctx->legacy_hw_ctx.rcs_state = obj;
267
	}
268 269

	/* Default context will never have a file_priv */
270 271
	if (file_priv != NULL) {
		ret = idr_alloc(&file_priv->context_idr, ctx,
272
				DEFAULT_CONTEXT_HANDLE, 0, GFP_KERNEL);
273 274 275
		if (ret < 0)
			goto err_out;
	} else
276
		ret = DEFAULT_CONTEXT_HANDLE;
277 278

	ctx->file_priv = file_priv;
279
	ctx->user_handle = ret;
280 281 282
	/* NB: Mark all slices as needing a remap so that when the context first
	 * loads it will restore whatever remap state already exists. If there
	 * is no remap info, it will be a NOP. */
283
	ctx->remap_slice = ALL_L3_SLICES(dev_priv);
284

285 286
	ctx->hang_stats.ban_period_seconds = DRM_I915_CTX_BAN_PERIOD;

287
	return ctx;
288 289

err_out:
290
	i915_gem_context_unreference(ctx);
291
	return ERR_PTR(ret);
292 293
}

294 295 296 297 298
/**
 * The default context needs to exist per ring that uses contexts. It stores the
 * context state of the GPU for applications that don't utilize HW contexts, as
 * well as an idle case.
 */
299
static struct intel_context *
300
i915_gem_create_context(struct drm_device *dev,
301
			struct drm_i915_file_private *file_priv)
302
{
303
	const bool is_global_default_ctx = file_priv == NULL;
304
	struct intel_context *ctx;
305
	int ret = 0;
306

B
Ben Widawsky 已提交
307
	BUG_ON(!mutex_is_locked(&dev->struct_mutex));
308

309
	ctx = __create_hw_context(dev, file_priv);
310
	if (IS_ERR(ctx))
311
		return ctx;
312

313
	if (is_global_default_ctx && ctx->legacy_hw_ctx.rcs_state) {
314 315 316 317 318 319 320
		/* We may need to do things with the shrinker which
		 * require us to immediately switch back to the default
		 * context. This can cause a problem as pinning the
		 * default context also requires GTT space which may not
		 * be available. To avoid this we always pin the default
		 * context.
		 */
321
		ret = i915_gem_obj_ggtt_pin(ctx->legacy_hw_ctx.rcs_state,
322
					    get_context_alignment(to_i915(dev)), 0);
323 324 325 326 327 328
		if (ret) {
			DRM_DEBUG_DRIVER("Couldn't pin %d\n", ret);
			goto err_destroy;
		}
	}

329
	if (USES_FULL_PPGTT(dev)) {
330
		struct i915_hw_ppgtt *ppgtt = i915_ppgtt_create(dev, file_priv);
331 332

		if (IS_ERR_OR_NULL(ppgtt)) {
333 334
			DRM_DEBUG_DRIVER("PPGTT setup failed (%ld)\n",
					 PTR_ERR(ppgtt));
335
			ret = PTR_ERR(ppgtt);
336
			goto err_unpin;
337 338 339 340
		}

		ctx->ppgtt = ppgtt;
	}
341

342 343
	trace_i915_context_create(ctx);

344
	return ctx;
345

346
err_unpin:
347 348
	if (is_global_default_ctx && ctx->legacy_hw_ctx.rcs_state)
		i915_gem_object_ggtt_unpin(ctx->legacy_hw_ctx.rcs_state);
349
err_destroy:
350
	idr_remove(&file_priv->context_idr, ctx->user_handle);
351
	i915_gem_context_unreference(ctx);
352
	return ERR_PTR(ret);
353 354
}

355 356 357
static void i915_gem_context_unpin(struct intel_context *ctx,
				   struct intel_engine_cs *engine)
{
358 359 360 361 362 363 364
	if (i915.enable_execlists) {
		intel_lr_context_unpin(ctx, engine);
	} else {
		if (engine->id == RCS && ctx->legacy_hw_ctx.rcs_state)
			i915_gem_object_ggtt_unpin(ctx->legacy_hw_ctx.rcs_state);
		i915_gem_context_unreference(ctx);
	}
365 366
}

367 368 369 370
void i915_gem_context_reset(struct drm_device *dev)
{
	struct drm_i915_private *dev_priv = dev->dev_private;

371 372 373
	if (i915.enable_execlists) {
		struct intel_context *ctx;

374
		list_for_each_entry(ctx, &dev_priv->context_list, link)
375
			intel_lr_context_reset(dev_priv, ctx);
376
	}
377

378
	i915_gem_context_lost(dev_priv);
379 380
}

381
int i915_gem_context_init(struct drm_device *dev)
382 383
{
	struct drm_i915_private *dev_priv = dev->dev_private;
384
	struct intel_context *ctx;
385

386 387
	/* Init should only be called once per module load. Eventually the
	 * restriction on the context_disabled check can be loosened. */
388
	if (WARN_ON(dev_priv->kernel_context))
389
		return 0;
390

391 392
	if (intel_vgpu_active(dev_priv) &&
	    HAS_LOGICAL_RING_CONTEXTS(dev_priv)) {
393 394 395 396 397 398
		if (!i915.enable_execlists) {
			DRM_INFO("Only EXECLIST mode is supported in vgpu.\n");
			return -EINVAL;
		}
	}

399 400 401 402
	/* Using the simple ida interface, the max is limited by sizeof(int) */
	BUILD_BUG_ON(MAX_CONTEXT_HW_ID > INT_MAX);
	ida_init(&dev_priv->context_hw_ida);

403 404 405 406
	if (i915.enable_execlists) {
		/* NB: intentionally left blank. We will allocate our own
		 * backing objects as we need them, thank you very much */
		dev_priv->hw_context_size = 0;
407 408 409
	} else if (HAS_HW_CONTEXTS(dev_priv)) {
		dev_priv->hw_context_size =
			round_up(get_context_size(dev_priv), 4096);
410 411 412 413 414
		if (dev_priv->hw_context_size > (1<<20)) {
			DRM_DEBUG_DRIVER("Disabling HW Contexts; invalid size %d\n",
					 dev_priv->hw_context_size);
			dev_priv->hw_context_size = 0;
		}
415 416
	}

417
	ctx = i915_gem_create_context(dev, NULL);
418 419 420 421
	if (IS_ERR(ctx)) {
		DRM_ERROR("Failed to create default global context (error %ld)\n",
			  PTR_ERR(ctx));
		return PTR_ERR(ctx);
422 423
	}

424
	dev_priv->kernel_context = ctx;
425

426 427 428
	DRM_DEBUG_DRIVER("%s context support initialized\n",
			i915.enable_execlists ? "LR" :
			dev_priv->hw_context_size ? "HW" : "fake");
429
	return 0;
430 431
}

432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448
void i915_gem_context_lost(struct drm_i915_private *dev_priv)
{
	struct intel_engine_cs *engine;

	for_each_engine(engine, dev_priv) {
		if (engine->last_context == NULL)
			continue;

		i915_gem_context_unpin(engine->last_context, engine);
		engine->last_context = NULL;
	}

	/* Force the GPU state to be reinitialised on enabling */
	dev_priv->kernel_context->legacy_hw_ctx.initialized = false;
	dev_priv->kernel_context->remap_slice = ALL_L3_SLICES(dev_priv);
}

449 450 451
void i915_gem_context_fini(struct drm_device *dev)
{
	struct drm_i915_private *dev_priv = dev->dev_private;
452
	struct intel_context *dctx = dev_priv->kernel_context;
453

454
	if (dctx->legacy_hw_ctx.rcs_state)
455
		i915_gem_object_ggtt_unpin(dctx->legacy_hw_ctx.rcs_state);
456

457
	i915_gem_context_unreference(dctx);
458
	dev_priv->kernel_context = NULL;
459 460

	ida_destroy(&dev_priv->context_hw_ida);
461 462
}

463 464
static int context_idr_cleanup(int id, void *p, void *data)
{
465
	struct intel_context *ctx = p;
466

467
	i915_gem_context_unreference(ctx);
468
	return 0;
469 470
}

471 472 473
int i915_gem_context_open(struct drm_device *dev, struct drm_file *file)
{
	struct drm_i915_file_private *file_priv = file->driver_priv;
474
	struct intel_context *ctx;
475 476 477

	idr_init(&file_priv->context_idr);

478
	mutex_lock(&dev->struct_mutex);
479
	ctx = i915_gem_create_context(dev, file_priv);
480 481
	mutex_unlock(&dev->struct_mutex);

482
	if (IS_ERR(ctx)) {
483
		idr_destroy(&file_priv->context_idr);
484
		return PTR_ERR(ctx);
485 486
	}

487 488 489
	return 0;
}

490 491
void i915_gem_context_close(struct drm_device *dev, struct drm_file *file)
{
492
	struct drm_i915_file_private *file_priv = file->driver_priv;
493

494
	idr_for_each(&file_priv->context_idr, context_idr_cleanup, NULL);
495 496 497
	idr_destroy(&file_priv->context_idr);
}

498
struct intel_context *
499 500
i915_gem_context_get(struct drm_i915_file_private *file_priv, u32 id)
{
501
	struct intel_context *ctx;
502

503
	ctx = (struct intel_context *)idr_find(&file_priv->context_idr, id);
504 505 506 507
	if (!ctx)
		return ERR_PTR(-ENOENT);

	return ctx;
508
}
509 510

static inline int
511
mi_set_context(struct drm_i915_gem_request *req, u32 hw_flags)
512
{
513
	struct drm_i915_private *dev_priv = req->i915;
514
	struct intel_engine_cs *engine = req->engine;
515
	u32 flags = hw_flags | MI_MM_SPACE_GTT;
516 517
	const int num_rings =
		/* Use an extended w/a on ivb+ if signalling from other rings */
518 519
		i915_semaphore_is_enabled(dev_priv) ?
		hweight32(INTEL_INFO(dev_priv)->ring_mask) - 1 :
520
		0;
521
	int len, ret;
522

523 524 525 526 527
	/* w/a: If Flush TLB Invalidation Mode is enabled, driver must do a TLB
	 * invalidation prior to MI_SET_CONTEXT. On GEN6 we don't set the value
	 * explicitly, so we rely on the value at ring init, stored in
	 * itlb_before_ctx_switch.
	 */
528
	if (IS_GEN6(dev_priv)) {
529
		ret = engine->flush(req, I915_GEM_GPU_DOMAINS, 0);
530 531 532 533
		if (ret)
			return ret;
	}

534
	/* These flags are for resource streamer on HSW+ */
535
	if (IS_HASWELL(dev_priv) || INTEL_GEN(dev_priv) >= 8)
536
		flags |= (HSW_MI_RS_SAVE_STATE_EN | HSW_MI_RS_RESTORE_STATE_EN);
537
	else if (INTEL_GEN(dev_priv) < 8)
538 539
		flags |= (MI_SAVE_EXT_STATE_EN | MI_RESTORE_EXT_STATE_EN);

540 541

	len = 4;
542
	if (INTEL_GEN(dev_priv) >= 7)
543
		len += 2 + (num_rings ? 4*num_rings + 6 : 0);
544

545
	ret = intel_ring_begin(req, len);
546 547 548
	if (ret)
		return ret;

549
	/* WaProgramMiArbOnOffAroundMiSetContext:ivb,vlv,hsw,bdw,chv */
550
	if (INTEL_GEN(dev_priv) >= 7) {
551
		intel_ring_emit(engine, MI_ARB_ON_OFF | MI_ARB_DISABLE);
552 553 554
		if (num_rings) {
			struct intel_engine_cs *signaller;

555 556
			intel_ring_emit(engine,
					MI_LOAD_REGISTER_IMM(num_rings));
557
			for_each_engine(signaller, dev_priv) {
558
				if (signaller == engine)
559 560
					continue;

561 562 563 564
				intel_ring_emit_reg(engine,
						    RING_PSMI_CTL(signaller->mmio_base));
				intel_ring_emit(engine,
						_MASKED_BIT_ENABLE(GEN6_PSMI_SLEEP_MSG_DISABLE));
565 566 567
			}
		}
	}
568

569 570 571 572
	intel_ring_emit(engine, MI_NOOP);
	intel_ring_emit(engine, MI_SET_CONTEXT);
	intel_ring_emit(engine,
			i915_gem_obj_ggtt_offset(req->ctx->legacy_hw_ctx.rcs_state) |
573
			flags);
574 575 576 577
	/*
	 * w/a: MI_SET_CONTEXT must always be followed by MI_NOOP
	 * WaMiSetContext_Hang:snb,ivb,vlv
	 */
578
	intel_ring_emit(engine, MI_NOOP);
579

580
	if (INTEL_GEN(dev_priv) >= 7) {
581 582
		if (num_rings) {
			struct intel_engine_cs *signaller;
583
			i915_reg_t last_reg = {}; /* keep gcc quiet */
584

585 586
			intel_ring_emit(engine,
					MI_LOAD_REGISTER_IMM(num_rings));
587
			for_each_engine(signaller, dev_priv) {
588
				if (signaller == engine)
589 590
					continue;

591 592
				last_reg = RING_PSMI_CTL(signaller->mmio_base);
				intel_ring_emit_reg(engine, last_reg);
593 594
				intel_ring_emit(engine,
						_MASKED_BIT_DISABLE(GEN6_PSMI_SLEEP_MSG_DISABLE));
595
			}
596 597 598 599 600 601 602 603

			/* Insert a delay before the next switch! */
			intel_ring_emit(engine,
					MI_STORE_REGISTER_MEM |
					MI_SRM_LRM_GLOBAL_GTT);
			intel_ring_emit_reg(engine, last_reg);
			intel_ring_emit(engine, engine->scratch.gtt_offset);
			intel_ring_emit(engine, MI_NOOP);
604
		}
605
		intel_ring_emit(engine, MI_ARB_ON_OFF | MI_ARB_ENABLE);
606
	}
607

608
	intel_ring_advance(engine);
609 610 611 612

	return ret;
}

C
Chris Wilson 已提交
613
static int remap_l3(struct drm_i915_gem_request *req, int slice)
614
{
615
	u32 *remap_info = req->i915->l3_parity.remap_info[slice];
616 617 618
	struct intel_engine_cs *engine = req->engine;
	int i, ret;

619
	if (!remap_info)
620 621
		return 0;

622
	ret = intel_ring_begin(req, GEN7_L3LOG_SIZE/4 * 2 + 2);
623 624 625 626 627 628 629 630
	if (ret)
		return ret;

	/*
	 * Note: We do not worry about the concurrent register cacheline hang
	 * here because no other code should access these registers other than
	 * at initialization time.
	 */
631 632
	intel_ring_emit(engine, MI_LOAD_REGISTER_IMM(GEN7_L3LOG_SIZE/4));
	for (i = 0; i < GEN7_L3LOG_SIZE/4; i++) {
633 634 635
		intel_ring_emit_reg(engine, GEN7_L3LOG(slice, i));
		intel_ring_emit(engine, remap_info[i]);
	}
636
	intel_ring_emit(engine, MI_NOOP);
637 638
	intel_ring_advance(engine);

639
	return 0;
640 641
}

642 643
static inline bool skip_rcs_switch(struct i915_hw_ppgtt *ppgtt,
				   struct intel_engine_cs *engine,
644
				   struct intel_context *to)
645
{
646 647 648
	if (to->remap_slice)
		return false;

649 650 651
	if (!to->legacy_hw_ctx.initialized)
		return false;

652
	if (ppgtt && (intel_engine_flag(engine) & ppgtt->pd_dirty_rings))
653
		return false;
654

655
	return to == engine->last_context;
656 657 658
}

static bool
659 660 661
needs_pd_load_pre(struct i915_hw_ppgtt *ppgtt,
		  struct intel_engine_cs *engine,
		  struct intel_context *to)
662
{
663
	if (!ppgtt)
664 665
		return false;

666 667 668 669 670
	/* Always load the ppgtt on first use */
	if (!engine->last_context)
		return true;

	/* Same context without new entries, skip */
671
	if (engine->last_context == to &&
672
	    !(intel_engine_flag(engine) & ppgtt->pd_dirty_rings))
673 674 675
		return false;

	if (engine->id != RCS)
676 677
		return true;

678
	if (INTEL_GEN(engine->i915) < 8)
679 680 681 682 683 684
		return true;

	return false;
}

static bool
685 686 687
needs_pd_load_post(struct i915_hw_ppgtt *ppgtt,
		   struct intel_context *to,
		   u32 hw_flags)
688
{
689
	if (!ppgtt)
690 691
		return false;

692
	if (!IS_GEN8(to->i915))
693 694
		return false;

B
Ben Widawsky 已提交
695
	if (hw_flags & MI_RESTORE_INHIBIT)
696 697 698 699 700
		return true;

	return false;
}

701
static int do_rcs_switch(struct drm_i915_gem_request *req)
702
{
703
	struct intel_context *to = req->ctx;
704
	struct intel_engine_cs *engine = req->engine;
705
	struct i915_hw_ppgtt *ppgtt = to->ppgtt ?: req->i915->mm.aliasing_ppgtt;
706 707
	struct intel_context *from;
	u32 hw_flags;
708
	int ret, i;
709

710
	if (skip_rcs_switch(ppgtt, engine, to))
711 712
		return 0;

713
	/* Trying to pin first makes error handling easier. */
714
	ret = i915_gem_obj_ggtt_pin(to->legacy_hw_ctx.rcs_state,
715
				    get_context_alignment(engine->i915),
716 717 718
				    0);
	if (ret)
		return ret;
719

720 721 722 723
	/*
	 * Pin can switch back to the default context if we end up calling into
	 * evict_everything - as a last ditch gtt defrag effort that also
	 * switches to the default context. Hence we need to reload from here.
724 725
	 *
	 * XXX: Doing so is painfully broken!
726
	 */
727
	from = engine->last_context;
728 729 730

	/*
	 * Clear this page out of any CPU caches for coherent swap-in/out. Note
731 732 733
	 * that thanks to write = false in this call and us not setting any gpu
	 * write domains when putting a context object onto the active list
	 * (when switching away from it), this won't block.
734 735 736
	 *
	 * XXX: We need a real interface to do this instead of trickery.
	 */
737
	ret = i915_gem_object_set_to_gtt_domain(to->legacy_hw_ctx.rcs_state, false);
738 739
	if (ret)
		goto unpin_out;
740

741
	if (needs_pd_load_pre(ppgtt, engine, to)) {
742 743 744 745 746
		/* Older GENs and non render rings still want the load first,
		 * "PP_DCLV followed by PP_DIR_BASE register through Load
		 * Register Immediate commands in Ring Buffer before submitting
		 * a context."*/
		trace_switch_mm(engine, to);
747
		ret = ppgtt->switch_mm(ppgtt, req);
748 749 750 751 752
		if (ret)
			goto unpin_out;
	}

	if (!to->legacy_hw_ctx.initialized || i915_gem_context_is_default(to))
B
Ben Widawsky 已提交
753 754 755 756
		/* NB: If we inhibit the restore, the context is not allowed to
		 * die because future work may end up depending on valid address
		 * space. This means we must enforce that a page table load
		 * occur when this occurs. */
757
		hw_flags = MI_RESTORE_INHIBIT;
758
	else if (ppgtt && intel_engine_flag(engine) & ppgtt->pd_dirty_rings)
759 760 761
		hw_flags = MI_FORCE_RESTORE;
	else
		hw_flags = 0;
762

763 764
	if (to != from || (hw_flags & MI_FORCE_RESTORE)) {
		ret = mi_set_context(req, hw_flags);
765
		if (ret)
766
			goto unpin_out;
767 768
	}

769 770 771 772 773 774
	/* The backing object for the context is done after switching to the
	 * *next* context. Therefore we cannot retire the previous context until
	 * the next context has already started running. In fact, the below code
	 * is a bit suboptimal because the retiring can occur simply after the
	 * MI_SET_CONTEXT instead of when the next seqno has completed.
	 */
775
	if (from != NULL) {
776
		from->legacy_hw_ctx.rcs_state->base.read_domains = I915_GEM_DOMAIN_INSTRUCTION;
777
		i915_vma_move_to_active(i915_gem_obj_to_ggtt(from->legacy_hw_ctx.rcs_state), req);
778 779 780 781 782 783 784
		/* As long as MI_SET_CONTEXT is serializing, ie. it flushes the
		 * whole damn pipeline, we don't need to explicitly mark the
		 * object dirty. The only exception is that the context must be
		 * correct in case the object gets swapped out. Ideally we'd be
		 * able to defer doing this until we know the object would be
		 * swapped, but there is no way to do that yet.
		 */
785
		from->legacy_hw_ctx.rcs_state->dirty = 1;
786

787
		/* obj is kept alive until the next request by its active ref */
788
		i915_gem_object_ggtt_unpin(from->legacy_hw_ctx.rcs_state);
789
		i915_gem_context_unreference(from);
790
	}
791
	i915_gem_context_reference(to);
792
	engine->last_context = to;
793

794 795 796
	/* GEN8 does *not* require an explicit reload if the PDPs have been
	 * setup, and we do not wish to move them.
	 */
797
	if (needs_pd_load_post(ppgtt, to, hw_flags)) {
798
		trace_switch_mm(engine, to);
799
		ret = ppgtt->switch_mm(ppgtt, req);
800 801 802 803 804 805 806 807 808
		/* The hardware context switch is emitted, but we haven't
		 * actually changed the state - so it's probably safe to bail
		 * here. Still, let the user know something dangerous has
		 * happened.
		 */
		if (ret)
			return ret;
	}

809 810
	if (ppgtt)
		ppgtt->pd_dirty_rings &= ~intel_engine_flag(engine);
811 812 813 814 815

	for (i = 0; i < MAX_L3_SLICES; i++) {
		if (!(to->remap_slice & (1<<i)))
			continue;

C
Chris Wilson 已提交
816
		ret = remap_l3(req, i);
817 818 819 820 821 822 823
		if (ret)
			return ret;

		to->remap_slice &= ~(1<<i);
	}

	if (!to->legacy_hw_ctx.initialized) {
824 825
		if (engine->init_context) {
			ret = engine->init_context(req);
826
			if (ret)
827
				return ret;
828
		}
829
		to->legacy_hw_ctx.initialized = true;
830 831
	}

832
	return 0;
833 834

unpin_out:
835
	i915_gem_object_ggtt_unpin(to->legacy_hw_ctx.rcs_state);
836
	return ret;
837 838 839 840
}

/**
 * i915_switch_context() - perform a GPU context switch.
841
 * @req: request for which we'll execute the context switch
842 843 844
 *
 * The context life cycle is simple. The context refcount is incremented and
 * decremented by 1 and create and destroy. If the context is in use by the GPU,
845
 * it will have a refcount > 1. This allows us to destroy the context abstract
846
 * object while letting the normal object tracking destroy the backing BO.
847 848 849 850
 *
 * This function should not be used in execlists mode.  Instead the context is
 * switched by writing to the ELSP and requests keep a reference to their
 * context.
851
 */
852
int i915_switch_context(struct drm_i915_gem_request *req)
853
{
854
	struct intel_engine_cs *engine = req->engine;
855
	struct drm_i915_private *dev_priv = req->i915;
856

857
	WARN_ON(i915.enable_execlists);
858 859
	WARN_ON(!mutex_is_locked(&dev_priv->dev->struct_mutex));

860 861 862
	if (engine->id != RCS ||
	    req->ctx->legacy_hw_ctx.rcs_state == NULL) {
		struct intel_context *to = req->ctx;
863 864
		struct i915_hw_ppgtt *ppgtt =
			to->ppgtt ?: req->i915->mm.aliasing_ppgtt;
865

866
		if (needs_pd_load_pre(ppgtt, engine, to)) {
867 868 869
			int ret;

			trace_switch_mm(engine, to);
870
			ret = ppgtt->switch_mm(ppgtt, req);
871 872 873
			if (ret)
				return ret;

874
			ppgtt->pd_dirty_rings &= ~intel_engine_flag(engine);
875 876 877 878
		}

		if (to != engine->last_context) {
			i915_gem_context_reference(to);
879 880
			if (engine->last_context)
				i915_gem_context_unreference(engine->last_context);
881
			engine->last_context = to;
882
		}
883

884
		return 0;
885
	}
886

887
	return do_rcs_switch(req);
888
}
889

890
static bool contexts_enabled(struct drm_device *dev)
891
{
892
	return i915.enable_execlists || to_i915(dev)->hw_context_size;
893 894
}

895 896 897 898 899
int i915_gem_context_create_ioctl(struct drm_device *dev, void *data,
				  struct drm_file *file)
{
	struct drm_i915_gem_context_create *args = data;
	struct drm_i915_file_private *file_priv = file->driver_priv;
900
	struct intel_context *ctx;
901 902
	int ret;

903
	if (!contexts_enabled(dev))
904 905
		return -ENODEV;

906 907 908
	if (args->pad != 0)
		return -EINVAL;

909 910 911 912
	ret = i915_mutex_lock_interruptible(dev);
	if (ret)
		return ret;

913
	ctx = i915_gem_create_context(dev, file_priv);
914
	mutex_unlock(&dev->struct_mutex);
915 916
	if (IS_ERR(ctx))
		return PTR_ERR(ctx);
917

918
	args->ctx_id = ctx->user_handle;
919 920
	DRM_DEBUG_DRIVER("HW context %d created\n", args->ctx_id);

921
	return 0;
922 923 924 925 926 927 928
}

int i915_gem_context_destroy_ioctl(struct drm_device *dev, void *data,
				   struct drm_file *file)
{
	struct drm_i915_gem_context_destroy *args = data;
	struct drm_i915_file_private *file_priv = file->driver_priv;
929
	struct intel_context *ctx;
930 931
	int ret;

932 933 934
	if (args->pad != 0)
		return -EINVAL;

935
	if (args->ctx_id == DEFAULT_CONTEXT_HANDLE)
936
		return -ENOENT;
937

938 939 940 941 942
	ret = i915_mutex_lock_interruptible(dev);
	if (ret)
		return ret;

	ctx = i915_gem_context_get(file_priv, args->ctx_id);
943
	if (IS_ERR(ctx)) {
944
		mutex_unlock(&dev->struct_mutex);
945
		return PTR_ERR(ctx);
946 947
	}

948
	idr_remove(&ctx->file_priv->context_idr, ctx->user_handle);
949
	i915_gem_context_unreference(ctx);
950 951 952 953 954
	mutex_unlock(&dev->struct_mutex);

	DRM_DEBUG_DRIVER("HW context %d destroyed\n", args->ctx_id);
	return 0;
}
955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978

int i915_gem_context_getparam_ioctl(struct drm_device *dev, void *data,
				    struct drm_file *file)
{
	struct drm_i915_file_private *file_priv = file->driver_priv;
	struct drm_i915_gem_context_param *args = data;
	struct intel_context *ctx;
	int ret;

	ret = i915_mutex_lock_interruptible(dev);
	if (ret)
		return ret;

	ctx = i915_gem_context_get(file_priv, args->ctx_id);
	if (IS_ERR(ctx)) {
		mutex_unlock(&dev->struct_mutex);
		return PTR_ERR(ctx);
	}

	args->size = 0;
	switch (args->param) {
	case I915_CONTEXT_PARAM_BAN_PERIOD:
		args->value = ctx->hang_stats.ban_period_seconds;
		break;
979 980 981
	case I915_CONTEXT_PARAM_NO_ZEROMAP:
		args->value = ctx->flags & CONTEXT_NO_ZEROMAP;
		break;
C
Chris Wilson 已提交
982 983 984 985 986 987
	case I915_CONTEXT_PARAM_GTT_SIZE:
		if (ctx->ppgtt)
			args->value = ctx->ppgtt->base.total;
		else if (to_i915(dev)->mm.aliasing_ppgtt)
			args->value = to_i915(dev)->mm.aliasing_ppgtt->base.total;
		else
988
			args->value = to_i915(dev)->ggtt.base.total;
C
Chris Wilson 已提交
989
		break;
990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026
	default:
		ret = -EINVAL;
		break;
	}
	mutex_unlock(&dev->struct_mutex);

	return ret;
}

int i915_gem_context_setparam_ioctl(struct drm_device *dev, void *data,
				    struct drm_file *file)
{
	struct drm_i915_file_private *file_priv = file->driver_priv;
	struct drm_i915_gem_context_param *args = data;
	struct intel_context *ctx;
	int ret;

	ret = i915_mutex_lock_interruptible(dev);
	if (ret)
		return ret;

	ctx = i915_gem_context_get(file_priv, args->ctx_id);
	if (IS_ERR(ctx)) {
		mutex_unlock(&dev->struct_mutex);
		return PTR_ERR(ctx);
	}

	switch (args->param) {
	case I915_CONTEXT_PARAM_BAN_PERIOD:
		if (args->size)
			ret = -EINVAL;
		else if (args->value < ctx->hang_stats.ban_period_seconds &&
			 !capable(CAP_SYS_ADMIN))
			ret = -EPERM;
		else
			ctx->hang_stats.ban_period_seconds = args->value;
		break;
1027 1028 1029 1030 1031 1032 1033 1034
	case I915_CONTEXT_PARAM_NO_ZEROMAP:
		if (args->size) {
			ret = -EINVAL;
		} else {
			ctx->flags &= ~CONTEXT_NO_ZEROMAP;
			ctx->flags |= args->value ? CONTEXT_NO_ZEROMAP : 0;
		}
		break;
1035 1036 1037 1038 1039 1040 1041 1042
	default:
		ret = -EINVAL;
		break;
	}
	mutex_unlock(&dev->struct_mutex);

	return ret;
}
1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058

int i915_gem_context_reset_stats_ioctl(struct drm_device *dev,
				       void *data, struct drm_file *file)
{
	struct drm_i915_private *dev_priv = dev->dev_private;
	struct drm_i915_reset_stats *args = data;
	struct i915_ctx_hang_stats *hs;
	struct intel_context *ctx;
	int ret;

	if (args->flags || args->pad)
		return -EINVAL;

	if (args->ctx_id == DEFAULT_CONTEXT_HANDLE && !capable(CAP_SYS_ADMIN))
		return -EPERM;

1059
	ret = i915_mutex_lock_interruptible(dev);
1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081
	if (ret)
		return ret;

	ctx = i915_gem_context_get(file->driver_priv, args->ctx_id);
	if (IS_ERR(ctx)) {
		mutex_unlock(&dev->struct_mutex);
		return PTR_ERR(ctx);
	}
	hs = &ctx->hang_stats;

	if (capable(CAP_SYS_ADMIN))
		args->reset_count = i915_reset_count(&dev_priv->gpu_error);
	else
		args->reset_count = 0;

	args->batch_active = hs->batch_active;
	args->batch_pending = hs->batch_pending;

	mutex_unlock(&dev->struct_mutex);

	return 0;
}