i915_dma.c 54.2 KB
Newer Older
L
Linus Torvalds 已提交
1 2
/* i915_dma.c -- DMA support for the I915 -*- linux-c -*-
 */
D
Dave Airlie 已提交
3
/*
L
Linus Torvalds 已提交
4 5
 * Copyright 2003 Tungsten Graphics, Inc., Cedar Park, Texas.
 * All Rights Reserved.
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
 *
 * 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, sub license, 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 NON-INFRINGEMENT.
 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS 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.
 *
D
Dave Airlie 已提交
27
 */
L
Linus Torvalds 已提交
28

29 30
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt

31 32 33
#include <drm/drmP.h>
#include <drm/drm_crtc_helper.h>
#include <drm/drm_fb_helper.h>
J
Jesse Barnes 已提交
34
#include "intel_drv.h"
35
#include <drm/i915_drm.h>
L
Linus Torvalds 已提交
36
#include "i915_drv.h"
C
Chris Wilson 已提交
37
#include "i915_trace.h"
38
#include <linux/pci.h>
39
#include <linux/vgaarb.h>
40 41
#include <linux/acpi.h>
#include <linux/pnp.h>
42
#include <linux/vga_switcheroo.h>
43
#include <linux/slab.h>
44
#include <acpi/video.h>
45 46
#include <linux/pm.h>
#include <linux/pm_runtime.h>
L
Linus Torvalds 已提交
47

48 49 50 51 52 53 54 55 56
#define LP_RING(d) (&((struct drm_i915_private *)(d))->ring[RCS])

#define BEGIN_LP_RING(n) \
	intel_ring_begin(LP_RING(dev_priv), (n))

#define OUT_RING(x) \
	intel_ring_emit(LP_RING(dev_priv), x)

#define ADVANCE_LP_RING() \
57
	__intel_ring_advance(LP_RING(dev_priv))
58 59 60 61 62 63 64 65 66 67 68 69

/**
 * Lock test for when it's just for synchronization of ring access.
 *
 * In that case, we don't need to do it when GEM is initialized as nobody else
 * has access to the ring.
 */
#define RING_LOCK_TEST_WITH_RETURN(dev, file) do {			\
	if (LP_RING(dev->dev_private)->obj == NULL)			\
		LOCK_TEST_WITH_RETURN(dev, file);			\
} while (0)

70 71 72 73 74 75 76 77 78 79
static inline u32
intel_read_legacy_status_page(struct drm_i915_private *dev_priv, int reg)
{
	if (I915_NEED_GFX_HWS(dev_priv->dev))
		return ioread32(dev_priv->dri1.gfx_hws_cpu_addr + reg);
	else
		return intel_read_status_page(LP_RING(dev_priv), reg);
}

#define READ_HWSP(dev_priv, reg) intel_read_legacy_status_page(dev_priv, reg)
80 81 82
#define READ_BREADCRUMB(dev_priv) READ_HWSP(dev_priv, I915_BREADCRUMB_INDEX)
#define I915_BREADCRUMB_INDEX		0x21

83 84 85 86 87
void i915_update_dri1_breadcrumb(struct drm_device *dev)
{
	drm_i915_private_t *dev_priv = dev->dev_private;
	struct drm_i915_master_private *master_priv;

88 89 90 91 92 93 94 95
	/*
	 * The dri breadcrumb update races against the drm master disappearing.
	 * Instead of trying to fix this (this is by far not the only ums issue)
	 * just don't do the update in kms mode.
	 */
	if (drm_core_check_feature(dev, DRIVER_MODESET))
		return;

96 97 98 99 100 101 102 103
	if (dev->primary->master) {
		master_priv = dev->primary->master->driver_priv;
		if (master_priv->sarea_priv)
			master_priv->sarea_priv->last_dispatch =
				READ_BREADCRUMB(dev_priv);
	}
}

104 105 106 107 108 109 110 111 112 113 114
static void i915_write_hws_pga(struct drm_device *dev)
{
	drm_i915_private_t *dev_priv = dev->dev_private;
	u32 addr;

	addr = dev_priv->status_page_dmah->busaddr;
	if (INTEL_INFO(dev)->gen >= 4)
		addr |= (dev_priv->status_page_dmah->busaddr >> 28) & 0xf0;
	I915_WRITE(HWS_PGA, addr);
}

115 116 117 118
/**
 * Frees the hardware status page, whether it's a physical address or a virtual
 * address set up by the X Server.
 */
119
static void i915_free_hws(struct drm_device *dev)
120 121
{
	drm_i915_private_t *dev_priv = dev->dev_private;
122 123
	struct intel_ring_buffer *ring = LP_RING(dev_priv);

124 125 126 127 128
	if (dev_priv->status_page_dmah) {
		drm_pci_free(dev, dev_priv->status_page_dmah);
		dev_priv->status_page_dmah = NULL;
	}

129 130
	if (ring->status_page.gfx_addr) {
		ring->status_page.gfx_addr = 0;
131
		iounmap(dev_priv->dri1.gfx_hws_cpu_addr);
132 133 134 135 136 137
	}

	/* Need to rewrite hardware status page */
	I915_WRITE(HWS_PGA, 0x1ffff000);
}

138
void i915_kernel_lost_context(struct drm_device * dev)
L
Linus Torvalds 已提交
139 140
{
	drm_i915_private_t *dev_priv = dev->dev_private;
141
	struct drm_i915_master_private *master_priv;
142
	struct intel_ring_buffer *ring = LP_RING(dev_priv);
L
Linus Torvalds 已提交
143

J
Jesse Barnes 已提交
144 145 146 147 148 149 150
	/*
	 * We should never lose context on the ring with modesetting
	 * as we don't expose it to userspace
	 */
	if (drm_core_check_feature(dev, DRIVER_MODESET))
		return;

151 152
	ring->head = I915_READ_HEAD(ring) & HEAD_ADDR;
	ring->tail = I915_READ_TAIL(ring) & TAIL_ADDR;
153
	ring->space = ring->head - (ring->tail + I915_RING_FREE_SPACE);
L
Linus Torvalds 已提交
154
	if (ring->space < 0)
155
		ring->space += ring->size;
L
Linus Torvalds 已提交
156

157 158 159 160 161 162
	if (!dev->primary->master)
		return;

	master_priv = dev->primary->master->driver_priv;
	if (ring->head == ring->tail && master_priv->sarea_priv)
		master_priv->sarea_priv->perf_boxes |= I915_BOX_RING_EMPTY;
L
Linus Torvalds 已提交
163 164
}

165
static int i915_dma_cleanup(struct drm_device * dev)
L
Linus Torvalds 已提交
166
{
J
Jesse Barnes 已提交
167
	drm_i915_private_t *dev_priv = dev->dev_private;
168 169
	int i;

L
Linus Torvalds 已提交
170 171 172 173
	/* Make sure interrupts are disabled here because the uninstall ioctl
	 * may not have been called from userspace and after dev_private
	 * is freed, it's too late.
	 */
174
	if (dev->irq_enabled)
D
Dave Airlie 已提交
175
		drm_irq_uninstall(dev);
L
Linus Torvalds 已提交
176

177
	mutex_lock(&dev->struct_mutex);
178 179
	for (i = 0; i < I915_NUM_RINGS; i++)
		intel_cleanup_ring_buffer(&dev_priv->ring[i]);
180
	mutex_unlock(&dev->struct_mutex);
181

182 183 184
	/* Clear the HWS virtual address at teardown */
	if (I915_NEED_GFX_HWS(dev))
		i915_free_hws(dev);
L
Linus Torvalds 已提交
185 186 187 188

	return 0;
}

J
Jesse Barnes 已提交
189
static int i915_initialize(struct drm_device * dev, drm_i915_init_t * init)
L
Linus Torvalds 已提交
190
{
J
Jesse Barnes 已提交
191
	drm_i915_private_t *dev_priv = dev->dev_private;
192
	struct drm_i915_master_private *master_priv = dev->primary->master->driver_priv;
193
	int ret;
L
Linus Torvalds 已提交
194

195 196 197 198 199
	master_priv->sarea = drm_getsarea(dev);
	if (master_priv->sarea) {
		master_priv->sarea_priv = (drm_i915_sarea_t *)
			((u8 *)master_priv->sarea->handle + init->sarea_priv_offset);
	} else {
200
		DRM_DEBUG_DRIVER("sarea not found assuming DRI2 userspace\n");
201 202
	}

203
	if (init->ring_size != 0) {
204
		if (LP_RING(dev_priv)->obj != NULL) {
205 206 207 208 209
			i915_dma_cleanup(dev);
			DRM_ERROR("Client tried to initialize ringbuffer in "
				  "GEM mode\n");
			return -EINVAL;
		}
L
Linus Torvalds 已提交
210

211 212 213 214
		ret = intel_render_ring_init_dri(dev,
						 init->ring_start,
						 init->ring_size);
		if (ret) {
215
			i915_dma_cleanup(dev);
216
			return ret;
217
		}
L
Linus Torvalds 已提交
218 219
	}

220 221 222 223
	dev_priv->dri1.cpp = init->cpp;
	dev_priv->dri1.back_offset = init->back_offset;
	dev_priv->dri1.front_offset = init->front_offset;
	dev_priv->dri1.current_page = 0;
224 225
	if (master_priv->sarea_priv)
		master_priv->sarea_priv->pf_current_page = 0;
L
Linus Torvalds 已提交
226 227 228

	/* Allow hardware batchbuffers unless told otherwise.
	 */
229
	dev_priv->dri1.allow_batchbuffer = 1;
L
Linus Torvalds 已提交
230 231 232 233

	return 0;
}

234
static int i915_dma_resume(struct drm_device * dev)
L
Linus Torvalds 已提交
235 236
{
	drm_i915_private_t *dev_priv = (drm_i915_private_t *) dev->dev_private;
237
	struct intel_ring_buffer *ring = LP_RING(dev_priv);
L
Linus Torvalds 已提交
238

239
	DRM_DEBUG_DRIVER("%s\n", __func__);
L
Linus Torvalds 已提交
240

241
	if (ring->virtual_start == NULL) {
L
Linus Torvalds 已提交
242 243
		DRM_ERROR("can not ioremap virtual address for"
			  " ring buffer\n");
E
Eric Anholt 已提交
244
		return -ENOMEM;
L
Linus Torvalds 已提交
245 246 247
	}

	/* Program Hardware Status Page */
248
	if (!ring->status_page.page_addr) {
L
Linus Torvalds 已提交
249
		DRM_ERROR("Can not find hardware status page\n");
E
Eric Anholt 已提交
250
		return -EINVAL;
L
Linus Torvalds 已提交
251
	}
252
	DRM_DEBUG_DRIVER("hw status page @ %p\n",
253 254
				ring->status_page.page_addr);
	if (ring->status_page.gfx_addr != 0)
255
		intel_ring_setup_status_page(ring);
256
	else
257
		i915_write_hws_pga(dev);
258

259
	DRM_DEBUG_DRIVER("Enabled hardware status page\n");
L
Linus Torvalds 已提交
260 261 262 263

	return 0;
}

264 265
static int i915_dma_init(struct drm_device *dev, void *data,
			 struct drm_file *file_priv)
