i915_dma.c 32.0 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
#include <linux/async.h>
32 33 34
#include <drm/drmP.h>
#include <drm/drm_crtc_helper.h>
#include <drm/drm_fb_helper.h>
35
#include <drm/drm_legacy.h>
J
Jesse Barnes 已提交
36
#include "intel_drv.h"
37
#include <drm/i915_drm.h>
L
Linus Torvalds 已提交
38
#include "i915_drv.h"
C
Chris Wilson 已提交
39
#include "i915_trace.h"
40
#include <linux/pci.h>
D
Daniel Vetter 已提交
41 42
#include <linux/console.h>
#include <linux/vt.h>
43
#include <linux/vgaarb.h>
44 45
#include <linux/acpi.h>
#include <linux/pnp.h>
46
#include <linux/vga_switcheroo.h>
47
#include <linux/slab.h>
48
#include <acpi/video.h>
49 50
#include <linux/pm.h>
#include <linux/pm_runtime.h>
51
#include <linux/oom.h>
L
Linus Torvalds 已提交
52 53


54 55
static int i915_getparam(struct drm_device *dev, void *data,
			 struct drm_file *file_priv)
L
Linus Torvalds 已提交
56
{
57
	struct drm_i915_private *dev_priv = dev->dev_private;
58
	drm_i915_getparam_t *param = data;
L
Linus Torvalds 已提交
59 60
	int value;

61
	switch (param->param) {
L
Linus Torvalds 已提交
62 63
	case I915_PARAM_IRQ_ACTIVE:
	case I915_PARAM_ALLOW_BATCHBUFFER:
D
Dave Airlie 已提交
64
	case I915_PARAM_LAST_DISPATCH:
65
		/* Reject all old ums/dri params. */
66
		return -ENODEV;
K
Kristian Høgsberg 已提交
67
	case I915_PARAM_CHIPSET_ID:
68
		value = dev->pdev->device;
K
Kristian Høgsberg 已提交
69
		break;
70
	case I915_PARAM_HAS_GEM:
71
		value = 1;
72
		break;
73 74 75
	case I915_PARAM_NUM_FENCES_AVAIL:
		value = dev_priv->num_fence_regs - dev_priv->fence_reg_start;
		break;
76 77 78
	case I915_PARAM_HAS_OVERLAY:
		value = dev_priv->overlay ? 1 : 0;
		break;
79 80 81
	case I915_PARAM_HAS_PAGEFLIPPING:
		value = 1;
		break;
J
Jesse Barnes 已提交
82 83
	case I915_PARAM_HAS_EXECBUF2:
		/* depends on GEM */
84
		value = 1;
J
Jesse Barnes 已提交
85
		break;
86
	case I915_PARAM_HAS_BSD:
87
		value = intel_ring_initialized(&dev_priv->ring[VCS]);
88
		break;
89
	case I915_PARAM_HAS_BLT:
90
		value = intel_ring_initialized(&dev_priv->ring[BCS]);
91
		break;
92 93 94
	case I915_PARAM_HAS_VEBOX:
		value = intel_ring_initialized(&dev_priv->ring[VECS]);
		break;
95 96 97
	case I915_PARAM_HAS_RELAXED_FENCING:
		value = 1;
		break;
98 99 100
	case I915_PARAM_HAS_COHERENT_RINGS:
		value = 1;
		break;
101 102 103
	case I915_PARAM_HAS_EXEC_CONSTANTS:
		value = INTEL_INFO(dev)->gen >= 4;
		break;
104 105 106
	case I915_PARAM_HAS_RELAXED_DELTA:
		value = 1;
		break;
107 108 109
	case I915_PARAM_HAS_GEN7_SOL_RESET:
		value = 1;
		break;
110 111 112
	case I915_PARAM_HAS_LLC:
		value = HAS_LLC(dev);
		break;
113 114 115
	case I915_PARAM_HAS_WT:
		value = HAS_WT(dev);
		break;
116
	case I915_PARAM_HAS_ALIASING_PPGTT:
117
		value = USES_PPGTT(dev);
118
		break;
119 120 121
	case I915_PARAM_HAS_WAIT_TIMEOUT:
		value = 1;
		break;
122 123 124
	case I915_PARAM_HAS_SEMAPHORES:
		value = i915_semaphore_is_enabled(dev);
		break;
125 126 127
	case I915_PARAM_HAS_PRIME_VMAP_FLUSH:
		value = 1;
		break;
128 129 130
	case I915_PARAM_HAS_SECURE_BATCHES:
		value = capable(CAP_SYS_ADMIN);
		break;
131 132 133
	case I915_PARAM_HAS_PINNED_BATCHES:
		value = 1;
		break;
134 135 136
	case I915_PARAM_HAS_EXEC_NO_RELOC:
		value = 1;
		break;
137 138 139
	case I915_PARAM_HAS_EXEC_HANDLE_LUT:
		value = 1;
		break;
140 141 142
	case I915_PARAM_CMD_PARSER_VERSION:
		value = i915_cmd_parser_get_version();
		break;
143 144
	case I915_PARAM_HAS_COHERENT_PHYS_GTT:
		value = 1;
145 146 147
		break;
	case I915_PARAM_MMAP_VERSION:
		value = 1;
148
		break;
L
Linus Torvalds 已提交
149
	default:
150
		DRM_DEBUG("Unknown parameter %d\n", param->param);
E
Eric Anholt 已提交
151
		return -EINVAL;
L
Linus Torvalds 已提交
152 153
	}

D
Daniel Vetter 已提交
154 155
	if (copy_to_user(param->value, &value, sizeof(int))) {
		DRM_ERROR("copy_to_user failed\n");
E
Eric Anholt 已提交
156
		return -EFAULT;
L
Linus Torvalds 已提交
157 158 159 160 161
	}

	return 0;
}

