nouveau_drm.c 28.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
/*
 * Copyright 2012 Red Hat Inc.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 * OTHER DEALINGS IN THE SOFTWARE.
 *
 * Authors: Ben Skeggs
 */

25
#include <linux/console.h>
26
#include <linux/delay.h>
27 28
#include <linux/module.h>
#include <linux/pci.h>
29 30
#include <linux/pm_runtime.h>
#include <linux/vga_switcheroo.h>
31

32 33
#include <drm/drmP.h>
#include <drm/drm_crtc_helper.h>
34

35
#include <core/gpuobj.h>
36
#include <core/option.h>
37 38
#include <core/pci.h>
#include <core/tegra.h>
39

40 41
#include <nvif/driver.h>

42
#include <nvif/class.h>
43
#include <nvif/cl0002.h>
44
#include <nvif/cla06f.h>
45 46
#include <nvif/if0004.h>

47
#include "nouveau_drv.h"
48
#include "nouveau_dma.h"
49 50 51
#include "nouveau_ttm.h"
#include "nouveau_gem.h"
#include "nouveau_vga.h"
52
#include "nouveau_led.h"
53
#include "nouveau_hwmon.h"
54 55 56
#include "nouveau_acpi.h"
#include "nouveau_bios.h"
#include "nouveau_ioctl.h"
57 58 59
#include "nouveau_abi16.h"
#include "nouveau_fbcon.h"
#include "nouveau_fence.h"
60
#include "nouveau_debugfs.h"
61
#include "nouveau_usif.h"
62
#include "nouveau_connector.h"
63
#include "nouveau_platform.h"
64

65 66 67 68 69 70 71 72
MODULE_PARM_DESC(config, "option string to pass to driver core");
static char *nouveau_config;
module_param_named(config, nouveau_config, charp, 0400);

MODULE_PARM_DESC(debug, "debug string to pass to driver core");
static char *nouveau_debug;
module_param_named(debug, nouveau_debug, charp, 0400);

73 74 75 76
MODULE_PARM_DESC(noaccel, "disable kernel/abi16 acceleration");
static int nouveau_noaccel = 0;
module_param_named(noaccel, nouveau_noaccel, int, 0400);

77 78 79
MODULE_PARM_DESC(modeset, "enable driver (default: auto, "
		          "0 = disabled, 1 = enabled, 2 = headless)");
int nouveau_modeset = -1;
80 81
module_param_named(modeset, nouveau_modeset, int, 0400);

82 83 84 85
MODULE_PARM_DESC(runpm, "disable (0), force enable (1), optimus only default (-1)");
int nouveau_runtime_pm = -1;
module_param_named(runpm, nouveau_runtime_pm, int, 0400);

86 87 88
static struct drm_driver driver_stub;
static struct drm_driver driver_pci;
static struct drm_driver driver_platform;
89

90
static u64
A
Alexandre Courbot 已提交
91
nouveau_pci_name(struct pci_dev *pdev)
92 93 94 95 96 97 98
{
	u64 name = (u64)pci_domain_nr(pdev->bus) << 32;
	name |= pdev->bus->number << 16;
	name |= PCI_SLOT(pdev->devfn) << 8;
	return name | PCI_FUNC(pdev->devfn);
}

A
Alexandre Courbot 已提交
99 100 101 102 103 104 105 106 107 108 109 110
static u64
nouveau_platform_name(struct platform_device *platformdev)
{
	return platformdev->id;
}

static u64
nouveau_name(struct drm_device *dev)
{
	if (dev->pdev)
		return nouveau_pci_name(dev->pdev);
	else
111
		return nouveau_platform_name(to_platform_device(dev->dev));
A
Alexandre Courbot 已提交
112 113
}

114 115 116 117 118
static void
nouveau_cli_fini(struct nouveau_cli *cli)
{
	nvkm_vm_ref(NULL, &nvxx_client(&cli->base)->vm, NULL);
	usif_client_fini(cli);
119
	nvif_device_fini(&cli->device);
120 121 122
	nvif_client_fini(&cli->base);
}

123
static int
124 125
nouveau_cli_init(struct nouveau_drm *drm, const char *sname,
		 struct nouveau_cli *cli)
126
{
127
	u64 device = nouveau_name(drm->dev);
B
Ben Skeggs 已提交
128 129
	int ret;

130 131 132 133 134
	snprintf(cli->name, sizeof(cli->name), "%s", sname);
	cli->dev = drm->dev;
	mutex_init(&cli->mutex);
	usif_client_init(cli);

135 136 137 138 139
	if (cli == &drm->client) {
		ret = nvif_driver_init(NULL, nouveau_config, nouveau_debug,
				       cli->name, device, &cli->base);
	} else {
		ret = nvif_client_init(&drm->client.base, cli->name, device,
B
Ben Skeggs 已提交
140
				       &cli->base);
141
	}
142 143 144
	if (ret) {
		NV_ERROR(drm, "Client allocation failed: %d\n", ret);
		goto done;
145
	}
146

147 148 149 150 151 152 153 154 155 156
	ret = nvif_device_init(&cli->base.object, 0, NV_DEVICE,
			       &(struct nv_device_v0) {
					.device = ~0,
			       }, sizeof(struct nv_device_v0),
			       &cli->device);
	if (ret) {
		NV_ERROR(drm, "Device allocation failed: %d\n", ret);
		goto done;
	}

157 158 159 160
done:
	if (ret)
		nouveau_cli_fini(cli);
	return ret;
161 162
}