L
Linus Torvalds 已提交
266
{
267
	drm_i915_init_t *init = data;
L
Linus Torvalds 已提交
268 269
	int retcode = 0;

270 271 272
	if (drm_core_check_feature(dev, DRIVER_MODESET))
		return -ENODEV;

273
	switch (init->func) {
L
Linus Torvalds 已提交
274
	case I915_INIT_DMA:
J
Jesse Barnes 已提交
275
		retcode = i915_initialize(dev, init);
L
Linus Torvalds 已提交
276 277 278 279 280
		break;
	case I915_CLEANUP_DMA:
		retcode = i915_dma_cleanup(dev);
		break;
	case I915_RESUME_DMA:
D
Dave Airlie 已提交
281
		retcode = i915_dma_resume(dev);
L
Linus Torvalds 已提交
282 283
		break;
	default:
E
Eric Anholt 已提交
284
		retcode = -EINVAL;
L
Linus Torvalds 已提交
285 286 287 288 289 290 291 292 293 294 295 296 297 298 299
		break;
	}

	return retcode;
}

/* Implement basically the same security restrictions as hardware does
 * for MI_BATCH_NON_SECURE.  These can be made stricter at any time.
 *
 * Most of the calculations below involve calculating the size of a
 * particular instruction.  It's important to get the size right as
 * that tells us where the next instruction to check is.  Any illegal
 * instruction detected will be given a size of zero, which is a
 * signal to abort the rest of the buffer.
 */
300
static int validate_cmd(int cmd)
L
Linus Torvalds 已提交
301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324
{
	switch (((cmd >> 29) & 0x7)) {
	case 0x0:
		switch ((cmd >> 23) & 0x3f) {
		case 0x0:
			return 1;	/* MI_NOOP */
		case 0x4:
			return 1;	/* MI_FLUSH */
		default:
			return 0;	/* disallow everything else */
		}
		break;
	case 0x1:
		return 0;	/* reserved */
	case 0x2:
		return (cmd & 0xff) + 2;	/* 2d commands */
	case 0x3:
		if (((cmd >> 24) & 0x1f) <= 0x18)
			return 1;

		switch ((cmd >> 24) & 0x1f) {
		case 0x1c:
			return 1;
		case 0x1d:
D
Dave Airlie 已提交
325
			switch ((cmd >> 16) & 0xff) {
L
Linus Torvalds 已提交
326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357
			case 0x3:
				return (cmd & 0x1f) + 2;
			case 0x4:
				return (cmd & 0xf) + 2;
			default:
				return (cmd & 0xffff) + 2;
			}
		case 0x1e:
			if (cmd & (1 << 23))
				return (cmd & 0xffff) + 1;
			else
				return 1;
		case 0x1f:
			if ((cmd & (1 << 23)) == 0)	/* inline vertices */
				return (cmd & 0x1ffff) + 2;
			else if (cmd & (1 << 17))	/* indirect random */
				if ((cmd & 0xffff) == 0)
					return 0;	/* unknown length, too hard */
				else
					return (((cmd & 0xffff) + 1) / 2) + 1;
			else
				return 2;	/* indirect sequential */
		default:
			return 0;
		}
	default:
		return 0;
	}

	return 0;
}

358
static int i915_emit_cmds(struct drm_device * dev, int *buffer, int dwords)
L
Linus Torvalds 已提交
359 360
{
	drm_i915_private_t *dev_priv = dev->dev_private;
361
	int i, ret;
L
Linus Torvalds 已提交
362

363
	if ((dwords+1) * sizeof(int) >= LP_RING(dev_priv)->size - 8)
E
Eric Anholt 已提交
364
		return -EINVAL;
365

L
Linus Torvalds 已提交
366
	for (i = 0; i < dwords;) {
367 368
		int sz = validate_cmd(buffer[i]);
		if (sz == 0 || i + sz > dwords)
E
Eric Anholt 已提交
369
			return -EINVAL;
370
		i += sz;
L
Linus Torvalds 已提交
371 372
	}

373 374 375 376 377 378
	ret = BEGIN_LP_RING((dwords+1)&~1);
	if (ret)
		return ret;

	for (i = 0; i < dwords; i++)
		OUT_RING(buffer[i]);
379 380 381 382 383
	if (dwords & 1)
		OUT_RING(0);

	ADVANCE_LP_RING();

L
Linus Torvalds 已提交
384 385 386
	return 0;
}

387 388
int
i915_emit_box(struct drm_device *dev,
389 390
	      struct drm_clip_rect *box,
	      int DR1, int DR4)
L
Linus Torvalds 已提交
391
{
392 393
	struct drm_i915_private *dev_priv = dev->dev_private;
	int ret;
L
Linus Torvalds 已提交
394

395 396
	if (box->y2 <= box->y1 || box->x2 <= box->x1 ||
	    box->y2 <= 0 || box->x2 <= 0) {
L
Linus Torvalds 已提交
397
		DRM_ERROR("Bad box %d,%d..%d,%d\n",
398
			  box->x1, box->y1, box->x2, box->y2);
E
Eric Anholt 已提交
399
		return -EINVAL;
L
Linus Torvalds 已提交
400 401
	}

402
	if (INTEL_INFO(dev)->gen >= 4) {
403 404 405 406
		ret = BEGIN_LP_RING(4);
		if (ret)
			return ret;

407
		OUT_RING(GFX_OP_DRAWRECT_INFO_I965);
408 409
		OUT_RING((box->x1 & 0xffff) | (box->y1 << 16));
		OUT_RING(((box->x2 - 1) & 0xffff) | ((box->y2 - 1) << 16));
410 411
		OUT_RING(DR4);
	} else {
412 413 414 415
		ret = BEGIN_LP_RING(6);
		if (ret)
			return ret;

416 417
		OUT_RING(GFX_OP_DRAWRECT_INFO);
		OUT_RING(DR1);
418 419
		OUT_RING((box->x1 & 0xffff) | (box->y1 << 16));
		OUT_RING(((box->x2 - 1) & 0xffff) | ((box->y2 - 1) << 16));
420 421 422
		OUT_RING(DR4);
		OUT_RING(0);
	}
423
	ADVANCE_LP_RING();
L
Linus Torvalds 已提交
424 425 426 427

	return 0;
}

428 429 430 431
/* XXX: Emitting the counter should really be moved to part of the IRQ
 * emit. For now, do it in both places:
 */

432
static void i915_emit_breadcrumb(struct drm_device *dev)
433 434
{
	drm_i915_private_t *dev_priv = dev->dev_private;
435
	struct drm_i915_master_private *master_priv = dev->primary->master->driver_priv;
436

437 438 439
	dev_priv->dri1.counter++;
	if (dev_priv->dri1.counter > 0x7FFFFFFFUL)
		dev_priv->dri1.counter = 0;
440
	if (master_priv->sarea_priv)
441
		master_priv->sarea_priv->last_enqueue = dev_priv->dri1.counter;
442

443 444 445
	if (BEGIN_LP_RING(4) == 0) {
		OUT_RING(MI_STORE_DWORD_INDEX);
		OUT_RING(I915_BREADCRUMB_INDEX << MI_STORE_DWORD_INDEX_SHIFT);
446
		OUT_RING(dev_priv->dri1.counter);
447 448 449
		OUT_RING(0);
		ADVANCE_LP_RING();
	}
450 451
}

452
static int i915_dispatch_cmdbuffer(struct drm_device * dev,
453 454 455
				   drm_i915_cmdbuffer_t *cmd,
				   struct drm_clip_rect *cliprects,
				   void *cmdbuf)
L
Linus Torvalds 已提交
456 457 458 459 460 461
{
	int nbox = cmd->num_cliprects;
	int i = 0, count, ret;

	if (cmd->sz & 0x3) {
		DRM_ERROR("alignment");
E
Eric Anholt 已提交
462
		return -EINVAL;
L
Linus Torvalds 已提交
463 464 465 466 467 468 469 470
	}

	i915_kernel_lost_context(dev);

	count = nbox ? nbox : 1;

	for (i = 0; i < count; i++) {
		if (i < nbox) {
471
			ret = i915_emit_box(dev, &cliprects[i],
L
Linus Torvalds 已提交
472 473 474 475 476
					    cmd->DR1, cmd->DR4);
			if (ret)
				return ret;
		}

477
		ret = i915_emit_cmds(dev, cmdbuf, cmd->sz / 4);
L
Linus Torvalds 已提交
478 479 480 481
		if (ret)
			return ret;
	}

482
	i915_emit_breadcrumb(dev);
L
Linus Torvalds 已提交
483 484 485
	return 0;
}

486
static int i915_dispatch_batchbuffer(struct drm_device * dev,
487 488
				     drm_i915_batchbuffer_t * batch,
				     struct drm_clip_rect *cliprects)
L
Linus Torvalds 已提交
489
{
490
	struct drm_i915_private *dev_priv = dev->dev_private;
L
Linus Torvalds 已提交
491
	int nbox = batch->num_cliprects;
492
	int i, count, ret;
L
Linus Torvalds 已提交
493 494 495

	if ((batch->start | batch->used) & 0x7) {
		DRM_ERROR("alignment");
E
Eric Anholt 已提交
496
		return -EINVAL;
L
Linus Torvalds 已提交
497 498 499 500 501 502 503
	}

	i915_kernel_lost_context(dev);

	count = nbox ? nbox : 1;
	for (i = 0; i < count; i++) {
		if (i < nbox) {
504
			ret = i915_emit_box(dev, &cliprects[i],
505
					    batch->DR1, batch->DR4);
L
Linus Torvalds 已提交
506 507 508 509
			if (ret)
				return ret;
		}

510
		if (!IS_I830(dev) && !IS_845G(dev)) {
511 512 513 514
			ret = BEGIN_LP_RING(2);
			if (ret)
				return ret;

515
			if (INTEL_INFO(dev)->gen >= 4) {
516 517 518 519 520 521
				OUT_RING(MI_BATCH_BUFFER_START | (2 << 6) | MI_BATCH_NON_SECURE_I965);
				OUT_RING(batch->start);
			} else {
				OUT_RING(MI_BATCH_BUFFER_START | (2 << 6));
				OUT_RING(batch->start | MI_BATCH_NON_SECURE);
			}
L
Linus Torvalds 已提交
522
		} else {
523 524 525 526
			ret = BEGIN_LP_RING(4);
			if (ret)
				return ret;

L
Linus Torvalds 已提交
527 528 529 530 531
			OUT_RING(MI_BATCH_BUFFER);
			OUT_RING(batch->start | MI_BATCH_NON_SECURE);
			OUT_RING(batch->start + batch->used - 4);
			OUT_RING(0);
		}
532
		ADVANCE_LP_RING();
L
Linus Torvalds 已提交
533 534
	}

535

536
	if (IS_G4X(dev) || IS_GEN5(dev)) {
537 538 539 540 541
		if (BEGIN_LP_RING(2) == 0) {
			OUT_RING(MI_FLUSH | MI_NO_WRITE_FLUSH | MI_INVALIDATE_ISP);
			OUT_RING(MI_NOOP);
			ADVANCE_LP_RING();
		}
542
	}
L
Linus Torvalds 已提交
543

544
	i915_emit_breadcrumb(dev);
L
Linus Torvalds 已提交
545 546 547
	return 0;
}