162 163
static int i915_setparam(struct drm_device *dev, void *data,
			 struct drm_file *file_priv)
L
Linus Torvalds 已提交
164
{
165
	struct drm_i915_private *dev_priv = dev->dev_private;
166
	drm_i915_setparam_t *param = data;
L
Linus Torvalds 已提交
167

168
	switch (param->param) {
L
Linus Torvalds 已提交
169 170 171
	case I915_SETPARAM_USE_MI_BATCHBUFFER_START:
	case I915_SETPARAM_TEX_LRU_LOG_GRANULARITY:
	case I915_SETPARAM_ALLOW_BATCHBUFFER:
172
		/* Reject all old ums/dri params. */
173 174
		return -ENODEV;

175 176 177 178 179 180 181
	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 已提交
182
	default:
183
		DRM_DEBUG_DRIVER("unknown parameter %d\n",
184
					param->param);
E
Eric Anholt 已提交
185
		return -EINVAL;
L
Linus Torvalds 已提交
186 187 188 189 190
	}

	return 0;
}

191 192 193 194
static int i915_get_bridge_dev(struct drm_device *dev)
{
	struct drm_i915_private *dev_priv = dev->dev_private;

195
	dev_priv->bridge_dev = pci_get_bus_and_slot(0, PCI_DEVFN(0, 0));
196 197 198 199 200 201 202
	if (!dev_priv->bridge_dev) {
		DRM_ERROR("bridge device not found\n");
		return -1;
	}
	return 0;
}

203 204 205 206 207 208 209 210 211 212 213
#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)
{
214
	struct drm_i915_private *dev_priv = dev->dev_private;
215
	int reg = INTEL_INFO(dev)->gen >= 4 ? MCHBAR_I965 : MCHBAR_I915;
216 217
	u32 temp_lo, temp_hi = 0;
	u64 mchbar_addr;
218
	int ret;
219

220
	if (INTEL_INFO(dev)->gen >= 4)
221 222 223 224 225 226 227
		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 &&
228 229
	    pnp_range_reserved(mchbar_addr, mchbar_addr + MCHBAR_SIZE))
		return 0;
230 231 232
#endif

	/* Get some space for it */
233 234 235 236
	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,
237 238
				     MCHBAR_SIZE, MCHBAR_SIZE,
				     PCIBIOS_MIN_MEM,
239
				     0, pcibios_align_resource,
240 241 242 243
				     dev_priv->bridge_dev);
	if (ret) {
		DRM_DEBUG_DRIVER("failed bus alloc: %d\n", ret);
		dev_priv->mch_res.start = 0;
244
		return ret;
245 246
	}

247
	if (INTEL_INFO(dev)->gen >= 4)
248 249 250 251 252
		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));
253
	return 0;
254 255 256 257 258 259
}

/* Setup MCHBAR if possible, return true if we should disable it again */
static void
intel_setup_mchbar(struct drm_device *dev)
{
260
	struct drm_i915_private *dev_priv = dev->dev_private;
261
	int mchbar_reg = INTEL_INFO(dev)->gen >= 4 ? MCHBAR_I965 : MCHBAR_I915;
262 263 264
	u32 temp;
	bool enabled;

J
Jesse Barnes 已提交
265 266 267
	if (IS_VALLEYVIEW(dev))
		return;

268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299
	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)
{
300
	struct drm_i915_private *dev_priv = dev->dev_private;
301
	int mchbar_reg = INTEL_INFO(dev)->gen >= 4 ? MCHBAR_I965 : MCHBAR_I915;
302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319
	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);
}