163 164 165
static void
nouveau_accel_fini(struct nouveau_drm *drm)
{
166
	nouveau_channel_idle(drm->channel);
167
	nvif_object_fini(&drm->ntfy);
168
	nvkm_gpuobj_del(&drm->notify);
169
	nvif_notify_fini(&drm->flip);
170
	nvif_object_fini(&drm->nvsw);
171 172 173
	nouveau_channel_del(&drm->channel);

	nouveau_channel_idle(drm->cechan);
174
	nvif_object_fini(&drm->ttm.copy);
175 176
	nouveau_channel_del(&drm->cechan);

177 178 179 180 181 182 183
	if (drm->fence)
		nouveau_fence(drm)->dtor(drm);
}

static void
nouveau_accel_init(struct nouveau_drm *drm)
{
184
	struct nvif_device *device = &drm->client.device;
185
	struct nvif_sclass *sclass;
186
	u32 arg0, arg1;
187
	int ret, i, n;
188

189
	if (nouveau_noaccel)
190 191 192
		return;

	/* initialise synchronisation routines */
193 194 195
	/*XXX: this is crap, but the fence/channel stuff is a little
	 *     backwards in some places.  this will be fixed.
	 */
196
	ret = n = nvif_object_sclass_get(&device->object, &sclass);
197 198 199
	if (ret < 0)
		return;

200 201
	for (ret = -ENOSYS, i = 0; i < n; i++) {
		switch (sclass[i].oclass) {
202
		case NV03_CHANNEL_DMA:
203 204
			ret = nv04_fence_create(drm);
			break;
205
		case NV10_CHANNEL_DMA:
206 207
			ret = nv10_fence_create(drm);
			break;
208 209
		case NV17_CHANNEL_DMA:
		case NV40_CHANNEL_DMA:
210 211
			ret = nv17_fence_create(drm);
			break;
212
		case NV50_CHANNEL_GPFIFO:
213 214
			ret = nv50_fence_create(drm);
			break;
215
		case G82_CHANNEL_GPFIFO:
216 217
			ret = nv84_fence_create(drm);
			break;
218 219
		case FERMI_CHANNEL_GPFIFO:
		case KEPLER_CHANNEL_GPFIFO_A:
220
		case KEPLER_CHANNEL_GPFIFO_B:
221
		case MAXWELL_CHANNEL_GPFIFO_A:
222
		case PASCAL_CHANNEL_GPFIFO_A:
223 224 225 226 227 228 229
			ret = nvc0_fence_create(drm);
			break;
		default:
			break;
		}
	}

230
	nvif_object_sclass_put(&sclass);
231 232 233 234 235 236
	if (ret) {
		NV_ERROR(drm, "failed to initialise sync subsystem, %d\n", ret);
		nouveau_accel_fini(drm);
		return;
	}

237
	if (device->info.family >= NV_DEVICE_INFO_V0_KEPLER) {
238
		ret = nouveau_channel_new(drm, &drm->client.device,
239 240
					  NVA06F_V0_ENGINE_CE0 |
					  NVA06F_V0_ENGINE_CE1,
241
					  0, &drm->cechan);
242 243 244
		if (ret)
			NV_ERROR(drm, "failed to create ce channel, %d\n", ret);

245
		arg0 = NVA06F_V0_ENGINE_GR;
246
		arg1 = 1;
247
	} else
248 249 250
	if (device->info.chipset >= 0xa3 &&
	    device->info.chipset != 0xaa &&
	    device->info.chipset != 0xac) {
251
		ret = nouveau_channel_new(drm, &drm->client.device,
252
					  NvDmaFB, NvDmaTT, &drm->cechan);
253 254 255 256 257
		if (ret)
			NV_ERROR(drm, "failed to create ce channel, %d\n", ret);

		arg0 = NvDmaFB;
		arg1 = NvDmaTT;
258 259 260 261 262
	} else {
		arg0 = NvDmaFB;
		arg1 = NvDmaTT;
	}

263 264
	ret = nouveau_channel_new(drm, &drm->client.device,
				  arg0, arg1, &drm->channel);
265 266 267 268 269 270
	if (ret) {
		NV_ERROR(drm, "failed to create kernel channel, %d\n", ret);
		nouveau_accel_fini(drm);
		return;
	}

271
	ret = nvif_object_init(&drm->channel->user, NVDRM_NVSW,
272
			       nouveau_abi16_swclass(drm), NULL, 0, &drm->nvsw);
273 274 275
	if (ret == 0) {
		ret = RING_SPACE(drm->channel, 2);
		if (ret == 0) {
276
			if (device->info.family < NV_DEVICE_INFO_V0_FERMI) {
277 278 279
				BEGIN_NV04(drm->channel, NvSubSw, 0, 1);
				OUT_RING  (drm->channel, NVDRM_NVSW);
			} else
280
			if (device->info.family < NV_DEVICE_INFO_V0_KEPLER) {
281 282 283 284
				BEGIN_NVC0(drm->channel, FermiSw, 0, 1);
				OUT_RING  (drm->channel, 0x001f0000);
			}
		}
285 286

		ret = nvif_notify_init(&drm->nvsw, nouveau_flip_complete,
287 288
				       false, NV04_NVSW_NTFY_UEVENT,
				       NULL, 0, 0, &drm->flip);
289 290 291 292 293 294
		if (ret == 0)
			ret = nvif_notify_get(&drm->flip);
		if (ret) {
			nouveau_accel_fini(drm);
			return;
		}
295 296 297 298 299 300 301 302
	}

	if (ret) {
		NV_ERROR(drm, "failed to allocate software object, %d\n", ret);
		nouveau_accel_fini(drm);
		return;
	}

303
	if (device->info.family < NV_DEVICE_INFO_V0_FERMI) {
304 305
		ret = nvkm_gpuobj_new(nvxx_device(&drm->client.device), 32, 0,
				      false, NULL, &drm->notify);
306 307 308 309 310 311
		if (ret) {
			NV_ERROR(drm, "failed to allocate notifier, %d\n", ret);
			nouveau_accel_fini(drm);
			return;
		}

312
		ret = nvif_object_init(&drm->channel->user, NvNotify0,
313 314 315 316
				       NV_DMA_IN_MEMORY,
				       &(struct nv_dma_v0) {
						.target = NV_DMA_V0_TARGET_VRAM,
						.access = NV_DMA_V0_ACCESS_RDWR,
317 318
						.start = drm->notify->addr,
						.limit = drm->notify->addr + 31
319
				       }, sizeof(struct nv_dma_v0),
320
				       &drm->ntfy);
321 322 323 324 325 326 327
		if (ret) {
			nouveau_accel_fini(drm);
			return;
		}
	}


328
	nouveau_bo_move_init(drm);
329 330
}