548
static int i915_dispatch_flip(struct drm_device * dev)
L
Linus Torvalds 已提交
549 550
{
	drm_i915_private_t *dev_priv = dev->dev_private;
551 552
	struct drm_i915_master_private *master_priv =
		dev->primary->master->driver_priv;
553
	int ret;
L
Linus Torvalds 已提交
554

555
	if (!master_priv->sarea_priv)
556 557
		return -EINVAL;

558
	DRM_DEBUG_DRIVER("%s: page=%d pfCurrentPage=%d\n",
559
			  __func__,
560
			 dev_priv->dri1.current_page,
561
			 master_priv->sarea_priv->pf_current_page);
L
Linus Torvalds 已提交
562

563 564
	i915_kernel_lost_context(dev);

565 566 567 568
	ret = BEGIN_LP_RING(10);
	if (ret)
		return ret;

569
	OUT_RING(MI_FLUSH | MI_READ_FLUSH);
570
	OUT_RING(0);
L
Linus Torvalds 已提交
571

572 573
	OUT_RING(CMD_OP_DISPLAYBUFFER_INFO | ASYNC_FLIP);
	OUT_RING(0);
574 575 576
	if (dev_priv->dri1.current_page == 0) {
		OUT_RING(dev_priv->dri1.back_offset);
		dev_priv->dri1.current_page = 1;
L
Linus Torvalds 已提交
577
	} else {
578 579
		OUT_RING(dev_priv->dri1.front_offset);
		dev_priv->dri1.current_page = 0;
L
Linus Torvalds 已提交
580
	}
581
	OUT_RING(0);
L
Linus Torvalds 已提交
582

583 584
	OUT_RING(MI_WAIT_FOR_EVENT | MI_WAIT_FOR_PLANE_A_FLIP);
	OUT_RING(0);
585

586
	ADVANCE_LP_RING();
L
Linus Torvalds 已提交
587

588
	master_priv->sarea_priv->last_enqueue = dev_priv->dri1.counter++;
L
Linus Torvalds 已提交
589

590 591 592
	if (BEGIN_LP_RING(4) == 0) {
		OUT_RING(MI_STORE_DWORD_INDEX);
		OUT_RING(I915_BREADCRUMB_INDEX << MI_STORE_DWORD_INDEX_SHIFT);
593
		OUT_RING(dev_priv->dri1.counter);
594 595 596
		OUT_RING(0);
		ADVANCE_LP_RING();
	}
L
Linus Torvalds 已提交
597

598
	master_priv->sarea_priv->pf_current_page = dev_priv->dri1.current_page;
599
	return 0;
L
Linus Torvalds 已提交
600 601
}

602
static int i915_quiescent(struct drm_device *dev)
L
Linus Torvalds 已提交
603 604
{
	i915_kernel_lost_context(dev);
605
	return intel_ring_idle(LP_RING(dev->dev_private));
L
Linus Torvalds 已提交
606 607
}

608 609
static int i915_flush_ioctl(struct drm_device *dev, void *data,
			    struct drm_file *file_priv)
L
Linus Torvalds 已提交
610
{
611 612
	int ret;

613 614 615
	if (drm_core_check_feature(dev, DRIVER_MODESET))
		return -ENODEV;

616
	RING_LOCK_TEST_WITH_RETURN(dev, file_priv);
L
Linus Torvalds 已提交
617

618 619 620 621 622
	mutex_lock(&dev->struct_mutex);
	ret = i915_quiescent(dev);
	mutex_unlock(&dev->struct_mutex);

	return ret;
L
Linus Torvalds 已提交
623 624
}

625 626
static int i915_batchbuffer(struct drm_device *dev, void *data,
			    struct drm_file *file_priv)
L
Linus Torvalds 已提交
627 628
{
	drm_i915_private_t *dev_priv = (drm_i915_private_t *) dev->dev_private;
629
	struct drm_i915_master_private *master_priv = dev->primary->master->driver_priv;
L
Linus Torvalds 已提交
630
	drm_i915_sarea_t *sarea_priv = (drm_i915_sarea_t *)
631
	    master_priv->sarea_priv;
632
	drm_i915_batchbuffer_t *batch = data;
L
Linus Torvalds 已提交
633
	int ret;
634
	struct drm_clip_rect *cliprects = NULL;
L
Linus Torvalds 已提交
635

636 637 638
	if (drm_core_check_feature(dev, DRIVER_MODESET))
		return -ENODEV;

639
	if (!dev_priv->dri1.allow_batchbuffer) {
L
Linus Torvalds 已提交
640
		DRM_ERROR("Batchbuffer ioctl disabled\n");
E
Eric Anholt 已提交
641
		return -EINVAL;
L
Linus Torvalds 已提交
642 643
	}

644
	DRM_DEBUG_DRIVER("i915 batchbuffer, start %x used %d cliprects %d\n",
645
			batch->start, batch->used, batch->num_cliprects);
L
Linus Torvalds 已提交
646

647
	RING_LOCK_TEST_WITH_RETURN(dev, file_priv);
L
Linus Torvalds 已提交
648

649 650 651 652
	if (batch->num_cliprects < 0)
		return -EINVAL;

	if (batch->num_cliprects) {
653
		cliprects = kcalloc(batch->num_cliprects,
654
				    sizeof(*cliprects),
655
				    GFP_KERNEL);
656 657 658 659 660 661
		if (cliprects == NULL)
			return -ENOMEM;

		ret = copy_from_user(cliprects, batch->cliprects,
				     batch->num_cliprects *
				     sizeof(struct drm_clip_rect));
662 663
		if (ret != 0) {
			ret = -EFAULT;
664
			goto fail_free;
665
		}
666
	}
L
Linus Torvalds 已提交
667

668
	mutex_lock(&dev->struct_mutex);
669
	ret = i915_dispatch_batchbuffer(dev, batch, cliprects);
670
	mutex_unlock(&dev->struct_mutex);
L
Linus Torvalds 已提交
671

672
	if (sarea_priv)
673
		sarea_priv->last_dispatch = READ_BREADCRUMB(dev_priv);
674 675

fail_free:
676
	kfree(cliprects);
677

L
Linus Torvalds 已提交
678 679 680
	return ret;
}

681 682
static int i915_cmdbuffer(struct drm_device *dev, void *data,
			  struct drm_file *file_priv)
L
Linus Torvalds 已提交
683 684
{
	drm_i915_private_t *dev_priv = (drm_i915_private_t *) dev->dev_private;
685
	struct drm_i915_master_private *master_priv = dev->primary->master->driver_priv;
L
Linus Torvalds 已提交
686
	drm_i915_sarea_t *sarea_priv = (drm_i915_sarea_t *)
687
	    master_priv->sarea_priv;
688
	drm_i915_cmdbuffer_t *cmdbuf = data;
689 690
	struct drm_clip_rect *cliprects = NULL;
	void *batch_data;
L
Linus Torvalds 已提交
691 692
	int ret;

693
	DRM_DEBUG_DRIVER("i915 cmdbuffer, buf %p sz %d cliprects %d\n",
694
			cmdbuf->buf, cmdbuf->sz, cmdbuf->num_cliprects);
L
Linus Torvalds 已提交
695

696 697 698
	if (drm_core_check_feature(dev, DRIVER_MODESET))
		return -ENODEV;

699
	RING_LOCK_TEST_WITH_RETURN(dev, file_priv);
L
Linus Torvalds 已提交
700

701 702 703
	if (cmdbuf->num_cliprects < 0)
		return -EINVAL;

704
	batch_data = kmalloc(cmdbuf->sz, GFP_KERNEL);
705 706 707 708
	if (batch_data == NULL)
		return -ENOMEM;

	ret = copy_from_user(batch_data, cmdbuf->buf, cmdbuf->sz);
709 710
	if (ret != 0) {
		ret = -EFAULT;
711
		goto fail_batch_free;
712
	}
713 714

	if (cmdbuf->num_cliprects) {
715
		cliprects = kcalloc(cmdbuf->num_cliprects,
716
				    sizeof(*cliprects), GFP_KERNEL);
717 718
		if (cliprects == NULL) {
			ret = -ENOMEM;
719
			goto fail_batch_free;
720
		}
721 722 723 724

		ret = copy_from_user(cliprects, cmdbuf->cliprects,
				     cmdbuf->num_cliprects *
				     sizeof(struct drm_clip_rect));
725 726
		if (ret != 0) {
			ret = -EFAULT;
727
			goto fail_clip_free;
728
		}
L
Linus Torvalds 已提交
729 730
	}

731
	mutex_lock(&dev->struct_mutex);
732
	ret = i915_dispatch_cmdbuffer(dev, cmdbuf, cliprects, batch_data);
733
	mutex_unlock(&dev->struct_mutex);
L
Linus Torvalds 已提交
734 735
	if (ret) {
		DRM_ERROR("i915_dispatch_cmdbuffer failed\n");
736
		goto fail_clip_free;
L
Linus Torvalds 已提交
737 738
	}

739
	if (sarea_priv)
740
		sarea_priv->last_dispatch = READ_BREADCRUMB(dev_priv);
741 742

fail_clip_free:
743
	kfree(cliprects);
744
fail_batch_free:
745
	kfree(batch_data);
746 747

	return ret;
L
Linus Torvalds 已提交
748 749
}

750 751 752 753 754 755 756 757 758
static int i915_emit_irq(struct drm_device * dev)
{
	drm_i915_private_t *dev_priv = dev->dev_private;
	struct drm_i915_master_private *master_priv = dev->primary->master->driver_priv;

	i915_kernel_lost_context(dev);

	DRM_DEBUG_DRIVER("\n");

759 760 761
	dev_priv->dri1.counter++;
	if (dev_priv->dri1.counter > 0x7FFFFFFFUL)
		dev_priv->dri1.counter = 1;
762
	if (master_priv->sarea_priv)
763
		master_priv->sarea_priv->last_enqueue = dev_priv->dri1.counter;
764 765 766 767

	if (BEGIN_LP_RING(4) == 0) {
		OUT_RING(MI_STORE_DWORD_INDEX);
		OUT_RING(I915_BREADCRUMB_INDEX << MI_STORE_DWORD_INDEX_SHIFT);
768
		OUT_RING(dev_priv->dri1.counter);
769 770 771 772
		OUT_RING(MI_USER_INTERRUPT);
		ADVANCE_LP_RING();
	}

773
	return dev_priv->dri1.counter;
774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795
}

static int i915_wait_irq(struct drm_device * dev, int irq_nr)
{
	drm_i915_private_t *dev_priv = (drm_i915_private_t *) dev->dev_private;
	struct drm_i915_master_private *master_priv = dev->primary->master->driver_priv;
	int ret = 0;
	struct intel_ring_buffer *ring = LP_RING(dev_priv);

	DRM_DEBUG_DRIVER("irq_nr=%d breadcrumb=%d\n", irq_nr,
		  READ_BREADCRUMB(dev_priv));

	if (READ_BREADCRUMB(dev_priv) >= irq_nr) {
		if (master_priv->sarea_priv)
			master_priv->sarea_priv->last_dispatch = READ_BREADCRUMB(dev_priv);
		return 0;
	}

	if (master_priv->sarea_priv)
		master_priv->sarea_priv->perf_boxes |= I915_BOX_WAIT;

	if (ring->irq_get(ring)) {
D
Daniel Vetter 已提交
796
		DRM_WAIT_ON(ret, ring->irq_queue, 3 * HZ,
797 798 799 800 801 802 803
			    READ_BREADCRUMB(dev_priv) >= irq_nr);
		ring->irq_put(ring);
	} else if (wait_for(READ_BREADCRUMB(dev_priv) >= irq_nr, 3000))
		ret = -EBUSY;

	if (ret == -EBUSY) {
		DRM_ERROR("EBUSY -- rec: %d emitted: %d\n",
804
			  READ_BREADCRUMB(dev_priv), (int)dev_priv->dri1.counter);
805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832
	}

	return ret;
}