320 321 322 323 324 325 326 327 328 329 330 331 332
/* 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;
}

333 334 335 336
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 };
337

338
	if (state == VGA_SWITCHEROO_ON) {
339
		pr_info("switched on\n");
340
		dev->switch_power_state = DRM_SWITCH_POWER_CHANGING;
341 342
		/* i915 resume handler doesn't set to D0 */
		pci_set_power_state(dev->pdev, PCI_D0);
343
		i915_resume_legacy(dev);
344
		dev->switch_power_state = DRM_SWITCH_POWER_ON;
345
	} else {
346
		pr_err("switched off\n");
347
		dev->switch_power_state = DRM_SWITCH_POWER_CHANGING;
348
		i915_suspend_legacy(dev, pmm);
349
		dev->switch_power_state = DRM_SWITCH_POWER_OFF;
350 351 352 353 354 355 356
	}
}

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

357 358 359 360 361 362
	/*
	 * FIXME: open_count is protected by drm_global_mutex but that would lead to
	 * locking inversion with the driver load path. And the access here is
	 * completely racy anyway. So don't bother with locking for now.
	 */
	return dev->open_count == 0;
363 364
}

365 366 367 368 369 370
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,
};

371 372 373 374
static int i915_load_modeset_init(struct drm_device *dev)
{
	struct drm_i915_private *dev_priv = dev->dev_private;
	int ret;
J
Jesse Barnes 已提交
375

376
	ret = intel_parse_bios(dev);
J
Jesse Barnes 已提交
377 378 379
	if (ret)
		DRM_INFO("failed to find VBIOS tables\n");

380 381 382 383 384 385 386
	/* 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.
	 */
387 388 389
	ret = vga_client_register(dev->pdev, dev, NULL, i915_vga_set_decode);
	if (ret && ret != -ENODEV)
		goto out;
390

J
Jesse Barnes 已提交
391 392
	intel_register_dsm_handler();

393
	ret = vga_switcheroo_register_client(dev->pdev, &i915_switcheroo_ops, false);
394
	if (ret)
395
		goto cleanup_vga_client;
396

397 398 399 400 401 402 403
	/* 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;

404 405
	intel_power_domains_init_hw(dev_priv);

406
	ret = intel_irq_install(dev_priv);
407 408 409 410 411
	if (ret)
		goto cleanup_gem_stolen;

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

414
	ret = i915_gem_init(dev);
J
Jesse Barnes 已提交
415
	if (ret)
416
		goto cleanup_irq;
417

418
	intel_modeset_gem_init(dev);
419

J
Jesse Barnes 已提交
420 421
	/* Always safe in the mode setting case. */
	/* FIXME: do pre/post-mode set stuff in core KMS code */
422
	dev->vblank_disable_allowed = true;
423
	if (INTEL_INFO(dev)->num_pipes == 0)
B
Ben Widawsky 已提交
424
		return 0;
J
Jesse Barnes 已提交
425

426 427
	ret = intel_fbdev_init(dev);
	if (ret)
428 429
		goto cleanup_gem;

430
	/* Only enable hotplug handling once the fbdev is fully set up. */
431
	intel_hpd_init(dev_priv);
432 433 434 435 436 437 438 439 440 441 442

	/*
	 * 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.
	 */
443
	async_schedule(intel_fbdev_initial_config, dev_priv);
444

445
	drm_kms_helper_poll_init(dev);
446

J
Jesse Barnes 已提交
447 448
	return 0;

449 450 451
cleanup_gem:
	mutex_lock(&dev->struct_mutex);
	i915_gem_cleanup_ringbuffer(dev);
452
	i915_gem_context_fini(dev);
453
	mutex_unlock(&dev->struct_mutex);
454
cleanup_irq:
455
	drm_irq_uninstall(dev);
456 457
cleanup_gem_stolen:
	i915_gem_cleanup_stolen(dev);
458 459 460 461
cleanup_vga_switcheroo:
	vga_switcheroo_unregister_client(dev->pdev);
cleanup_vga_client:
	vga_client_register(dev->pdev, NULL, NULL, NULL);
J
Jesse Barnes 已提交
462 463 464 465
out:
	return ret;
}