331 332
static int nouveau_drm_probe(struct pci_dev *pdev,
			     const struct pci_device_id *pent)
333
{
334
	struct nvkm_device *device;
335 336
	struct apertures_struct *aper;
	bool boot = false;
337 338
	int ret;

339
	if (vga_switcheroo_client_probe_defer(pdev))
340 341
		return -EPROBE_DEFER;

342 343 344 345 346 347 348 349 350 351
	/* We need to check that the chipset is supported before booting
	 * fbdev off the hardware, as there's no way to put it back.
	 */
	ret = nvkm_device_pci_new(pdev, NULL, "error", true, false, 0, &device);
	if (ret)
		return ret;

	nvkm_device_del(&device);

	/* Remove conflicting drivers (vesafb, efifb etc). */
352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374
	aper = alloc_apertures(3);
	if (!aper)
		return -ENOMEM;

	aper->ranges[0].base = pci_resource_start(pdev, 1);
	aper->ranges[0].size = pci_resource_len(pdev, 1);
	aper->count = 1;

	if (pci_resource_len(pdev, 2)) {
		aper->ranges[aper->count].base = pci_resource_start(pdev, 2);
		aper->ranges[aper->count].size = pci_resource_len(pdev, 2);
		aper->count++;
	}

	if (pci_resource_len(pdev, 3)) {
		aper->ranges[aper->count].base = pci_resource_start(pdev, 3);
		aper->ranges[aper->count].size = pci_resource_len(pdev, 3);
		aper->count++;
	}

#ifdef CONFIG_X86
	boot = pdev->resource[PCI_ROM_RESOURCE].flags & IORESOURCE_ROM_SHADOW;
#endif
B
Ben Skeggs 已提交
375
	if (nouveau_modeset != 2)
376
		drm_fb_helper_remove_conflicting_framebuffers(aper, "nouveaufb", boot);
377
	kfree(aper);
378

379 380
	ret = nvkm_device_pci_new(pdev, nouveau_config, nouveau_debug,
				  true, true, ~0ULL, &device);
381 382 383 384 385
	if (ret)
		return ret;

	pci_set_master(pdev);

386
	ret = drm_get_pci_dev(pdev, pent, &driver_pci);
387
	if (ret) {
388
		nvkm_device_del(&device);
389 390 391 392 393 394
		return ret;
	}

	return 0;
}

395 396 397
#define PCI_CLASS_MULTIMEDIA_HD_AUDIO 0x0403

static void
398
nouveau_get_hdmi_dev(struct nouveau_drm *drm)
399
{
400
	struct pci_dev *pdev = drm->dev->pdev;
401

A
Alexandre Courbot 已提交
402
	if (!pdev) {
403
		NV_DEBUG(drm, "not a PCI device; no HDMI\n");
A
Alexandre Courbot 已提交
404 405 406 407
		drm->hdmi_device = NULL;
		return;
	}

408 409 410 411 412
	/* subfunction one is a hdmi audio device? */
	drm->hdmi_device = pci_get_bus_and_slot((unsigned int)pdev->bus->number,
						PCI_DEVFN(PCI_SLOT(pdev->devfn), 1));

	if (!drm->hdmi_device) {
413
		NV_DEBUG(drm, "hdmi device not found %d %d %d\n", pdev->bus->number, PCI_SLOT(pdev->devfn), 1);
414 415 416 417
		return;
	}

	if ((drm->hdmi_device->class >> 8) != PCI_CLASS_MULTIMEDIA_HD_AUDIO) {
418
		NV_DEBUG(drm, "possible hdmi device not audio %d\n", drm->hdmi_device->class);
419 420 421 422 423 424
		pci_dev_put(drm->hdmi_device);
		drm->hdmi_device = NULL;
		return;
	}
}