/* Needs the lock as it touches the ring.
 */
static int i915_irq_emit(struct drm_device *dev, void *data,
			 struct drm_file *file_priv)
{
	drm_i915_private_t *dev_priv = dev->dev_private;
	drm_i915_irq_emit_t *emit = data;
	int result;

	if (drm_core_check_feature(dev, DRIVER_MODESET))
		return -ENODEV;

	if (!dev_priv || !LP_RING(dev_priv)->virtual_start) {
		DRM_ERROR("called with no initialization\n");
		return -EINVAL;
	}

	RING_LOCK_TEST_WITH_RETURN(dev, file_priv);

	mutex_lock(&dev->struct_mutex);
	result = i915_emit_irq(dev);
	mutex_unlock(&dev->struct_mutex);

D
Daniel Vetter 已提交
833
	if (copy_to_user(emit->irq_seq, &result, sizeof(int))) {
834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859
		DRM_ERROR("copy_to_user\n");
		return -EFAULT;
	}

	return 0;
}

/* Doesn't need the hardware lock.
 */
static int i915_irq_wait(struct drm_device *dev, void *data,
			 struct drm_file *file_priv)
{
	drm_i915_private_t *dev_priv = dev->dev_private;
	drm_i915_irq_wait_t *irqwait = data;

	if (drm_core_check_feature(dev, DRIVER_MODESET))
		return -ENODEV;

	if (!dev_priv) {
		DRM_ERROR("called with no initialization\n");
		return -EINVAL;
	}

	return i915_wait_irq(dev, irqwait->irq_seq);
}

860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901
static int i915_vblank_pipe_get(struct drm_device *dev, void *data,
			 struct drm_file *file_priv)
{
	drm_i915_private_t *dev_priv = dev->dev_private;
	drm_i915_vblank_pipe_t *pipe = data;

	if (drm_core_check_feature(dev, DRIVER_MODESET))
		return -ENODEV;

	if (!dev_priv) {
		DRM_ERROR("called with no initialization\n");
		return -EINVAL;
	}

	pipe->pipe = DRM_I915_VBLANK_PIPE_A | DRM_I915_VBLANK_PIPE_B;

	return 0;
}

/**
 * Schedule buffer swap at given vertical blank.
 */
static int i915_vblank_swap(struct drm_device *dev, void *data,
		     struct drm_file *file_priv)
{
	/* The delayed swap mechanism was fundamentally racy, and has been
	 * removed.  The model was that the client requested a delayed flip/swap
	 * from the kernel, then waited for vblank before continuing to perform
	 * rendering.  The problem was that the kernel might wake the client
	 * up before it dispatched the vblank swap (since the lock has to be
	 * held while touching the ringbuffer), in which case the client would
	 * clear and start the next frame before the swap occurred, and
	 * flicker would occur in addition to likely missing the vblank.
	 *
	 * In the absence of this ioctl, userland falls back to a correct path
	 * of waiting for a vblank, then dispatching the swap on its own.
	 * Context switching to userland and back is plenty fast enough for
	 * meeting the requirements of vblank swapping.
	 */
	return -EINVAL;
}

902 903
static int i915_flip_bufs(struct drm_device *dev, void *data,
			  struct drm_file *file_priv)
L
Linus Torvalds 已提交
904
{
905 906
	int ret;

907 908 909
	if (drm_core_check_feature(dev, DRIVER_MODESET))
		return -ENODEV;

910
	DRM_DEBUG_DRIVER("%s\n", __func__);
L
Linus Torvalds 已提交
911

912
	RING_LOCK_TEST_WITH_RETURN(dev, file_priv);
L
Linus Torvalds 已提交
913

914 915 916 917 918
	mutex_lock(&dev->struct_mutex);
	ret = i915_dispatch_flip(dev);
	mutex_unlock(&dev->struct_mutex);

	return ret;
L
Linus Torvalds 已提交
919 920
}

921 922
static int i915_getparam(struct drm_device *dev, void *data,
			 struct drm_file *file_priv)
L
Linus Torvalds 已提交
923 924
{
	drm_i915_private_t *dev_priv = dev->dev_private;
925
	drm_i915_getparam_t *param = data;
L
Linus Torvalds 已提交
926 927 928
	int value;

	if (!dev_priv) {
929
		DRM_ERROR("called with no initialization\n");
E
Eric Anholt 已提交
930
		return -EINVAL;
L
Linus Torvalds 已提交
931 932
	}

933
	switch (param->param) {
L
Linus Torvalds 已提交
934
	case I915_PARAM_IRQ_ACTIVE:
935
		value = dev->pdev->irq ? 1 : 0;
L
Linus Torvalds 已提交
936 937
		break;
	case I915_PARAM_ALLOW_BATCHBUFFER:
938
		value = dev_priv->dri1.allow_batchbuffer ? 1 : 0;
L
Linus Torvalds 已提交
939
		break;
D
Dave Airlie 已提交
940 941 942
	case I915_PARAM_LAST_DISPATCH:
		value = READ_BREADCRUMB(dev_priv);
		break;
K
Kristian Høgsberg 已提交
943
	case I915_PARAM_CHIPSET_ID:
944
		value = dev->pdev->device;
K
Kristian Høgsberg 已提交
945
		break;
946
	case I915_PARAM_HAS_GEM:
947
		value = 1;
948
		break;
949 950 951
	case I915_PARAM_NUM_FENCES_AVAIL:
		value = dev_priv->num_fence_regs - dev_priv->fence_reg_start;
		break;
952 953 954
	case I915_PARAM_HAS_OVERLAY:
		value = dev_priv->overlay ? 1 : 0;
		break;
955 956 957
	case I915_PARAM_HAS_PAGEFLIPPING:
		value = 1;
		break;
J
Jesse Barnes 已提交
958 959
	case I915_PARAM_HAS_EXECBUF2:
		/* depends on GEM */
960
		value = 1;
J
Jesse Barnes 已提交
961
		break;
962
	case I915_PARAM_HAS_BSD:
963
		value = intel_ring_initialized(&dev_priv->ring[VCS]);
964
		break;
965
	case I915_PARAM_HAS_BLT:
966
		value = intel_ring_initialized(&dev_priv->ring[BCS]);
967
		break;
968 969 970
	case I915_PARAM_HAS_VEBOX:
		value = intel_ring_initialized(&dev_priv->ring[VECS]);
		break;
971 972 973
	case I915_PARAM_HAS_RELAXED_FENCING:
		value = 1;
		break;
974 975 976
	case I915_PARAM_HAS_COHERENT_RINGS:
		value = 1;
		break;
977 978 979
	case I915_PARAM_HAS_EXEC_CONSTANTS:
		value = INTEL_INFO(dev)->gen >= 4;
		break;
980 981 982
	case I915_PARAM_HAS_RELAXED_DELTA:
		value = 1;
		break;
983 984 985
	case I915_PARAM_HAS_GEN7_SOL_RESET:
		value = 1;
		break;
986 987 988
	case I915_PARAM_HAS_LLC:
		value = HAS_LLC(dev);
		break;
989 990 991
	case I915_PARAM_HAS_WT:
		value = HAS_WT(dev);
		break;
992
	case I915_PARAM_HAS_ALIASING_PPGTT:
993
		value = dev_priv->mm.aliasing_ppgtt || USES_FULL_PPGTT(dev);
994
		break;
995 996 997
	case I915_PARAM_HAS_WAIT_TIMEOUT:
		value = 1;
		break;
998 999 1000
	case I915_PARAM_HAS_SEMAPHORES:
		value = i915_semaphore_is_enabled(dev);
		break;
1001 1002 1003
	case I915_PARAM_HAS_PRIME_VMAP_FLUSH:
		value = 1;
		break;
1004 1005 1006
	case I915_PARAM_HAS_SECURE_BATCHES:
		value = capable(CAP_SYS_ADMIN);
		break;
1007 1008 1009
	case I915_PARAM_HAS_PINNED_BATCHES:
		value = 1;
		break;
1010 1011 1012
	case I915_PARAM_HAS_EXEC_NO_RELOC:
		value = 1;
		break;
1013 1014 1015
	case I915_PARAM_HAS_EXEC_HANDLE_LUT:
		value = 1;
		break;
L
Linus Torvalds 已提交
1016
	default:
1017
		DRM_DEBUG("Unknown parameter %d\n", param->param);
E
Eric Anholt 已提交
1018
		return -EINVAL;
L
Linus Torvalds 已提交
1019 1020
	}

D
Daniel Vetter 已提交
1021 1022
	if (copy_to_user(param->value, &value, sizeof(int))) {
		DRM_ERROR("copy_to_user failed\n");
E
Eric Anholt 已提交
1023
		return -EFAULT;
L
Linus Torvalds 已提交
1024 1025 1026 1027 1028
	}

	return 0;
}

1029 1030
static int i915_setparam(struct drm_device *dev, void *data,
			 struct drm_file *file_priv)
L
Linus Torvalds 已提交
1031 1032
{
	drm_i915_private_t *dev_priv = dev->dev_private;
1033
	drm_i915_setparam_t *param = data;
L
Linus Torvalds 已提交
1034 1035

	if (!dev_priv) {
1036
		DRM_ERROR("called with no initialization\n");
E
Eric Anholt 已提交
1037
		return -EINVAL;
L
Linus Torvalds 已提交
1038 1039
	}

1040
	switch (param->param) {
L
Linus Torvalds 已提交
1041 1042 1043 1044 1045
	case I915_SETPARAM_USE_MI_BATCHBUFFER_START:
		break;
	case I915_SETPARAM_TEX_LRU_LOG_GRANULARITY:
		break;
	case I915_SETPARAM_ALLOW_BATCHBUFFER:
1046
		dev_priv->dri1.allow_batchbuffer = param->value ? 1 : 0;
L
Linus Torvalds 已提交
1047
		break;
1048 1049 1050 1051 1052 1053 1054
	case I915_SETPARAM_NUM_USED_FENCES:
		if (param->value > dev_priv->num_fence_regs ||
		    param->value < 0)
			return -EINVAL;
		/* Userspace can use first N regs */
		dev_priv->fence_reg_start = param->value;
		break;
L
Linus Torvalds 已提交
1055
	default:
1056
		DRM_DEBUG_DRIVER("unknown parameter %d\n",
1057
					param->param);
E
Eric Anholt 已提交
1058
		return -EINVAL;
L
Linus Torvalds 已提交
1059 1060 1061 1062 1063
	}

	return 0;
}