466
#if IS_ENABLED(CONFIG_FB)
467
static int i915_kick_out_firmware_fb(struct drm_i915_private *dev_priv)
468 469 470 471
{
	struct apertures_struct *ap;
	struct pci_dev *pdev = dev_priv->dev->pdev;
	bool primary;
472
	int ret;
473 474 475

	ap = alloc_apertures(1);
	if (!ap)
476
		return -ENOMEM;
477

478
	ap->ranges[0].base = dev_priv->gtt.mappable_base;
479
	ap->ranges[0].size = dev_priv->gtt.mappable_end;
480

481 482 483
	primary =
		pdev->resource[PCI_ROM_RESOURCE].flags & IORESOURCE_ROM_SHADOW;

484
	ret = remove_conflicting_framebuffers(ap, "inteldrmfb", primary);
485 486

	kfree(ap);
487 488

	return ret;
489
}
490
#else
491
static int i915_kick_out_firmware_fb(struct drm_i915_private *dev_priv)
492
{
493
	return 0;
494 495
}
#endif
496

D
Daniel Vetter 已提交
497 498 499 500 501 502 503 504 505 506 507 508 509
#if !defined(CONFIG_VGA_CONSOLE)
static int i915_kick_out_vgacon(struct drm_i915_private *dev_priv)
{
	return 0;
}
#elif !defined(CONFIG_DUMMY_CONSOLE)
static int i915_kick_out_vgacon(struct drm_i915_private *dev_priv)
{
	return -ENODEV;
}
#else
static int i915_kick_out_vgacon(struct drm_i915_private *dev_priv)
{
510
	int ret = 0;
D
Daniel Vetter 已提交
511 512 513 514

	DRM_INFO("Replacing VGA console driver\n");

	console_lock();
515 516
	if (con_is_bound(&vga_con))
		ret = do_take_over_console(&dummy_con, 0, MAX_NR_CONSOLES - 1, 1);
D
Daniel Vetter 已提交
517 518 519 520 521 522 523 524 525 526 527 528 529
	if (ret == 0) {
		ret = do_unregister_con_driver(&vga_con);

		/* Ignore "already unregistered". */
		if (ret == -ENODEV)
			ret = 0;
	}
	console_unlock();

	return ret;
}
#endif

D
Daniel Vetter 已提交
530 531
static void i915_dump_device_info(struct drm_i915_private *dev_priv)
{
532
	const struct intel_device_info *info = &dev_priv->info;
D
Daniel Vetter 已提交
533

534 535
#define PRINT_S(name) "%s"
#define SEP_EMPTY
536 537
#define PRINT_FLAG(name) info->name ? #name "," : ""
#define SEP_COMMA ,
538
	DRM_DEBUG_DRIVER("i915 device info: gen=%i, pciid=0x%04x rev=0x%02x flags="
539
			 DEV_INFO_FOR_EACH_FLAG(PRINT_S, SEP_EMPTY),
D
Daniel Vetter 已提交
540 541
			 info->gen,
			 dev_priv->dev->pdev->device,
542
			 dev_priv->dev->pdev->revision,
543
			 DEV_INFO_FOR_EACH_FLAG(PRINT_FLAG, SEP_COMMA));
544 545
#undef PRINT_S
#undef SEP_EMPTY
546 547
#undef PRINT_FLAG
#undef SEP_COMMA
D
Daniel Vetter 已提交
548 549
}

550 551 552 553 554 555 556
/*
 * 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.
557 558 559 560 561
 *
 * 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.
562 563 564
 */
static void intel_device_info_runtime_init(struct drm_device *dev)
{
565
	struct drm_i915_private *dev_priv = dev->dev_private;
566
	struct intel_device_info *info;
567
	enum pipe pipe;
568

569
	info = (struct intel_device_info *)&dev_priv->info;
570

571
	if (IS_VALLEYVIEW(dev) || INTEL_INFO(dev)->gen == 9)
572
		for_each_pipe(dev_priv, pipe)
573 574
			info->num_sprites[pipe] = 2;
	else
575
		for_each_pipe(dev_priv, pipe)
576
			info->num_sprites[pipe] = 1;
577

578 579 580 581 582 583
	if (i915.disable_display) {
		DRM_INFO("Display disabled (module parameter)\n");
		info->num_pipes = 0;
	} else if (info->num_pipes > 0 &&
		   (INTEL_INFO(dev)->gen == 7 || INTEL_INFO(dev)->gen == 8) &&
		   !IS_VALLEYVIEW(dev)) {
584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603
		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;
		}
	}
604 605
}

J
Jesse Barnes 已提交
606 607 608 609 610 611 612 613 614 615 616
/**
 * 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
 */