425
static int
426 427 428 429 430
nouveau_drm_load(struct drm_device *dev, unsigned long flags)
{
	struct nouveau_drm *drm;
	int ret;

431 432 433 434 435 436
	if (!(drm = kzalloc(sizeof(*drm), GFP_KERNEL)))
		return -ENOMEM;
	dev->dev_private = drm;
	drm->dev = dev;

	ret = nouveau_cli_init(drm, "DRM", &drm->client);
437 438 439
	if (ret)
		return ret;

440 441
	dev->irq_enabled = true;

442
	nvxx_client(&drm->client.base)->debug =
443
		nvkm_dbgopt(nouveau_debug, "DRM");
444

445
	INIT_LIST_HEAD(&drm->clients);
446
	spin_lock_init(&drm->tile.lock);
447

448
	nouveau_get_hdmi_dev(drm);
449

450 451 452 453
	/* workaround an odd issue on nvc1 by disabling the device's
	 * nosnoop capability.  hopefully won't cause issues until a
	 * better fix is found - assuming there is one...
	 */
454 455
	if (drm->client.device.info.chipset == 0xc1)
		nvif_mask(&drm->client.device.object, 0x00088080, 0x00000800, 0x00000000);
456

457
	nouveau_vga_init(drm);
458

459 460
	if (drm->client.device.info.family >= NV_DEVICE_INFO_V0_TESLA) {
		if (!nvxx_device(&drm->client.device)->mmu) {
461 462 463 464
			ret = -ENOSYS;
			goto fail_device;
		}

465 466 467
		ret = nvkm_vm_new(nvxx_device(&drm->client.device),
				  0, (1ULL << 40), 0x1000, NULL,
				  &drm->client.vm);
468 469
		if (ret)
			goto fail_device;
470

471
		nvxx_client(&drm->client.base)->vm = drm->client.vm;
472 473 474
	}

	ret = nouveau_ttm_init(drm);
475
	if (ret)
476 477 478 479 480 481 482
		goto fail_ttm;

	ret = nouveau_bios_init(dev);
	if (ret)
		goto fail_bios;

	ret = nouveau_display_create(dev);
483
	if (ret)
484 485 486 487 488 489 490 491
		goto fail_dispctor;

	if (dev->mode_config.num_crtc) {
		ret = nouveau_display_init(dev);
		if (ret)
			goto fail_dispinit;
	}

492
	nouveau_debugfs_init(drm);
493
	nouveau_hwmon_init(dev);
494 495
	nouveau_accel_init(drm);
	nouveau_fbcon_init(dev);
496
	nouveau_led_init(dev);
497 498 499 500 501 502 503 504 505

	if (nouveau_runtime_pm != 0) {
		pm_runtime_use_autosuspend(dev->dev);
		pm_runtime_set_autosuspend_delay(dev->dev, 5000);
		pm_runtime_set_active(dev->dev);
		pm_runtime_allow(dev->dev);
		pm_runtime_mark_last_busy(dev->dev);
		pm_runtime_put(dev->dev);
	}
506 507
	return 0;

508 509 510 511 512
fail_dispinit:
	nouveau_display_destroy(dev);
fail_dispctor:
	nouveau_bios_takedown(dev);
fail_bios:
513
	nouveau_ttm_fini(drm);
514 515
fail_ttm:
	nouveau_vga_fini(drm);
516
fail_device:
517 518
	nouveau_cli_fini(&drm->client);
	kfree(drm);
519 520 521
	return ret;
}

522
static void
523 524
nouveau_drm_unload(struct drm_device *dev)
{
525
	struct nouveau_drm *drm = nouveau_drm(dev);
526

527 528
	if (nouveau_runtime_pm != 0) {
		pm_runtime_get_sync(dev->dev);
529
		pm_runtime_forbid(dev->dev);
530 531
	}

532
	nouveau_led_fini(dev);
533 534
	nouveau_fbcon_fini(dev);
	nouveau_accel_fini(drm);
535
	nouveau_hwmon_fini(dev);
536
	nouveau_debugfs_fini(drm);
537

538
	if (dev->mode_config.num_crtc)
539
		nouveau_display_fini(dev, false);
540 541 542
	nouveau_display_destroy(dev);

	nouveau_bios_takedown(dev);
543

544
	nouveau_ttm_fini(drm);
545
	nouveau_vga_fini(drm);
546

547 548
	if (drm->hdmi_device)
		pci_dev_put(drm->hdmi_device);
549 550
	nouveau_cli_fini(&drm->client);
	kfree(drm);
551 552
}

553 554
void
nouveau_drm_device_remove(struct drm_device *dev)
555
{
556
	struct nouveau_drm *drm = nouveau_drm(dev);
557
	struct nvkm_client *client;
558
	struct nvkm_device *device;
559

560
	dev->irq_enabled = false;
561
	client = nvxx_client(&drm->client.base);
562
	device = nvkm_device_find(client->device);
563 564
	drm_put_dev(dev);

565
	nvkm_device_del(&device);
566
}
567 568 569 570 571 572 573 574

static void
nouveau_drm_remove(struct pci_dev *pdev)
{
	struct drm_device *dev = pci_get_drvdata(pdev);

	nouveau_drm_device_remove(dev);
}
575

576
static int
577
nouveau_do_suspend(struct drm_device *dev, bool runtime)
578
{
579
	struct nouveau_drm *drm = nouveau_drm(dev);
580 581
	int ret;

582 583
	nouveau_led_suspend(dev);

584 585 586
	if (dev->mode_config.num_crtc) {
		NV_INFO(drm, "suspending console...\n");
		nouveau_fbcon_set_suspend(dev, 1);
587
		NV_INFO(drm, "suspending display...\n");
588
		ret = nouveau_display_suspend(dev, runtime);
589 590 591
		if (ret)
			return ret;
	}
592

593
	NV_INFO(drm, "evicting buffers...\n");
594 595
	ttm_bo_evict_mm(&drm->ttm.bdev, TTM_PL_VRAM);

596
	NV_INFO(drm, "waiting for kernel channels to go idle...\n");
597 598 599
	if (drm->cechan) {
		ret = nouveau_channel_idle(drm->cechan);
		if (ret)
600
			goto fail_display;
601 602 603 604 605
	}

	if (drm->channel) {
		ret = nouveau_channel_idle(drm->channel);
		if (ret)
606
			goto fail_display;
607 608
	}

609
	NV_INFO(drm, "suspending fence...\n");
610
	if (drm->fence && nouveau_fence(drm)->suspend) {
611 612 613 614
		if (!nouveau_fence(drm)->suspend(drm)) {
			ret = -ENOMEM;
			goto fail_display;
		}
615 616
	}

617
	NV_INFO(drm, "suspending object tree...\n");
618
	ret = nvif_client_suspend(&drm->client.base);
619 620 621 622 623 624
	if (ret)
		goto fail_client;

	return 0;

fail_client:
625 626 627 628
	if (drm->fence && nouveau_fence(drm)->resume)
		nouveau_fence(drm)->resume(drm);

fail_display:
629
	if (dev->mode_config.num_crtc) {
630
		NV_INFO(drm, "resuming display...\n");
631
		nouveau_display_resume(dev, runtime);
632
	}
633 634 635
	return ret;
}