1064 1065
static int i915_set_status_page(struct drm_device *dev, void *data,
				struct drm_file *file_priv)
1066 1067
{
	drm_i915_private_t *dev_priv = dev->dev_private;
1068
	drm_i915_hws_addr_t *hws = data;
1069
	struct intel_ring_buffer *ring;
1070

1071 1072 1073
	if (drm_core_check_feature(dev, DRIVER_MODESET))
		return -ENODEV;

1074 1075
	if (!I915_NEED_GFX_HWS(dev))
		return -EINVAL;
1076 1077

	if (!dev_priv) {
1078
		DRM_ERROR("called with no initialization\n");
E
Eric Anholt 已提交
1079
		return -EINVAL;
1080 1081
	}

J
Jesse Barnes 已提交
1082 1083 1084 1085 1086
	if (drm_core_check_feature(dev, DRIVER_MODESET)) {
		WARN(1, "tried to set status page when mode setting active\n");
		return 0;
	}

1087
	DRM_DEBUG_DRIVER("set status page addr 0x%08x\n", (u32)hws->addr);
1088

1089
	ring = LP_RING(dev_priv);
1090
	ring->status_page.gfx_addr = hws->addr & (0x1ffff<<12);
1091

1092
	dev_priv->dri1.gfx_hws_cpu_addr =
B
Ben Widawsky 已提交
1093
		ioremap_wc(dev_priv->gtt.mappable_base + hws->addr, 4096);
1094
	if (dev_priv->dri1.gfx_hws_cpu_addr == NULL) {
1095
		i915_dma_cleanup(dev);
1096
		ring->status_page.gfx_addr = 0;
1097 1098
		DRM_ERROR("can not ioremap virtual address for"
				" G33 hw status page\n");
E
Eric Anholt 已提交
1099
		return -ENOMEM;
1100
	}
1101 1102

	memset_io(dev_priv->dri1.gfx_hws_cpu_addr, 0, PAGE_SIZE);
1103
	I915_WRITE(HWS_PGA, ring->status_page.gfx_addr);
1104

1105
	DRM_DEBUG_DRIVER("load hws HWS_PGA with gfx mem 0x%x\n",
1106
			 ring->status_page.gfx_addr);
1107
	DRM_DEBUG_DRIVER("load hws at %p\n",
1108
			 ring->status_page.page_addr);
1109 1110 1111
	return 0;
}

1112 1113 1114 1115
static int i915_get_bridge_dev(struct drm_device *dev)
{
	struct drm_i915_private *dev_priv = dev->dev_private;

1116
	dev_priv->bridge_dev = pci_get_bus_and_slot(0, PCI_DEVFN(0, 0));
1117 1118 1119 1120 1121 1122 1123
	if (!dev_priv->bridge_dev) {
		DRM_ERROR("bridge device not found\n");
		return -1;
	}
	return 0;
}

1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135
#define MCHBAR_I915 0x44
#define MCHBAR_I965 0x48
#define MCHBAR_SIZE (4*4096)

#define DEVEN_REG 0x54
#define   DEVEN_MCHBAR_EN (1 << 28)

/* Allocate space for the MCH regs if needed, return nonzero on error */
static int
intel_alloc_mchbar_resource(struct drm_device *dev)
{
	drm_i915_private_t *dev_priv = dev->dev_private;
1136
	int reg = INTEL_INFO(dev)->gen >= 4 ? MCHBAR_I965 : MCHBAR_I915;
1137 1138
	u32 temp_lo, temp_hi = 0;
	u64 mchbar_addr;
1139
	int ret;
1140

1141
	if (INTEL_INFO(dev)->gen >= 4)
1142 1143 1144 1145 1146 1147 1148
		pci_read_config_dword(dev_priv->bridge_dev, reg + 4, &temp_hi);
	pci_read_config_dword(dev_priv->bridge_dev, reg, &temp_lo);
	mchbar_addr = ((u64)temp_hi << 32) | temp_lo;

	/* If ACPI doesn't have it, assume we need to allocate it ourselves */
#ifdef CONFIG_PNP
	if (mchbar_addr &&
1149 1150
	    pnp_range_reserved(mchbar_addr, mchbar_addr + MCHBAR_SIZE))
		return 0;
1151 1152 1153
#endif

	/* Get some space for it */
1154 1155 1156 1157
	dev_priv->mch_res.name = "i915 MCHBAR";
	dev_priv->mch_res.flags = IORESOURCE_MEM;
	ret = pci_bus_alloc_resource(dev_priv->bridge_dev->bus,
				     &dev_priv->mch_res,
1158 1159
				     MCHBAR_SIZE, MCHBAR_SIZE,
				     PCIBIOS_MIN_MEM,
1160
				     0, pcibios_align_resource,
1161 1162 1163 1164
				     dev_priv->bridge_dev);
	if (ret) {
		DRM_DEBUG_DRIVER("failed bus alloc: %d\n", ret);
		dev_priv->mch_res.start = 0;
1165
		return ret;
1166 1167
	}

1168
	if (INTEL_INFO(dev)->gen >= 4)
1169 1170 1171 1172 1173
		pci_write_config_dword(dev_priv->bridge_dev, reg + 4,
				       upper_32_bits(dev_priv->mch_res.start));

	pci_write_config_dword(dev_priv->bridge_dev, reg,
			       lower_32_bits(dev_priv->mch_res.start));
1174
	return 0;
1175 1176 1177 1178 1179 1180 1181
}

/* Setup MCHBAR if possible, return true if we should disable it again */
static void
intel_setup_mchbar(struct drm_device *dev)
{
	drm_i915_private_t *dev_priv = dev->dev_private;
1182
	int mchbar_reg = INTEL_INFO(dev)->gen >= 4 ? MCHBAR_I965 : MCHBAR_I915;
1183 1184 1185 1186 1187 1188 1189 1190 1191 1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214 1215 1216 1217 1218
	u32 temp;
	bool enabled;

	dev_priv->mchbar_need_disable = false;

	if (IS_I915G(dev) || IS_I915GM(dev)) {
		pci_read_config_dword(dev_priv->bridge_dev, DEVEN_REG, &temp);
		enabled = !!(temp & DEVEN_MCHBAR_EN);
	} else {
		pci_read_config_dword(dev_priv->bridge_dev, mchbar_reg, &temp);
		enabled = temp & 1;
	}

	/* If it's already enabled, don't have to do anything */
	if (enabled)
		return;

	if (intel_alloc_mchbar_resource(dev))
		return;

	dev_priv->mchbar_need_disable = true;

	/* Space is allocated or reserved, so enable it. */
	if (IS_I915G(dev) || IS_I915GM(dev)) {
		pci_write_config_dword(dev_priv->bridge_dev, DEVEN_REG,
				       temp | DEVEN_MCHBAR_EN);
	} else {
		pci_read_config_dword(dev_priv->bridge_dev, mchbar_reg, &temp);
		pci_write_config_dword(dev_priv->bridge_dev, mchbar_reg, temp | 1);
	}
}

static void
intel_teardown_mchbar(struct drm_device *dev)
{
	drm_i915_private_t *dev_priv = dev->dev_private;
1219
	int mchbar_reg = INTEL_INFO(dev)->gen >= 4 ? MCHBAR_I965 : MCHBAR_I915;
1220 1221 1222 1223 1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237
	u32 temp;

	if (dev_priv->mchbar_need_disable) {
		if (IS_I915G(dev) || IS_I915GM(dev)) {
			pci_read_config_dword(dev_priv->bridge_dev, DEVEN_REG, &temp);
			temp &= ~DEVEN_MCHBAR_EN;
			pci_write_config_dword(dev_priv->bridge_dev, DEVEN_REG, temp);
		} else {
			pci_read_config_dword(dev_priv->bridge_dev, mchbar_reg, &temp);
			temp &= ~1;
			pci_write_config_dword(dev_priv->bridge_dev, mchbar_reg, temp);
		}
	}

	if (dev_priv->mch_res.start)
		release_resource(&dev_priv->mch_res);
}

1238 1239 1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250
/* true = enable decode, false = disable decoder */
static unsigned int i915_vga_set_decode(void *cookie, bool state)
{
	struct drm_device *dev = cookie;

	intel_modeset_vga_set_state(dev, state);
	if (state)
		return VGA_RSRC_LEGACY_IO | VGA_RSRC_LEGACY_MEM |
		       VGA_RSRC_NORMAL_IO | VGA_RSRC_NORMAL_MEM;
	else
		return VGA_RSRC_NORMAL_IO | VGA_RSRC_NORMAL_MEM;
}

1251 1252 1253 1254 1255
static void i915_switcheroo_set_state(struct pci_dev *pdev, enum vga_switcheroo_state state)
{
	struct drm_device *dev = pci_get_drvdata(pdev);
	pm_message_t pmm = { .event = PM_EVENT_SUSPEND };
	if (state == VGA_SWITCHEROO_ON) {
1256
		pr_info("switched on\n");
1257
		dev->switch_power_state = DRM_SWITCH_POWER_CHANGING;
1258 1259 1260
		/* i915 resume handler doesn't set to D0 */
		pci_set_power_state(dev->pdev, PCI_D0);
		i915_resume(dev);
1261
		dev->switch_power_state = DRM_SWITCH_POWER_ON;
1262
	} else {
1263
		pr_err("switched off\n");
1264
		dev->switch_power_state = DRM_SWITCH_POWER_CHANGING;
1265
		i915_suspend(dev, pmm);
1266
		dev->switch_power_state = DRM_SWITCH_POWER_OFF;
1267 1268 1269 1270 1271 1272 1273 1274 1275 1276 1277 1278 1279 1280
	}
}

static bool i915_switcheroo_can_switch(struct pci_dev *pdev)
{
	struct drm_device *dev = pci_get_drvdata(pdev);
	bool can_switch;

	spin_lock(&dev->count_lock);
	can_switch = (dev->open_count == 0);
	spin_unlock(&dev->count_lock);
	return can_switch;
}

1281 1282 1283 1284 1285 1286
static const struct vga_switcheroo_client_ops i915_switcheroo_ops = {
	.set_gpu_state = i915_switcheroo_set_state,
	.reprobe = NULL,
	.can_switch = i915_switcheroo_can_switch,
};