617
int i915_driver_load(struct drm_device *dev, unsigned long flags)
618
{
619
	struct drm_i915_private *dev_priv;
620
	struct intel_device_info *info, *device_info;
621
	int ret = 0, mmio_bar, mmio_size;
622
	uint32_t aperture_size;
623

624 625 626
	info = (struct intel_device_info *) flags;

	/* Refuse to load on gen6+ without kms enabled. */
627 628 629
	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");
630
		return -ENODEV;
631
	}
632

D
Daniel Vetter 已提交
633 634 635 636
	/* UMS needs agp support. */
	if (!drm_core_check_feature(dev, DRIVER_MODESET) && !dev->agp)
		return -EINVAL;

637
	dev_priv = kzalloc(sizeof(*dev_priv), GFP_KERNEL);
J
Jesse Barnes 已提交
638 639 640
	if (dev_priv == NULL)
		return -ENOMEM;

641
	dev->dev_private = dev_priv;
642
	dev_priv->dev = dev;
643

644
	/* Setup the write-once "constant" device info */
645
	device_info = (struct intel_device_info *)&dev_priv->info;
646 647
	memcpy(device_info, info, sizeof(dev_priv->info));
	device_info->device_id = dev->pdev->device;
J
Jesse Barnes 已提交
648

649 650
	spin_lock_init(&dev_priv->irq_lock);
	spin_lock_init(&dev_priv->gpu_error.lock);
651
	mutex_init(&dev_priv->backlight_lock);
652
	spin_lock_init(&dev_priv->uncore.lock);
653
	spin_lock_init(&dev_priv->mm.object_stat_lock);
654
	spin_lock_init(&dev_priv->mmio_flip_lock);
655 656 657
	mutex_init(&dev_priv->dpio_lock);
	mutex_init(&dev_priv->modeset_restore_lock);

D
Daniel Vetter 已提交
658
	intel_pm_setup(dev);
659

660 661
	intel_display_crc_init(dev);

D
Daniel Vetter 已提交
662 663
	i915_dump_device_info(dev_priv);

664 665 666 667 668 669 670 671
	/* 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");

672 673 674 675 676
	if (i915_get_bridge_dev(dev)) {
		ret = -EIO;
		goto free_priv;
	}

677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696
	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;
	}

697 698 699 700 701
	/* This must be called before any calls to HAS_PCH_* */
	intel_detect_pch(dev);

	intel_uncore_init(dev);

702 703
	ret = i915_gem_gtt_init(dev);
	if (ret)
704
		goto out_regs;
705

D
Daniel Vetter 已提交
706
	if (drm_core_check_feature(dev, DRIVER_MODESET)) {
D
Daniel Vetter 已提交
707 708 709
		/* WARNING: Apparently we must kick fbdev drivers before vgacon,
		 * otherwise the vga fbdev driver falls over. */
		ret = i915_kick_out_firmware_fb(dev_priv);
D
Daniel Vetter 已提交
710
		if (ret) {
D
Daniel Vetter 已提交
711
			DRM_ERROR("failed to remove conflicting framebuffer drivers\n");
D
Daniel Vetter 已提交
712 713 714
			goto out_gtt;
		}

D
Daniel Vetter 已提交
715
		ret = i915_kick_out_vgacon(dev_priv);
716
		if (ret) {
D
Daniel Vetter 已提交
717
			DRM_ERROR("failed to remove conflicting VGA console\n");
718 719
			goto out_gtt;
		}
D
Daniel Vetter 已提交
720
	}
721

722 723
	pci_set_master(dev->pdev);

724 725 726 727
	/* 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));

728 729 730 731 732 733 734 735 736 737 738
	/* 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));

739
	aperture_size = dev_priv->gtt.mappable_end;
740

B
Ben Widawsky 已提交
741 742
	dev_priv->gtt.mappable =
		io_mapping_create_wc(dev_priv->gtt.mappable_base,
743
				     aperture_size);
B
Ben Widawsky 已提交
744
	if (dev_priv->gtt.mappable == NULL) {
745
		ret = -EIO;
746
		goto out_gtt;
747 748
	}

749 750
	dev_priv->gtt.mtrr = arch_phys_wc_add(dev_priv->gtt.mappable_base,
					      aperture_size);
751

752 753 754 755 756 757 758
	/* 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
759
	 * idle-timers and recording error state.
760 761 762
	 *
	 * 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
763
	 * workqueue at any time.  Use an ordered one.
764
	 */
765
	dev_priv->wq = alloc_ordered_workqueue("i915", 0);