636
static int
637
nouveau_do_resume(struct drm_device *dev, bool runtime)
D
Dave Airlie 已提交
638 639 640
{
	struct nouveau_drm *drm = nouveau_drm(dev);

641
	NV_INFO(drm, "resuming object tree...\n");
642
	nvif_client_resume(&drm->client.base);
643

644
	NV_INFO(drm, "resuming fence...\n");
645 646 647
	if (drm->fence && nouveau_fence(drm)->resume)
		nouveau_fence(drm)->resume(drm);

648 649
	nouveau_run_vbios_init(dev);

650
	if (dev->mode_config.num_crtc) {
651
		NV_INFO(drm, "resuming display...\n");
652 653 654
		nouveau_display_resume(dev, runtime);
		NV_INFO(drm, "resuming console...\n");
		nouveau_fbcon_set_suspend(dev, 0);
655
	}
656

657 658
	nouveau_led_resume(dev);

659
	return 0;
660 661
}

662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679
int
nouveau_pmops_suspend(struct device *dev)
{
	struct pci_dev *pdev = to_pci_dev(dev);
	struct drm_device *drm_dev = pci_get_drvdata(pdev);
	int ret;

	if (drm_dev->switch_power_state == DRM_SWITCH_POWER_OFF ||
	    drm_dev->switch_power_state == DRM_SWITCH_POWER_DYNAMIC_OFF)
		return 0;

	ret = nouveau_do_suspend(drm_dev, false);
	if (ret)
		return ret;

	pci_save_state(pdev);
	pci_disable_device(pdev);
	pci_set_power_state(pdev, PCI_D3hot);
680
	udelay(200);
681 682 683 684 685
	return 0;
}

int
nouveau_pmops_resume(struct device *dev)
D
Dave Airlie 已提交
686 687 688 689 690
{
	struct pci_dev *pdev = to_pci_dev(dev);
	struct drm_device *drm_dev = pci_get_drvdata(pdev);
	int ret;

691 692
	if (drm_dev->switch_power_state == DRM_SWITCH_POWER_OFF ||
	    drm_dev->switch_power_state == DRM_SWITCH_POWER_DYNAMIC_OFF)
D
Dave Airlie 已提交
693 694 695 696 697 698 699 700 701
		return 0;

	pci_set_power_state(pdev, PCI_D0);
	pci_restore_state(pdev);
	ret = pci_enable_device(pdev);
	if (ret)
		return ret;
	pci_set_master(pdev);

702 703 704 705 706 707
	ret = nouveau_do_resume(drm_dev, false);

	/* Monitors may have been connected / disconnected during suspend */
	schedule_work(&nouveau_drm(drm_dev)->hpd_work);

	return ret;
D
Dave Airlie 已提交
708 709
}

710 711
static int
nouveau_pmops_freeze(struct device *dev)
D
Dave Airlie 已提交
712 713 714
{
	struct pci_dev *pdev = to_pci_dev(dev);
	struct drm_device *drm_dev = pci_get_drvdata(pdev);
715
	return nouveau_do_suspend(drm_dev, false);
D
Dave Airlie 已提交
716 717
}

718 719
static int
nouveau_pmops_thaw(struct device *dev)
D
Dave Airlie 已提交
720 721 722
{
	struct pci_dev *pdev = to_pci_dev(dev);
	struct drm_device *drm_dev = pci_get_drvdata(pdev);
723
	return nouveau_do_resume(drm_dev, false);
D
Dave Airlie 已提交
724 725
}

726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750
static int
nouveau_pmops_runtime_suspend(struct device *dev)
{
	struct pci_dev *pdev = to_pci_dev(dev);
	struct drm_device *drm_dev = pci_get_drvdata(pdev);
	int ret;

	if (nouveau_runtime_pm == 0) {
		pm_runtime_forbid(dev);
		return -EBUSY;
	}

	/* are we optimus enabled? */
	if (nouveau_runtime_pm == -1 && !nouveau_is_optimus() && !nouveau_is_v1_dsm()) {
		DRM_DEBUG_DRIVER("failing to power off - not optimus\n");
		pm_runtime_forbid(dev);
		return -EBUSY;
	}

	drm_kms_helper_poll_disable(drm_dev);
	vga_switcheroo_set_dynamic_switch(pdev, VGA_SWITCHEROO_OFF);
	nouveau_switcheroo_optimus_dsm();
	ret = nouveau_do_suspend(drm_dev, true);
	pci_save_state(pdev);
	pci_disable_device(pdev);
D
Dave Airlie 已提交
751
	pci_ignore_hotplug(pdev);
752 753 754 755 756 757 758 759 760 761
	pci_set_power_state(pdev, PCI_D3cold);
	drm_dev->switch_power_state = DRM_SWITCH_POWER_DYNAMIC_OFF;
	return ret;
}