1287 1288 1289 1290
static int i915_load_modeset_init(struct drm_device *dev)
{
	struct drm_i915_private *dev_priv = dev->dev_private;
	int ret;
J
Jesse Barnes 已提交
1291

1292
	ret = intel_parse_bios(dev);
J
Jesse Barnes 已提交
1293 1294 1295
	if (ret)
		DRM_INFO("failed to find VBIOS tables\n");

1296 1297 1298 1299 1300 1301 1302
	/* If we have > 1 VGA cards, then we need to arbitrate access
	 * to the common VGA resources.
	 *
	 * If we are a secondary display controller (!PCI_DISPLAY_CLASS_VGA),
	 * then we do not take part in VGA arbitration and the
	 * vga_client_register() fails with -ENODEV.
	 */
1303 1304 1305
	ret = vga_client_register(dev->pdev, dev, NULL, i915_vga_set_decode);
	if (ret && ret != -ENODEV)
		goto out;
1306

J
Jesse Barnes 已提交
1307 1308
	intel_register_dsm_handler();

1309
	ret = vga_switcheroo_register_client(dev->pdev, &i915_switcheroo_ops, false);
1310
	if (ret)
1311
		goto cleanup_vga_client;
1312

1313 1314 1315 1316 1317 1318 1319
	/* Initialise stolen first so that we may reserve preallocated
	 * objects for the BIOS to KMS transition.
	 */
	ret = i915_gem_init_stolen(dev);
	if (ret)
		goto cleanup_vga_switcheroo;

1320 1321 1322 1323
	ret = drm_irq_install(dev);
	if (ret)
		goto cleanup_gem_stolen;

1324
	intel_power_domains_init_hw(dev);
1325

1326 1327
	/* Important: The output setup functions called by modeset_init need
	 * working irqs for e.g. gmbus and dp aux transfers. */
1328 1329
	intel_modeset_init(dev);

1330
	ret = i915_gem_init(dev);
J
Jesse Barnes 已提交
1331
	if (ret)
1332
		goto cleanup_power;
1333

1334 1335
	INIT_WORK(&dev_priv->console_resume_work, intel_console_resume);

1336
	intel_modeset_gem_init(dev);
1337

J
Jesse Barnes 已提交
1338 1339
	/* Always safe in the mode setting case. */
	/* FIXME: do pre/post-mode set stuff in core KMS code */
1340
	dev->vblank_disable_allowed = true;
1341 1342
	if (INTEL_INFO(dev)->num_pipes == 0) {
		intel_display_power_put(dev, POWER_DOMAIN_VGA);
B
Ben Widawsky 已提交
1343
		return 0;
1344
	}
J
Jesse Barnes 已提交
1345

1346 1347
	ret = intel_fbdev_init(dev);
	if (ret)
1348 1349
		goto cleanup_gem;

1350 1351 1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362 1363 1364
	/* Only enable hotplug handling once the fbdev is fully set up. */
	intel_hpd_init(dev);

	/*
	 * Some ports require correctly set-up hpd registers for detection to
	 * work properly (leading to ghost connected connector status), e.g. VGA
	 * on gm45.  Hence we can only set up the initial fbdev config after hpd
	 * irqs are fully enabled. Now we should scan for the initial config
	 * only once hotplug handling is enabled, but due to screwed-up locking
	 * around kms/fbdev init we can't protect the fdbev initial config
	 * scanning against hotplug events. Hence do this first and ignore the
	 * tiny window where we will loose hotplug notifactions.
	 */
	intel_fbdev_initial_config(dev);

1365 1366
	/* Only enable hotplug handling once the fbdev is fully set up. */
	dev_priv->enable_hotplug_processing = true;
1367

1368
	drm_kms_helper_poll_init(dev);
1369

J
Jesse Barnes 已提交
1370 1371
	return 0;

1372 1373 1374
cleanup_gem:
	mutex_lock(&dev->struct_mutex);
	i915_gem_cleanup_ringbuffer(dev);
1375
	i915_gem_context_fini(dev);
1376
	mutex_unlock(&dev->struct_mutex);
1377
	WARN_ON(dev_priv->mm.aliasing_ppgtt);
1378
	drm_mm_takedown(&dev_priv->gtt.base.mm);
1379 1380
cleanup_power:
	intel_display_power_put(dev, POWER_DOMAIN_VGA);
1381
	drm_irq_uninstall(dev);
1382 1383
cleanup_gem_stolen:
	i915_gem_cleanup_stolen(dev);
1384 1385 1386 1387
cleanup_vga_switcheroo:
	vga_switcheroo_unregister_client(dev->pdev);
cleanup_vga_client:
	vga_client_register(dev->pdev, NULL, NULL, NULL);
J
Jesse Barnes 已提交
1388 1389 1390 1391
out:
	return ret;
}

1392 1393 1394 1395
int i915_master_create(struct drm_device *dev, struct drm_master *master)
{
	struct drm_i915_master_private *master_priv;

1396
	master_priv = kzalloc(sizeof(*master_priv), GFP_KERNEL);
1397 1398 1399 1400 1401 1402 1403 1404 1405 1406 1407 1408 1409 1410
	if (!master_priv)
		return -ENOMEM;

	master->driver_priv = master_priv;
	return 0;
}

void i915_master_destroy(struct drm_device *dev, struct drm_master *master)
{
	struct drm_i915_master_private *master_priv = master->driver_priv;

	if (!master_priv)
		return;

1411
	kfree(master_priv);
1412 1413 1414 1415

	master->driver_priv = NULL;
}

1416
#if IS_ENABLED(CONFIG_FB)
1417 1418 1419 1420 1421 1422 1423 1424 1425 1426
static void i915_kick_out_firmware_fb(struct drm_i915_private *dev_priv)
{
	struct apertures_struct *ap;
	struct pci_dev *pdev = dev_priv->dev->pdev;
	bool primary;

	ap = alloc_apertures(1);
	if (!ap)
		return;

1427
	ap->ranges[0].base = dev_priv->gtt.mappable_base;
1428
	ap->ranges[0].size = dev_priv->gtt.mappable_end;
1429

1430 1431 1432 1433 1434 1435 1436
	primary =
		pdev->resource[PCI_ROM_RESOURCE].flags & IORESOURCE_ROM_SHADOW;

	remove_conflicting_framebuffers(ap, "inteldrmfb", primary);

	kfree(ap);
}
1437 1438 1439 1440 1441
#else
static void i915_kick_out_firmware_fb(struct drm_i915_private *dev_priv)
{
}
#endif
1442

D
Daniel Vetter 已提交
1443 1444
static void i915_dump_device_info(struct drm_i915_private *dev_priv)
{
1445
	const struct intel_device_info *info = &dev_priv->info;
D
Daniel Vetter 已提交
1446

1447 1448
#define PRINT_S(name) "%s"
#define SEP_EMPTY
1449 1450
#define PRINT_FLAG(name) info->name ? #name "," : ""
#define SEP_COMMA ,
D
Daniel Vetter 已提交
1451
	DRM_DEBUG_DRIVER("i915 device info: gen=%i, pciid=0x%04x flags="
1452
			 DEV_INFO_FOR_EACH_FLAG(PRINT_S, SEP_EMPTY),
D
Daniel Vetter 已提交
1453 1454
			 info->gen,
			 dev_priv->dev->pdev->device,
1455
			 DEV_INFO_FOR_EACH_FLAG(PRINT_FLAG, SEP_COMMA));
1456 1457
#undef PRINT_S
#undef SEP_EMPTY
1458 1459
#undef PRINT_FLAG
#undef SEP_COMMA
D
Daniel Vetter 已提交
1460 1461
}

1462 1463 1464 1465 1466 1467 1468
/*
 * Determine various intel_device_info fields at runtime.
 *
 * Use it when either:
 *   - it's judged too laborious to fill n static structures with the limit
 *     when a simple if statement does the job,
 *   - run-time checks (eg read fuse/strap registers) are needed.
1469 1470 1471 1472 1473
 *
 * This function needs to be called:
 *   - after the MMIO has been setup as we are reading registers,
 *   - after the PCH has been detected,
 *   - before the first usage of the fields it can tweak.
1474 1475 1476
 */
static void intel_device_info_runtime_init(struct drm_device *dev)
{
1477
	struct drm_i915_private *dev_priv = dev->dev_private;
1478 1479
	struct intel_device_info *info;

1480
	info = (struct intel_device_info *)&dev_priv->info;
1481 1482 1483 1484

	info->num_sprites = 1;
	if (IS_VALLEYVIEW(dev))
		info->num_sprites = 2;
1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508

	if (info->num_pipes > 0 &&
	    (INTEL_INFO(dev)->gen == 7 || INTEL_INFO(dev)->gen == 8) &&
	    !IS_VALLEYVIEW(dev)) {
		u32 fuse_strap = I915_READ(FUSE_STRAP);
		u32 sfuse_strap = I915_READ(SFUSE_STRAP);

		/*
		 * SFUSE_STRAP is supposed to have a bit signalling the display
		 * is fused off. Unfortunately it seems that, at least in
		 * certain cases, fused off display means that PCH display
		 * reads don't land anywhere. In that case, we read 0s.
		 *
		 * On CPT/PPT, we can detect this case as SFUSE_STRAP_FUSE_LOCK
		 * should be set when taking over after the firmware.
		 */
		if (fuse_strap & ILK_INTERNAL_DISPLAY_DISABLE ||
		    sfuse_strap & SFUSE_STRAP_DISPLAY_DISABLED ||
		    (dev_priv->pch_type == PCH_CPT &&
		     !(sfuse_strap & SFUSE_STRAP_FUSE_LOCK))) {
			DRM_INFO("Display fused off, disabling\n");
			info->num_pipes = 0;
		}
	}
1509 1510
}

J
Jesse Barnes 已提交
1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521
/**
 * i915_driver_load - setup chip and create an initial config
 * @dev: DRM device
 * @flags: startup flags
 *
 * The driver load routine has to do several things:
 *   - drive output discovery via intel_modeset_init()
 *   - initialize the memory manager
 *   - allocate initial config memory
 *   - setup the DRM framebuffer with the allocated memory
 */