766 767 768
	if (dev_priv->wq == NULL) {
		DRM_ERROR("Failed to create our workqueue.\n");
		ret = -ENOMEM;
769
		goto out_mtrrfree;
770 771
	}

772 773 774 775 776 777 778
	dev_priv->dp_wq = alloc_ordered_workqueue("i915-dp", 0);
	if (dev_priv->dp_wq == NULL) {
		DRM_ERROR("Failed to create our dp workqueue.\n");
		ret = -ENOMEM;
		goto out_freewq;
	}

779
	intel_irq_init(dev_priv);
780
	intel_uncore_sanitize(dev);
781

782 783
	/* Try to make sure MCHBAR is enabled before poking at it */
	intel_setup_mchbar(dev);
784
	intel_setup_gmbus(dev);
785
	intel_opregion_setup(dev);
786

787 788
	intel_setup_bios(dev);

789 790
	i915_gem_load(dev);

791 792 793 794 795 796
	/* 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.
797 798
	 *
	 * According to chipset errata, on the 965GM, MSI interrupts may
799 800
	 * be lost or delayed, but we use them anyways to avoid
	 * stuck interrupts on some machines.
801
	 */
802
	if (!IS_I945G(dev) && !IS_I945GM(dev))
803
		pci_enable_msi(dev->pdev);
804

805
	intel_device_info_runtime_init(dev);
806

B
Ben Widawsky 已提交
807 808 809 810 811
	if (INTEL_INFO(dev)->num_pipes) {
		ret = drm_vblank_init(dev, INTEL_INFO(dev)->num_pipes);
		if (ret)
			goto out_gem_unload;
	}
812

813
	intel_power_domains_init(dev_priv);
814

J
Jesse Barnes 已提交
815
	if (drm_core_check_feature(dev, DRIVER_MODESET)) {
D
Daniel Vetter 已提交
816
		ret = i915_load_modeset_init(dev);
J
Jesse Barnes 已提交
817 818
		if (ret < 0) {
			DRM_ERROR("failed to init modeset\n");
819
			goto out_power_well;
J
Jesse Barnes 已提交
820 821 822
		}
	}

B
Ben Widawsky 已提交
823 824
	i915_setup_sysfs(dev);

B
Ben Widawsky 已提交
825 826 827
	if (INTEL_INFO(dev)->num_pipes) {
		/* Must be done after probing outputs */
		intel_opregion_init(dev);
828
		acpi_video_register();
B
Ben Widawsky 已提交
829
	}
830

831 832
	if (IS_GEN5(dev))
		intel_gpu_ips_init(dev_priv);
833

834
	intel_runtime_pm_enable(dev_priv);
835

J
Jesse Barnes 已提交
836 837
	return 0;

838
out_power_well:
839
	intel_power_domains_fini(dev_priv);
840
	drm_vblank_cleanup(dev);
841
out_gem_unload:
842 843
	WARN_ON(unregister_oom_notifier(&dev_priv->mm.oom_notifier));
	unregister_shrinker(&dev_priv->mm.shrinker);
844

845 846 847 848 849
	if (dev->pdev->msi_enabled)
		pci_disable_msi(dev->pdev);

	intel_teardown_gmbus(dev);
	intel_teardown_mchbar(dev);
850
	pm_qos_remove_request(&dev_priv->pm_qos);
851 852
	destroy_workqueue(dev_priv->dp_wq);
out_freewq:
853
	destroy_workqueue(dev_priv->wq);
854
out_mtrrfree:
855
	arch_phys_wc_del(dev_priv->gtt.mtrr);
B
Ben Widawsky 已提交
856
	io_mapping_free(dev_priv->gtt.mappable);
857
out_gtt:
858
	i915_global_gtt_cleanup(dev);
859
out_regs:
860
	intel_uncore_fini(dev);
861
	pci_iounmap(dev->pdev, dev_priv->regs);
862 863
put_bridge:
	pci_dev_put(dev_priv->bridge_dev);
J
Jesse Barnes 已提交
864
free_priv:
865 866
	if (dev_priv->slab)
		kmem_cache_destroy(dev_priv->slab);
867
	kfree(dev_priv);
J
Jesse Barnes 已提交
868 869 870 871 872 873
	return ret;
}

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

876 877 878 879 880 881
	ret = i915_gem_suspend(dev);
	if (ret) {
		DRM_ERROR("failed to idle hardware: %d\n", ret);
		return ret;
	}

882
	intel_power_domains_fini(dev_priv);
883

884
	intel_gpu_ips_teardown();
885

B
Ben Widawsky 已提交
886 887
	i915_teardown_sysfs(dev);