static int
nouveau_pmops_runtime_resume(struct device *dev)
{
	struct pci_dev *pdev = to_pci_dev(dev);
	struct drm_device *drm_dev = pci_get_drvdata(pdev);
762
	struct nvif_device *device = &nouveau_drm(drm_dev)->client.device;
763 764 765 766 767 768 769 770 771 772 773 774 775
	int ret;

	if (nouveau_runtime_pm == 0)
		return -EINVAL;

	pci_set_power_state(pdev, PCI_D0);
	pci_restore_state(pdev);
	ret = pci_enable_device(pdev);
	if (ret)
		return ret;
	pci_set_master(pdev);

	ret = nouveau_do_resume(drm_dev, true);
776 777 778 779

	if (!drm_dev->mode_config.poll_enabled)
		drm_kms_helper_poll_enable(drm_dev);

780
	/* do magic */
781
	nvif_mask(&device->object, 0x088488, (1 << 25), (1 << 25));
782 783
	vga_switcheroo_set_dynamic_switch(pdev, VGA_SWITCHEROO_ON);
	drm_dev->switch_power_state = DRM_SWITCH_POWER_ON;
784 785 786 787

	/* Monitors may have been connected / disconnected during suspend */
	schedule_work(&nouveau_drm(drm_dev)->hpd_work);

788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 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
	return ret;
}

static int
nouveau_pmops_runtime_idle(struct device *dev)
{
	struct pci_dev *pdev = to_pci_dev(dev);
	struct drm_device *drm_dev = pci_get_drvdata(pdev);
	struct nouveau_drm *drm = nouveau_drm(drm_dev);
	struct drm_crtc *crtc;

	if (nouveau_runtime_pm == 0) {
		pm_runtime_forbid(dev);
		return -EBUSY;
	}

	/* are we optimus enabled? */
	if (nouveau_runtime_pm == -1 && !nouveau_is_optimus() && !nouveau_is_v1_dsm()) {
		DRM_DEBUG_DRIVER("failing to power off - not optimus\n");
		pm_runtime_forbid(dev);
		return -EBUSY;
	}

	/* if we have a hdmi audio device - make sure it has a driver loaded */
	if (drm->hdmi_device) {
		if (!drm->hdmi_device->driver) {
			DRM_DEBUG_DRIVER("failing to power off - no HDMI audio driver loaded\n");
			pm_runtime_mark_last_busy(dev);
			return -EBUSY;
		}
	}

	list_for_each_entry(crtc, &drm->dev->mode_config.crtc_list, head) {
		if (crtc->enabled) {
			DRM_DEBUG_DRIVER("failing to power off - crtc active\n");
			return -EBUSY;
		}
	}
	pm_runtime_mark_last_busy(dev);
	pm_runtime_autosuspend(dev);
	/* we don't want the main rpm_idle to call suspend - we want to autosuspend */
	return 1;
}
D
Dave Airlie 已提交
831

832
static int
833 834 835 836
nouveau_drm_open(struct drm_device *dev, struct drm_file *fpriv)
{
	struct nouveau_drm *drm = nouveau_drm(dev);
	struct nouveau_cli *cli;
837
	char name[32], tmpname[TASK_COMM_LEN];
838 839
	int ret;

840 841
	/* need to bring up power immediately if opening device */
	ret = pm_runtime_get_sync(dev->dev);
842
	if (ret < 0 && ret != -EACCES)
843 844
		return ret;

845 846
	get_task_comm(tmpname, current);
	snprintf(name, sizeof(name), "%s[%d]", tmpname, pid_nr(fpriv->pid));
847

848 849
	if (!(cli = kzalloc(sizeof(*cli), GFP_KERNEL)))
		return ret;
A
Alexandre Courbot 已提交
850

851
	ret = nouveau_cli_init(drm, name, cli);
852
	if (ret)
853
		goto done;
854

855 856
	cli->base.super = false;

857 858 859
	if (drm->client.device.info.family >= NV_DEVICE_INFO_V0_TESLA) {
		ret = nvkm_vm_new(nvxx_device(&drm->client.device), 0,
				  (1ULL << 40), 0x1000, NULL, &cli->vm);
860 861
		if (ret)
			goto done;
862

863
		nvxx_client(&cli->base)->vm = cli->vm;
864 865 866 867 868 869 870
	}

	fpriv->driver_priv = cli;

	mutex_lock(&drm->client.mutex);
	list_add(&cli->head, &drm->clients);
	mutex_unlock(&drm->client.mutex);
871

872 873 874 875 876 877
done:
	if (ret && cli) {
		nouveau_cli_fini(cli);
		kfree(cli);
	}

878 879 880
	pm_runtime_mark_last_busy(dev->dev);
	pm_runtime_put_autosuspend(dev->dev);
	return ret;
881 882
}

883
static void
884
nouveau_drm_postclose(struct drm_device *dev, struct drm_file *fpriv)
885 886 887 888
{
	struct nouveau_cli *cli = nouveau_cli(fpriv);
	struct nouveau_drm *drm = nouveau_drm(dev);

889 890
	pm_runtime_get_sync(dev->dev);

891
	mutex_lock(&cli->mutex);
892 893
	if (cli->abi16)
		nouveau_abi16_fini(cli->abi16);
894
	mutex_unlock(&cli->mutex);
895 896 897 898

	mutex_lock(&drm->client.mutex);
	list_del(&cli->head);
	mutex_unlock(&drm->client.mutex);
899

900 901
	nouveau_cli_fini(cli);
	kfree(cli);
902 903
	pm_runtime_mark_last_busy(dev->dev);
	pm_runtime_put_autosuspend(dev->dev);
904 905
}