1522
int i915_driver_load(struct drm_device *dev, unsigned long flags)
1523
{
1524
	struct drm_i915_private *dev_priv;
1525
	struct intel_device_info *info, *device_info;
1526
	int ret = 0, mmio_bar, mmio_size;
1527
	uint32_t aperture_size;
1528

1529 1530 1531
	info = (struct intel_device_info *) flags;

	/* Refuse to load on gen6+ without kms enabled. */
1532 1533 1534
	if (info->gen >= 6 && !drm_core_check_feature(dev, DRIVER_MODESET)) {
		DRM_INFO("Your hardware requires kernel modesetting (KMS)\n");
		DRM_INFO("See CONFIG_DRM_I915_KMS, nomodeset, and i915.modeset parameters\n");
1535
		return -ENODEV;
1536
	}
1537

D
Daniel Vetter 已提交
1538 1539 1540 1541
	/* UMS needs agp support. */
	if (!drm_core_check_feature(dev, DRIVER_MODESET) && !dev->agp)
		return -EINVAL;

1542
	dev_priv = kzalloc(sizeof(*dev_priv), GFP_KERNEL);
J
Jesse Barnes 已提交
1543 1544 1545 1546
	if (dev_priv == NULL)
		return -ENOMEM;

	dev->dev_private = (void *)dev_priv;
1547
	dev_priv->dev = dev;
1548 1549 1550 1551

	/* copy initial configuration to dev_priv->info */
	device_info = (struct intel_device_info *)&dev_priv->info;
	*device_info = *info;
J
Jesse Barnes 已提交
1552

1553 1554
	spin_lock_init(&dev_priv->irq_lock);
	spin_lock_init(&dev_priv->gpu_error.lock);
1555
	spin_lock_init(&dev_priv->backlight_lock);
1556
	spin_lock_init(&dev_priv->uncore.lock);
1557
	spin_lock_init(&dev_priv->mm.object_stat_lock);
1558 1559 1560
	mutex_init(&dev_priv->dpio_lock);
	mutex_init(&dev_priv->modeset_restore_lock);

D
Daniel Vetter 已提交
1561
	intel_pm_setup(dev);
1562

1563 1564
	intel_display_crc_init(dev);

D
Daniel Vetter 已提交
1565 1566
	i915_dump_device_info(dev_priv);

1567 1568 1569 1570 1571 1572 1573 1574
	/* Not all pre-production machines fall into this category, only the
	 * very first ones. Almost everything should work, except for maybe
	 * suspend/resume. And we don't implement workarounds that affect only
	 * pre-production machines. */
	if (IS_HSW_EARLY_SDV(dev))
		DRM_INFO("This is an early pre-production Haswell machine. "
			 "It may not be fully functional.\n");

1575 1576 1577 1578 1579
	if (i915_get_bridge_dev(dev)) {
		ret = -EIO;
		goto free_priv;
	}

1580 1581 1582 1583 1584 1585 1586 1587 1588 1589 1590 1591 1592 1593 1594 1595 1596 1597 1598 1599
	mmio_bar = IS_GEN2(dev) ? 1 : 0;
	/* Before gen4, the registers and the GTT are behind different BARs.
	 * However, from gen4 onwards, the registers and the GTT are shared
	 * in the same BAR, so we want to restrict this ioremap from
	 * clobbering the GTT which we want ioremap_wc instead. Fortunately,
	 * the register BAR remains the same size for all the earlier
	 * generations up to Ironlake.
	 */
	if (info->gen < 5)
		mmio_size = 512*1024;
	else
		mmio_size = 2*1024*1024;

	dev_priv->regs = pci_iomap(dev->pdev, mmio_bar, mmio_size);
	if (!dev_priv->regs) {
		DRM_ERROR("failed to map registers\n");
		ret = -EIO;
		goto put_bridge;
	}

1600
	intel_uncore_early_sanitize(dev);
1601

1602 1603 1604 1605 1606
	/* This must be called before any calls to HAS_PCH_* */
	intel_detect_pch(dev);

	intel_uncore_init(dev);

1607 1608
	ret = i915_gem_gtt_init(dev);
	if (ret)
1609
		goto out_regs;
1610

1611 1612
	if (drm_core_check_feature(dev, DRIVER_MODESET))
		i915_kick_out_firmware_fb(dev_priv);
1613

1614 1615
	pci_set_master(dev->pdev);

1616 1617 1618 1619
	/* overlay on gen2 is broken and can't address above 1G */
	if (IS_GEN2(dev))
		dma_set_coherent_mask(&dev->pdev->dev, DMA_BIT_MASK(30));

1620 1621 1622 1623 1624 1625 1626 1627 1628 1629 1630
	/* 965GM sometimes incorrectly writes to hardware status page (HWS)
	 * using 32bit addressing, overwriting memory if HWS is located
	 * above 4GB.
	 *
	 * The documentation also mentions an issue with undefined
	 * behaviour if any general state is accessed within a page above 4GB,
	 * which also needs to be handled carefully.
	 */
	if (IS_BROADWATER(dev) || IS_CRESTLINE(dev))
		dma_set_coherent_mask(&dev->pdev->dev, DMA_BIT_MASK(32));

1631
	aperture_size = dev_priv->gtt.mappable_end;
1632

B
Ben Widawsky 已提交
1633 1634
	dev_priv->gtt.mappable =
		io_mapping_create_wc(dev_priv->gtt.mappable_base,
1635
				     aperture_size);
B
Ben Widawsky 已提交
1636
	if (dev_priv->gtt.mappable == NULL) {
1637
		ret = -EIO;
1638
		goto out_gtt;
1639 1640
	}

1641 1642
	dev_priv->gtt.mtrr = arch_phys_wc_add(dev_priv->gtt.mappable_base,
					      aperture_size);
1643

1644 1645 1646 1647 1648 1649 1650
	/* The i915 workqueue is primarily used for batched retirement of
	 * requests (and thus managing bo) once the task has been completed
	 * by the GPU. i915_gem_retire_requests() is called directly when we
	 * need high-priority retirement, such as waiting for an explicit
	 * bo.
	 *
	 * It is also used for periodic low-priority events, such as
1651
	 * idle-timers and recording error state.
1652 1653 1654
	 *
	 * All tasks on the workqueue are expected to acquire the dev mutex
	 * so there is no point in running more than one instance of the
1655
	 * workqueue at any time.  Use an ordered one.
1656
	 */
1657
	dev_priv->wq = alloc_ordered_workqueue("i915", 0);
1658 1659 1660
	if (dev_priv->wq == NULL) {
		DRM_ERROR("Failed to create our workqueue.\n");
		ret = -ENOMEM;
1661
		goto out_mtrrfree;
1662 1663
	}

1664
	intel_irq_init(dev);
1665
	intel_uncore_sanitize(dev);
1666

1667 1668
	/* Try to make sure MCHBAR is enabled before poking at it */
	intel_setup_mchbar(dev);
1669
	intel_setup_gmbus(dev);
1670
	intel_opregion_setup(dev);
1671

1672 1673
	intel_setup_bios(dev);

1674 1675
	i915_gem_load(dev);

1676 1677 1678 1679 1680 1681
	/* On the 945G/GM, the chipset reports the MSI capability on the
	 * integrated graphics even though the support isn't actually there
	 * according to the published specs.  It doesn't appear to function
	 * correctly in testing on 945G.
	 * This may be a side effect of MSI having been made available for PEG
	 * and the registers being closely associated.
1682 1683
	 *
	 * According to chipset errata, on the 965GM, MSI interrupts may
1684 1685
	 * be lost or delayed, but we use them anyways to avoid
	 * stuck interrupts on some machines.
1686
	 */
1687
	if (!IS_I945G(dev) && !IS_I945GM(dev))
1688
		pci_enable_msi(dev->pdev);
1689

1690
	intel_device_info_runtime_init(dev);
1691

B
Ben Widawsky 已提交
1692 1693 1694 1695 1696
	if (INTEL_INFO(dev)->num_pipes) {
		ret = drm_vblank_init(dev, INTEL_INFO(dev)->num_pipes);
		if (ret)
			goto out_gem_unload;
	}
1697

1698
	intel_power_domains_init(dev);
1699

J
Jesse Barnes 已提交
1700
	if (drm_core_check_feature(dev, DRIVER_MODESET)) {
D
Daniel Vetter 已提交
1701
		ret = i915_load_modeset_init(dev);
J
Jesse Barnes 已提交
1702 1703
		if (ret < 0) {
			DRM_ERROR("failed to init modeset\n");
1704
			goto out_power_well;
J
Jesse Barnes 已提交
1705
		}
1706 1707 1708
	} else {
		/* Start out suspended in ums mode. */
		dev_priv->ums.mm_suspended = 1;
J
Jesse Barnes 已提交
1709 1710
	}

B
Ben Widawsky 已提交
1711 1712
	i915_setup_sysfs(dev);

B
Ben Widawsky 已提交
1713 1714 1715
	if (INTEL_INFO(dev)->num_pipes) {
		/* Must be done after probing outputs */
		intel_opregion_init(dev);
1716
		acpi_video_register();
B
Ben Widawsky 已提交
1717
	}
1718

1719 1720
	if (IS_GEN5(dev))
		intel_gpu_ips_init(dev_priv);
1721

1722 1723
	intel_init_runtime_pm(dev_priv);

J
Jesse Barnes 已提交
1724 1725
	return 0;

1726
out_power_well:
1727
	intel_power_domains_remove(dev);
1728
	drm_vblank_cleanup(dev);
1729
out_gem_unload:
1730
	if (dev_priv->mm.inactive_shrinker.scan_objects)
1731 1732
		unregister_shrinker(&dev_priv->mm.inactive_shrinker);

1733 1734 1735 1736 1737
	if (dev->pdev->msi_enabled)
		pci_disable_msi(dev->pdev);

	intel_teardown_gmbus(dev);
	intel_teardown_mchbar(dev);
1738
	pm_qos_remove_request(&dev_priv->pm_qos);
1739
	destroy_workqueue(dev_priv->wq);
1740
out_mtrrfree:
1741
	arch_phys_wc_del(dev_priv->gtt.mtrr);
B
Ben Widawsky 已提交
1742
	io_mapping_free(dev_priv->gtt.mappable);
1743 1744 1745
out_gtt:
	list_del(&dev_priv->gtt.base.global_link);
	drm_mm_takedown(&dev_priv->gtt.base.mm);
1746
	dev_priv->gtt.base.cleanup(&dev_priv->gtt.base);
1747
out_regs:
1748
	intel_uncore_fini(dev);
1749
	pci_iounmap(dev->pdev, dev_priv->regs);
1750 1751
put_bridge:
	pci_dev_put(dev_priv->bridge_dev);
J
Jesse Barnes 已提交
1752
free_priv:
1753 1754
	if (dev_priv->slab)
		kmem_cache_destroy(dev_priv->slab);
1755
	kfree(dev_priv);
J
Jesse Barnes 已提交
1756 1757 1758 1759 1760 1761
	return ret;
}