888 889
	WARN_ON(unregister_oom_notifier(&dev_priv->mm.oom_notifier));
	unregister_shrinker(&dev_priv->mm.shrinker);
890

B
Ben Widawsky 已提交
891
	io_mapping_free(dev_priv->gtt.mappable);
892
	arch_phys_wc_del(dev_priv->gtt.mtrr);
893

894 895
	acpi_video_unregister();

896
	if (drm_core_check_feature(dev, DRIVER_MODESET))
897
		intel_fbdev_fini(dev);
898 899 900 901

	drm_vblank_cleanup(dev);

	if (drm_core_check_feature(dev, DRIVER_MODESET)) {
902 903
		intel_modeset_cleanup(dev);

Z
Zhao Yakui 已提交
904 905 906 907
		/*
		 * free the memory space allocated for the child device
		 * config parsed from VBT
		 */
908 909 910 911
		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 已提交
912
		}
913

914
		vga_switcheroo_unregister_client(dev->pdev);
915
		vga_client_register(dev->pdev, NULL, NULL, NULL);
J
Jesse Barnes 已提交
916 917
	}

918
	/* Free error state after interrupts are fully disabled. */
919 920
	del_timer_sync(&dev_priv->gpu_error.hangcheck_timer);
	cancel_work_sync(&dev_priv->gpu_error.work);
921
	i915_destroy_error_state(dev);
922

923 924 925
	if (dev->pdev->msi_enabled)
		pci_disable_msi(dev->pdev);

926
	intel_opregion_fini(dev);
927

J
Jesse Barnes 已提交
928
	if (drm_core_check_feature(dev, DRIVER_MODESET)) {
929 930 931
		/* Flush any outstanding unpin_work. */
		flush_workqueue(dev_priv->wq);

J
Jesse Barnes 已提交
932 933
		mutex_lock(&dev->struct_mutex);
		i915_gem_cleanup_ringbuffer(dev);
934
		i915_gem_batch_pool_fini(&dev_priv->mm.batch_pool);
935
		i915_gem_context_fini(dev);
J
Jesse Barnes 已提交
936
		mutex_unlock(&dev->struct_mutex);
937
		i915_gem_cleanup_stolen(dev);
J
Jesse Barnes 已提交
938 939
	}

940
	intel_teardown_gmbus(dev);
941 942
	intel_teardown_mchbar(dev);

943
	destroy_workqueue(dev_priv->dp_wq);
944
	destroy_workqueue(dev_priv->wq);
945
	pm_qos_remove_request(&dev_priv->pm_qos);
946

947
	i915_global_gtt_cleanup(dev);
948

949 950 951 952
	intel_uncore_fini(dev);
	if (dev_priv->regs != NULL)
		pci_iounmap(dev->pdev, dev_priv->regs);

953 954
	if (dev_priv->slab)
		kmem_cache_destroy(dev_priv->slab);
955

956
	pci_dev_put(dev_priv->bridge_dev);
957
	kfree(dev_priv);
J
Jesse Barnes 已提交
958

959 960 961
	return 0;
}

962
int i915_driver_open(struct drm_device *dev, struct drm_file *file)
963
{
964
	int ret;
965

966 967 968
	ret = i915_gem_open(dev, file);
	if (ret)
		return ret;
969

970 971 972
	return 0;
}

J
Jesse Barnes 已提交
973 974 975 976 977 978 979 980
/**
 * 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).
 *
981
 * Additionally, in the non-mode setting case, we'll tear down the GTT
J
Jesse Barnes 已提交
982 983 984
 * and DMA structures, since the kernel won't be using them, and clea
 * up any GEM state.
 */
985
void i915_driver_lastclose(struct drm_device *dev)
L
Linus Torvalds 已提交
986
{
D
Daniel Vetter 已提交
987 988
	intel_fbdev_restore_mode(dev);
	vga_switcheroo_process_delayed_switch();
L
Linus Torvalds 已提交
989 990
}

991
void i915_driver_preclose(struct drm_device *dev, struct drm_file *file)
L
Linus Torvalds 已提交
992
{
993
	mutex_lock(&dev->struct_mutex);
994 995
	i915_gem_context_close(dev, file);
	i915_gem_release(dev, file);
996
	mutex_unlock(&dev->struct_mutex);
997 998 999

	if (drm_core_check_feature(dev, DRIVER_MODESET))
		intel_modeset_preclose(dev, file);
L
Linus Torvalds 已提交
1000 1001
}