R
Rob Clark 已提交
906
static const struct drm_ioctl_desc
907
nouveau_ioctls[] = {
908 909 910 911 912 913 914 915 916 917 918 919
	DRM_IOCTL_DEF_DRV(NOUVEAU_GETPARAM, nouveau_abi16_ioctl_getparam, DRM_AUTH|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(NOUVEAU_SETPARAM, nouveau_abi16_ioctl_setparam, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),
	DRM_IOCTL_DEF_DRV(NOUVEAU_CHANNEL_ALLOC, nouveau_abi16_ioctl_channel_alloc, DRM_AUTH|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(NOUVEAU_CHANNEL_FREE, nouveau_abi16_ioctl_channel_free, DRM_AUTH|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(NOUVEAU_GROBJ_ALLOC, nouveau_abi16_ioctl_grobj_alloc, DRM_AUTH|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(NOUVEAU_NOTIFIEROBJ_ALLOC, nouveau_abi16_ioctl_notifierobj_alloc, DRM_AUTH|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(NOUVEAU_GPUOBJ_FREE, nouveau_abi16_ioctl_gpuobj_free, DRM_AUTH|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(NOUVEAU_GEM_NEW, nouveau_gem_ioctl_new, DRM_AUTH|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(NOUVEAU_GEM_PUSHBUF, nouveau_gem_ioctl_pushbuf, DRM_AUTH|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(NOUVEAU_GEM_CPU_PREP, nouveau_gem_ioctl_cpu_prep, DRM_AUTH|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(NOUVEAU_GEM_CPU_FINI, nouveau_gem_ioctl_cpu_fini, DRM_AUTH|DRM_RENDER_ALLOW),
	DRM_IOCTL_DEF_DRV(NOUVEAU_GEM_INFO, nouveau_gem_ioctl_info, DRM_AUTH|DRM_RENDER_ALLOW),
920 921
};

922 923
long
nouveau_drm_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
924
{
925 926
	struct drm_file *filp = file->private_data;
	struct drm_device *dev = filp->minor->dev;
927 928 929
	long ret;

	ret = pm_runtime_get_sync(dev->dev);
930
	if (ret < 0 && ret != -EACCES)
931 932
		return ret;

933 934 935 936 937 938 939 940
	switch (_IOC_NR(cmd) - DRM_COMMAND_BASE) {
	case DRM_NOUVEAU_NVIF:
		ret = usif_ioctl(filp, (void __user *)arg, _IOC_SIZE(cmd));
		break;
	default:
		ret = drm_ioctl(file, cmd, arg);
		break;
	}
941 942 943 944 945

	pm_runtime_mark_last_busy(dev->dev);
	pm_runtime_put_autosuspend(dev->dev);
	return ret;
}
946

947 948 949 950 951
static const struct file_operations
nouveau_driver_fops = {
	.owner = THIS_MODULE,
	.open = drm_open,
	.release = drm_release,
952
	.unlocked_ioctl = nouveau_drm_ioctl,
953 954 955 956 957 958 959 960 961 962
	.mmap = nouveau_ttm_mmap,
	.poll = drm_poll,
	.read = drm_read,
#if defined(CONFIG_COMPAT)
	.compat_ioctl = nouveau_compat_ioctl,
#endif
	.llseek = noop_llseek,
};

static struct drm_driver
963
driver_stub = {
964
	.driver_features =
965 966
		DRIVER_GEM | DRIVER_MODESET | DRIVER_PRIME | DRIVER_RENDER |
		DRIVER_KMS_LEGACY_CONTEXT,
967 968 969 970 971 972 973

	.load = nouveau_drm_load,
	.unload = nouveau_drm_unload,
	.open = nouveau_drm_open,
	.postclose = nouveau_drm_postclose,
	.lastclose = nouveau_vga_lastclose,

974
#if defined(CONFIG_DEBUG_FS)
975
	.debugfs_init = nouveau_drm_debugfs_init,
976 977
#endif

978 979
	.enable_vblank = nouveau_display_vblank_enable,
	.disable_vblank = nouveau_display_vblank_disable,
980
	.get_scanout_position = nouveau_display_scanoutpos,
981
	.get_vblank_timestamp = drm_calc_vbltimestamp_from_scanoutpos,
982 983

	.ioctls = nouveau_ioctls,
R
Rob Clark 已提交
984
	.num_ioctls = ARRAY_SIZE(nouveau_ioctls),
985 986 987 988
	.fops = &nouveau_driver_fops,

	.prime_handle_to_fd = drm_gem_prime_handle_to_fd,
	.prime_fd_to_handle = drm_gem_prime_fd_to_handle,
A
Aaron Plattner 已提交
989 990 991
	.gem_prime_export = drm_gem_prime_export,
	.gem_prime_import = drm_gem_prime_import,
	.gem_prime_pin = nouveau_gem_prime_pin,
992
	.gem_prime_res_obj = nouveau_gem_prime_res_obj,
993
	.gem_prime_unpin = nouveau_gem_prime_unpin,
A
Aaron Plattner 已提交
994 995 996 997
	.gem_prime_get_sg_table = nouveau_gem_prime_get_sg_table,
	.gem_prime_import_sg_table = nouveau_gem_prime_import_sg_table,
	.gem_prime_vmap = nouveau_gem_prime_vmap,
	.gem_prime_vunmap = nouveau_gem_prime_vunmap,
998

999
	.gem_free_object_unlocked = nouveau_gem_object_del,
1000 1001 1002 1003 1004
	.gem_open_object = nouveau_gem_object_open,
	.gem_close_object = nouveau_gem_object_close,

	.dumb_create = nouveau_display_dumb_create,
	.dumb_map_offset = nouveau_display_dumb_map_offset,
1005
	.dumb_destroy = drm_gem_dumb_destroy,
1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018

	.name = DRIVER_NAME,
	.desc = DRIVER_DESC,
#ifdef GIT_REVISION
	.date = GIT_REVISION,
#else
	.date = DRIVER_DATE,
#endif
	.major = DRIVER_MAJOR,
	.minor = DRIVER_MINOR,
	.patchlevel = DRIVER_PATCHLEVEL,
};

1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033
static struct pci_device_id
nouveau_drm_pci_table[] = {
	{
		PCI_DEVICE(PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID),
		.class = PCI_BASE_CLASS_DISPLAY << 16,
		.class_mask  = 0xff << 16,
	},
	{
		PCI_DEVICE(PCI_VENDOR_ID_NVIDIA_SGS, PCI_ANY_ID),
		.class = PCI_BASE_CLASS_DISPLAY << 16,
		.class_mask  = 0xff << 16,
	},
	{}
};

1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047
static void nouveau_display_options(void)
{
	DRM_DEBUG_DRIVER("Loading Nouveau with parameters:\n");

	DRM_DEBUG_DRIVER("... tv_disable   : %d\n", nouveau_tv_disable);
	DRM_DEBUG_DRIVER("... ignorelid    : %d\n", nouveau_ignorelid);
	DRM_DEBUG_DRIVER("... duallink     : %d\n", nouveau_duallink);
	DRM_DEBUG_DRIVER("... nofbaccel    : %d\n", nouveau_nofbaccel);
	DRM_DEBUG_DRIVER("... config       : %s\n", nouveau_config);
	DRM_DEBUG_DRIVER("... debug        : %s\n", nouveau_debug);
	DRM_DEBUG_DRIVER("... noaccel      : %d\n", nouveau_noaccel);
	DRM_DEBUG_DRIVER("... modeset      : %d\n", nouveau_modeset);
	DRM_DEBUG_DRIVER("... runpm        : %d\n", nouveau_runtime_pm);
	DRM_DEBUG_DRIVER("... vram_pushbuf : %d\n", nouveau_vram_pushbuf);
1048
	DRM_DEBUG_DRIVER("... hdmimhz      : %d\n", nouveau_hdmimhz);
1049 1050
}

D
Dave Airlie 已提交
1051 1052 1053 1054 1055 1056 1057
static const struct dev_pm_ops nouveau_pm_ops = {
	.suspend = nouveau_pmops_suspend,
	.resume = nouveau_pmops_resume,
	.freeze = nouveau_pmops_freeze,
	.thaw = nouveau_pmops_thaw,
	.poweroff = nouveau_pmops_freeze,
	.restore = nouveau_pmops_resume,
1058 1059 1060
	.runtime_suspend = nouveau_pmops_runtime_suspend,
	.runtime_resume = nouveau_pmops_runtime_resume,
	.runtime_idle = nouveau_pmops_runtime_idle,
D
Dave Airlie 已提交
1061 1062
};

1063 1064 1065 1066 1067 1068
static struct pci_driver
nouveau_drm_pci_driver = {
	.name = "nouveau",
	.id_table = nouveau_drm_pci_table,
	.probe = nouveau_drm_probe,
	.remove = nouveau_drm_remove,
D
Dave Airlie 已提交
1069
	.driver.pm = &nouveau_pm_ops,
1070 1071
};

1072
struct drm_device *
1073 1074
nouveau_platform_device_create(const struct nvkm_device_tegra_func *func,
			       struct platform_device *pdev,
1075
			       struct nvkm_device **pdevice)
A
Alexandre Courbot 已提交
1076
{
1077 1078
	struct drm_device *drm;
	int err;
A
Alexandre Courbot 已提交
1079

1080
	err = nvkm_device_tegra_new(func, pdev, nouveau_config, nouveau_debug,
1081
				    true, true, ~0ULL, pdevice);
1082
	if (err)
1083
		goto err_free;
1084

1085
	drm = drm_dev_alloc(&driver_platform, &pdev->dev);
1086 1087
	if (IS_ERR(drm)) {
		err = PTR_ERR(drm);
1088
		goto err_free;
A
Alexandre Courbot 已提交
1089 1090
	}

1091 1092 1093 1094 1095
	platform_set_drvdata(pdev, drm);

	return drm;

err_free:
1096
	nvkm_device_del(pdevice);
1097 1098

	return ERR_PTR(err);
A
Alexandre Courbot 已提交
1099 1100
}

1101 1102 1103
static int __init
nouveau_drm_init(void)
{
1104 1105 1106 1107
	driver_pci = driver_stub;
	driver_pci.set_busid = drm_pci_set_busid;
	driver_platform = driver_stub;

1108 1109
	nouveau_display_options();

1110 1111 1112 1113 1114 1115 1116 1117
	if (nouveau_modeset == -1) {
		if (vgacon_text_force())
			nouveau_modeset = 0;
	}

	if (!nouveau_modeset)
		return 0;

1118 1119 1120 1121
#ifdef CONFIG_NOUVEAU_PLATFORM_DRIVER
	platform_driver_register(&nouveau_platform_driver);
#endif

1122
	nouveau_register_dsm_handler();
1123
	nouveau_backlight_ctor();
1124
	return drm_pci_init(&driver_pci, &nouveau_drm_pci_driver);
1125 1126 1127 1128 1129
}

static void __exit
nouveau_drm_exit(void)
{
1130 1131 1132
	if (!nouveau_modeset)
		return;

1133
	drm_pci_exit(&driver_pci, &nouveau_drm_pci_driver);
1134
	nouveau_backlight_dtor();
1135
	nouveau_unregister_dsm_handler();
1136 1137 1138 1139

#ifdef CONFIG_NOUVEAU_PLATFORM_DRIVER
	platform_driver_unregister(&nouveau_platform_driver);
#endif
1140 1141 1142 1143 1144 1145
}

module_init(nouveau_drm_init);
module_exit(nouveau_drm_exit);

MODULE_DEVICE_TABLE(pci, nouveau_drm_pci_table);
1146 1147
MODULE_AUTHOR(DRIVER_AUTHOR);
MODULE_DESCRIPTION(DRIVER_DESC);
1148
MODULE_LICENSE("GPL and additional rights");