int i915_driver_unload(struct drm_device *dev)
{
	struct drm_i915_private *dev_priv = dev->dev_private;
1762
	int ret;
J
Jesse Barnes 已提交
1763

1764 1765 1766 1767 1768 1769
	ret = i915_gem_suspend(dev);
	if (ret) {
		DRM_ERROR("failed to idle hardware: %d\n", ret);
		return ret;
	}

1770 1771
	intel_fini_runtime_pm(dev_priv);

1772
	intel_gpu_ips_teardown();
1773

1774 1775 1776 1777 1778
	/* The i915.ko module is still not prepared to be loaded when
	 * the power well is not enabled, so just enable it in case
	 * we're going to unload/reload. */
	intel_display_set_init_power(dev, true);
	intel_power_domains_remove(dev);
1779

B
Ben Widawsky 已提交
1780 1781
	i915_teardown_sysfs(dev);

1782
	if (dev_priv->mm.inactive_shrinker.scan_objects)
1783 1784
		unregister_shrinker(&dev_priv->mm.inactive_shrinker);

B
Ben Widawsky 已提交
1785
	io_mapping_free(dev_priv->gtt.mappable);
1786
	arch_phys_wc_del(dev_priv->gtt.mtrr);
1787

1788 1789
	acpi_video_unregister();

J
Jesse Barnes 已提交
1790
	if (drm_core_check_feature(dev, DRIVER_MODESET)) {
1791
		intel_fbdev_fini(dev);
1792
		intel_modeset_cleanup(dev);
1793
		cancel_work_sync(&dev_priv->console_resume_work);
1794

Z
Zhao Yakui 已提交
1795 1796 1797 1798
		/*
		 * free the memory space allocated for the child device
		 * config parsed from VBT
		 */
1799 1800 1801 1802
		if (dev_priv->vbt.child_dev && dev_priv->vbt.child_dev_num) {
			kfree(dev_priv->vbt.child_dev);
			dev_priv->vbt.child_dev = NULL;
			dev_priv->vbt.child_dev_num = 0;
Z
Zhao Yakui 已提交
1803
		}
1804

1805
		vga_switcheroo_unregister_client(dev->pdev);
1806
		vga_client_register(dev->pdev, NULL, NULL, NULL);
J
Jesse Barnes 已提交
1807 1808
	}

1809
	/* Free error state after interrupts are fully disabled. */
1810 1811
	del_timer_sync(&dev_priv->gpu_error.hangcheck_timer);
	cancel_work_sync(&dev_priv->gpu_error.work);
1812
	i915_destroy_error_state(dev);
1813

1814 1815
	cancel_delayed_work_sync(&dev_priv->pc8.enable_work);

1816 1817 1818
	if (dev->pdev->msi_enabled)
		pci_disable_msi(dev->pdev);

1819
	intel_opregion_fini(dev);
1820

J
Jesse Barnes 已提交
1821
	if (drm_core_check_feature(dev, DRIVER_MODESET)) {
1822 1823 1824
		/* Flush any outstanding unpin_work. */
		flush_workqueue(dev_priv->wq);

J
Jesse Barnes 已提交
1825
		mutex_lock(&dev->struct_mutex);
1826
		i915_gem_free_all_phys_object(dev);
J
Jesse Barnes 已提交
1827
		i915_gem_cleanup_ringbuffer(dev);
1828
		i915_gem_context_fini(dev);
1829
		WARN_ON(dev_priv->mm.aliasing_ppgtt);
J
Jesse Barnes 已提交
1830
		mutex_unlock(&dev->struct_mutex);
1831
		i915_gem_cleanup_stolen(dev);
1832 1833 1834

		if (!I915_NEED_GFX_HWS(dev))
			i915_free_hws(dev);
J
Jesse Barnes 已提交
1835 1836
	}

1837 1838
	list_del(&dev_priv->gtt.base.global_link);
	WARN_ON(!list_empty(&dev_priv->vm_list));
D
Daniel Vetter 已提交
1839

1840 1841
	drm_vblank_cleanup(dev);

1842
	intel_teardown_gmbus(dev);
1843 1844
	intel_teardown_mchbar(dev);

1845
	destroy_workqueue(dev_priv->wq);
1846
	pm_qos_remove_request(&dev_priv->pm_qos);
1847

1848
	dev_priv->gtt.base.cleanup(&dev_priv->gtt.base);
1849

1850 1851 1852 1853
	intel_uncore_fini(dev);
	if (dev_priv->regs != NULL)
		pci_iounmap(dev->pdev, dev_priv->regs);

1854 1855
	if (dev_priv->slab)
		kmem_cache_destroy(dev_priv->slab);
1856

1857
	pci_dev_put(dev_priv->bridge_dev);
1858
	kfree(dev->dev_private);
J
Jesse Barnes 已提交
1859

1860 1861 1862
	return 0;
}

1863
int i915_driver_open(struct drm_device *dev, struct drm_file *file)
1864
{
1865
	int ret;
1866

1867 1868 1869
	ret = i915_gem_open(dev, file);
	if (ret)
		return ret;
1870

1871 1872 1873
	return 0;
}

J
Jesse Barnes 已提交
1874 1875 1876 1877 1878 1879 1880 1881
/**
 * i915_driver_lastclose - clean up after all DRM clients have exited
 * @dev: DRM device
 *
 * Take care of cleaning up after all DRM clients have exited.  In the
 * mode setting case, we want to restore the kernel's initial mode (just
 * in case the last client left us in a bad state).
 *
1882
 * Additionally, in the non-mode setting case, we'll tear down the GTT
J
Jesse Barnes 已提交
1883 1884 1885
 * and DMA structures, since the kernel won't be using them, and clea
 * up any GEM state.
 */
1886
void i915_driver_lastclose(struct drm_device * dev)
L
Linus Torvalds 已提交
1887
{
J
Jesse Barnes 已提交
1888 1889
	drm_i915_private_t *dev_priv = dev->dev_private;

1890 1891 1892 1893 1894 1895 1896
	/* On gen6+ we refuse to init without kms enabled, but then the drm core
	 * goes right around and calls lastclose. Check for this and don't clean
	 * up anything. */
	if (!dev_priv)
		return;

	if (drm_core_check_feature(dev, DRIVER_MODESET)) {
1897
		intel_fbdev_restore_mode(dev);
1898
		vga_switcheroo_process_delayed_switch();
D
Dave Airlie 已提交
1899
		return;
J
Jesse Barnes 已提交
1900
	}
D
Dave Airlie 已提交
1901

1902 1903
	i915_gem_lastclose(dev);

D
Dave Airlie 已提交
1904
	i915_dma_cleanup(dev);
L
Linus Torvalds 已提交
1905 1906
}

1907
void i915_driver_preclose(struct drm_device * dev, struct drm_file *file_priv)
L
Linus Torvalds 已提交
1908
{
1909
	mutex_lock(&dev->struct_mutex);
1910
	i915_gem_context_close(dev, file_priv);
1911
	i915_gem_release(dev, file_priv);
1912
	mutex_unlock(&dev->struct_mutex);
L
Linus Torvalds 已提交
1913 1914
}

1915
void i915_driver_postclose(struct drm_device *dev, struct drm_file *file)
1916
{
1917
	struct drm_i915_file_private *file_priv = file->driver_priv;
1918

1919
	kfree(file_priv);
1920 1921
}

R
Rob Clark 已提交
1922
const struct drm_ioctl_desc i915_ioctls[] = {
1923 1924 1925 1926 1927 1928
	DRM_IOCTL_DEF_DRV(I915_INIT, i915_dma_init, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
	DRM_IOCTL_DEF_DRV(I915_FLUSH, i915_flush_ioctl, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_FLIP, i915_flip_bufs, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_BATCHBUFFER, i915_batchbuffer, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_IRQ_EMIT, i915_irq_emit, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_IRQ_WAIT, i915_irq_wait, DRM_AUTH),
1929
	DRM_IOCTL_DEF_DRV(I915_GETPARAM, i915_getparam, DRM_AUTH|DRM_RENDER_ALLOW),
1930
	DRM_IOCTL_DEF_DRV(I915_SETPARAM, i915_setparam, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
D
Daniel Vetter 已提交
1931 1932 1933
	DRM_IOCTL_DEF_DRV(I915_ALLOC, drm_noop, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_FREE, drm_noop, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_INIT_HEAP, drm_noop, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
1934
	DRM_IOCTL_DEF_DRV(I915_CMDBUFFER, i915_cmdbuffer, DRM_AUTH),
D
Daniel Vetter 已提交
1935
	DRM_IOCTL_DEF_DRV(I915_DESTROY_HEAP,  drm_noop, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
1936
	DRM_IOCTL_DEF_DRV(I915_SET_VBLANK_PIPE,  drm_noop, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
1937 1938 1939 1940 1941
	DRM_IOCTL_DEF_DRV(I915_GET_VBLANK_PIPE,  i915_vblank_pipe_get, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_VBLANK_SWAP, i915_vblank_swap, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_HWS_ADDR, i915_set_status_page, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
	DRM_IOCTL_DEF_DRV(I915_GEM_INIT, i915_gem_init_ioctl, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY|DRM_UNLOCKED),
	DRM_IOCTL_DEF_DRV(I915_GEM_EXECBUFFER, i915_gem_execbuffer, DRM_AUTH|DRM_UNLOCKED),
1942
	DRM_IOCTL_DEF_DRV(I915_GEM_EXECBUFFER2, i915_gem_execbuffer2, DRM_AUTH|DRM_UNLOCKED|DRM_RENDER_ALLOW),
1943 1944
	DRM_IOCTL_DEF_DRV(I915_GEM_PIN, i915_gem_pin_ioctl, DRM_AUTH|DRM_ROOT_ONLY|DRM_UNLOCKED),
	DRM_IOCTL_DEF_DRV(I915_GEM_UNPIN, i915_gem_unpin_ioctl, DRM_AUTH|DRM_ROOT_ONLY|DRM_UNLOCKED),
1945 1946 1947 1948
	DRM_IOCTL_DEF_DRV(I915_GEM_BUSY, i915_gem_busy_ioctl, DRM_AUTH|DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_SET_CACHING, i915_gem_set_caching_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_GET_CACHING, i915_gem_get_caching_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_THROTTLE, i915_gem_throttle_ioctl, DRM_AUTH|DRM_UNLOCKED|DRM_RENDER_ALLOW),
1949 1950
	DRM_IOCTL_DEF_DRV(I915_GEM_ENTERVT, i915_gem_entervt_ioctl, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY|DRM_UNLOCKED),
	DRM_IOCTL_DEF_DRV(I915_GEM_LEAVEVT, i915_gem_leavevt_ioctl, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY|DRM_UNLOCKED),
1951 1952 1953 1954 1955 1956 1957 1958 1959 1960
	DRM_IOCTL_DEF_DRV(I915_GEM_CREATE, i915_gem_create_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_PREAD, i915_gem_pread_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_PWRITE, i915_gem_pwrite_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_MMAP, i915_gem_mmap_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_MMAP_GTT, i915_gem_mmap_gtt_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_SET_DOMAIN, i915_gem_set_domain_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_SW_FINISH, i915_gem_sw_finish_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_SET_TILING, i915_gem_set_tiling, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_GET_TILING, i915_gem_get_tiling, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_GET_APERTURE, i915_gem_get_aperture_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
1961
	DRM_IOCTL_DEF_DRV(I915_GET_PIPE_FROM_CRTC_ID, intel_get_pipe_from_crtc_id, DRM_UNLOCKED),
1962
	DRM_IOCTL_DEF_DRV(I915_GEM_MADVISE, i915_gem_madvise_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
1963 1964
	DRM_IOCTL_DEF_DRV(I915_OVERLAY_PUT_IMAGE, intel_overlay_put_image, DRM_MASTER|DRM_CONTROL_ALLOW|DRM_UNLOCKED),
	DRM_IOCTL_DEF_DRV(I915_OVERLAY_ATTRS, intel_overlay_attrs, DRM_MASTER|DRM_CONTROL_ALLOW|DRM_UNLOCKED),
1965 1966
	DRM_IOCTL_DEF_DRV(I915_SET_SPRITE_COLORKEY, intel_sprite_set_colorkey, DRM_MASTER|DRM_CONTROL_ALLOW|DRM_UNLOCKED),
	DRM_IOCTL_DEF_DRV(I915_GET_SPRITE_COLORKEY, intel_sprite_get_colorkey, DRM_MASTER|DRM_CONTROL_ALLOW|DRM_UNLOCKED),
1967 1968 1969 1970
	DRM_IOCTL_DEF_DRV(I915_GEM_WAIT, i915_gem_wait_ioctl, DRM_AUTH|DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_CONTEXT_CREATE, i915_gem_context_create_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_GEM_CONTEXT_DESTROY, i915_gem_context_destroy_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(I915_REG_READ, i915_reg_read_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
1971
	DRM_IOCTL_DEF_DRV(I915_GET_RESET_STATS, i915_get_reset_stats_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
D
Dave Airlie 已提交
1972 1973 1974
};

int i915_max_ioctl = DRM_ARRAY_SIZE(i915_ioctls);
1975

1976 1977 1978 1979
/*
 * This is really ugly: Because old userspace abused the linux agp interface to
 * manage the gtt, we need to claim that all intel devices are agp.  For
 * otherwise the drm core refuses to initialize the agp support code.
1980
 */
1981
int i915_driver_device_is_agp(struct drm_device * dev)
1982 1983 1984
{
	return 1;
}