1002
void i915_driver_postclose(struct drm_device *dev, struct drm_file *file)
1003
{
1004
	struct drm_i915_file_private *file_priv = file->driver_priv;
1005

1006 1007
	if (file_priv && file_priv->bsd_ring)
		file_priv->bsd_ring = NULL;
1008
	kfree(file_priv);
1009 1010
}

D
Daniel Vetter 已提交
1011 1012 1013 1014 1015 1016 1017
static int
i915_gem_reject_pin_ioctl(struct drm_device *dev, void *data,
			  struct drm_file *file)
{
	return -ENODEV;
}

R
Rob Clark 已提交
1018
const struct drm_ioctl_desc i915_ioctls[] = {
1019 1020 1021 1022 1023 1024
	DRM_IOCTL_DEF_DRV(I915_INIT, drm_noop, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
	DRM_IOCTL_DEF_DRV(I915_FLUSH, drm_noop, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_FLIP, drm_noop, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_BATCHBUFFER, drm_noop, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_IRQ_EMIT, drm_noop, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_IRQ_WAIT, drm_noop, DRM_AUTH),
1025
	DRM_IOCTL_DEF_DRV(I915_GETPARAM, i915_getparam, DRM_AUTH|DRM_RENDER_ALLOW),
1026
	DRM_IOCTL_DEF_DRV(I915_SETPARAM, i915_setparam, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
D
Daniel Vetter 已提交
1027 1028 1029
	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),
1030
	DRM_IOCTL_DEF_DRV(I915_CMDBUFFER, drm_noop, DRM_AUTH),
D
Daniel Vetter 已提交
1031
	DRM_IOCTL_DEF_DRV(I915_DESTROY_HEAP,  drm_noop, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
1032
	DRM_IOCTL_DEF_DRV(I915_SET_VBLANK_PIPE,  drm_noop, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
1033 1034 1035
	DRM_IOCTL_DEF_DRV(I915_GET_VBLANK_PIPE,  drm_noop, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_VBLANK_SWAP, drm_noop, DRM_AUTH),
	DRM_IOCTL_DEF_DRV(I915_HWS_ADDR, drm_noop, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
D
Daniel Vetter 已提交
1036
	DRM_IOCTL_DEF_DRV(I915_GEM_INIT, drm_noop, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY|DRM_UNLOCKED),
1037
	DRM_IOCTL_DEF_DRV(I915_GEM_EXECBUFFER, i915_gem_execbuffer, DRM_AUTH|DRM_UNLOCKED),
1038
	DRM_IOCTL_DEF_DRV(I915_GEM_EXECBUFFER2, i915_gem_execbuffer2, DRM_AUTH|DRM_UNLOCKED|DRM_RENDER_ALLOW),
D
Daniel Vetter 已提交
1039 1040
	DRM_IOCTL_DEF_DRV(I915_GEM_PIN, i915_gem_reject_pin_ioctl, DRM_AUTH|DRM_ROOT_ONLY|DRM_UNLOCKED),
	DRM_IOCTL_DEF_DRV(I915_GEM_UNPIN, i915_gem_reject_pin_ioctl, DRM_AUTH|DRM_ROOT_ONLY|DRM_UNLOCKED),
1041 1042 1043 1044
	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),
1045 1046
	DRM_IOCTL_DEF_DRV(I915_GEM_ENTERVT, drm_noop, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY|DRM_UNLOCKED),
	DRM_IOCTL_DEF_DRV(I915_GEM_LEAVEVT, drm_noop, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY|DRM_UNLOCKED),
1047 1048 1049 1050 1051 1052 1053 1054 1055 1056
	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),
1057
	DRM_IOCTL_DEF_DRV(I915_GET_PIPE_FROM_CRTC_ID, intel_get_pipe_from_crtc_id, DRM_UNLOCKED),
1058
	DRM_IOCTL_DEF_DRV(I915_GEM_MADVISE, i915_gem_madvise_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
1059 1060
	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),
1061 1062
	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),
1063 1064 1065 1066
	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),
1067
	DRM_IOCTL_DEF_DRV(I915_GET_RESET_STATS, i915_get_reset_stats_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
1068
	DRM_IOCTL_DEF_DRV(I915_GEM_USERPTR, i915_gem_userptr_ioctl, DRM_UNLOCKED|DRM_RENDER_ALLOW),
D
Dave Airlie 已提交
1069 1070
};

1071
int i915_max_ioctl = ARRAY_SIZE(i915_ioctls);
1072

1073 1074 1075 1076
/*
 * 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.
1077
 */
1078
int i915_driver_device_is_agp(struct drm_device *dev)
1079 1080 1081
{
	return 1;
}