diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-11-10 12:33:06 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-11-10 12:33:06 -0500 |
commit | 3e82806b97398d542a5e03bd94861f79ce10ecee (patch) | |
tree | 467753d23d422fc42a07992ac25cae7889e48c18 /drivers/gpu/drm/msm/mdp/mdp5/mdp5_kms.c | |
parent | bd4f203e433387d39be404b67ad02acf6f76b7bc (diff) | |
parent | 816d2206f0f9953ca854e4ff1a2749a5cbd62715 (diff) |
Merge branch 'drm-next' of git://people.freedesktop.org/~airlied/linux
Pull drm updates from Dave Airlie:
"I Was Almost Tempted To Capitalise Every Word, but then I decided I
couldn't read it myself!
I've also got one pull request for the sti driver outstanding. It
relied on a commit in Greg's tree and I didn't find out in time, that
commit is in your tree now so I might send that along once this is
merged.
I also had the accidental misfortune to have access to a Skylake on my
desk for a few days, and I've had to encourage Intel to try harder,
which seems to be happening now.
Here is the main drm-next pull request for 4.4.
Highlights:
New driver:
vc4 driver for the Rasberry Pi VPU.
(From Eric Anholt at Broadcom.)
Core:
Atomic fbdev support
Atomic helpers for runtime pm
dp/aux i2c STATUS_UPDATE handling
struct_mutex usage cleanups.
Generic of probing support.
Documentation:
Kerneldoc for VGA switcheroo code.
Rename to gpu instead of drm to reflect scope.
i915:
Skylake GuC firmware fixes
HPD A support
VBT backlight fallbacks
Fastboot by default for some systems
FBC work
BXT/SKL workarounds
Skylake deeper sleep state fixes
amdgpu:
Enable GPU scheduler by default
New atombios opcodes
GPUVM debugging options
Stoney support.
Fencing cleanups.
radeon:
More efficient CS checking
nouveau:
gk20a instance memory handling improvements.
Improved PGOB detection and GK107 support
Kepler GDDR5 PLL statbility improvement
G8x/GT2xx reclock improvements
new userspace API compatiblity fixes.
virtio-gpu:
Add 3D support - qemu 2.5 has it merged for it's gtk backend.
msm:
Initial msm88896 (snapdragon 8200)
exynos:
HDMI cleanups
Enable mixer driver byt default
Add DECON-TV support
vmwgfx:
Move to using memremap + fixes.
rcar-du:
Add support for R8A7793/4 DU
armada:
Remove support for non-component mode
Improved plane handling
Power savings while in DPMS off.
tda998x:
Remove unused slave encoder support
Use more HDMI helpers
Fix EDID read handling
dwhdmi:
Interlace video mode support for ipu-v3/dw_hdmi
Hotplug state fixes
Audio driver integration
imx:
More color formats support.
tegra:
Minor fixes/improvements"
[ Merge fixup: remove unused variable 'dev' that had all uses removed in
commit 4e270f088011: "drm/gem: Drop struct_mutex requirement from
drm_gem_mmap_obj" ]
* 'drm-next' of git://people.freedesktop.org/~airlied/linux: (764 commits)
drm/vmwgfx: Relax irq locking somewhat
drm/vmwgfx: Properly flush cursor updates and page-flips
drm/i915/skl: disable display side power well support for now
drm/i915: Extend DSL readout fix to BDW and SKL.
drm/i915: Do graphics device reset under forcewake
drm/i915: Skip fence installation for objects with rotated views (v4)
vga_switcheroo: Drop client power state VGA_SWITCHEROO_INIT
drm/amdgpu: group together common fence implementation
drm/amdgpu: remove AMDGPU_FENCE_OWNER_MOVE
drm/amdgpu: remove now unused fence functions
drm/amdgpu: fix fence fallback check
drm/amdgpu: fix stoping the scheduler timeout
drm/amdgpu: cleanup on error in amdgpu_cs_ioctl()
drm/i915: Fix locking around GuC firmware load
drm/amdgpu: update Fiji's Golden setting
drm/amdgpu: update Fiji's rev id
drm/amdgpu: extract common code in vi_common_early_init
drm/amd/scheduler: don't oops on failure to load
drm/amdgpu: don't oops on failure to load (v2)
drm/amdgpu: don't VT switch on suspend
...
Diffstat (limited to 'drivers/gpu/drm/msm/mdp/mdp5/mdp5_kms.c')
-rw-r--r-- | drivers/gpu/drm/msm/mdp/mdp5/mdp5_kms.c | 46 |
1 files changed, 30 insertions, 16 deletions
diff --git a/drivers/gpu/drm/msm/mdp/mdp5/mdp5_kms.c b/drivers/gpu/drm/msm/mdp/mdp5/mdp5_kms.c index 047cb0433ccb..b532faa8026d 100644 --- a/drivers/gpu/drm/msm/mdp/mdp5/mdp5_kms.c +++ b/drivers/gpu/drm/msm/mdp/mdp5/mdp5_kms.c | |||
@@ -452,15 +452,19 @@ static void read_hw_revision(struct mdp5_kms *mdp5_kms, | |||
452 | } | 452 | } |
453 | 453 | ||
454 | static int get_clk(struct platform_device *pdev, struct clk **clkp, | 454 | static int get_clk(struct platform_device *pdev, struct clk **clkp, |
455 | const char *name) | 455 | const char *name, bool mandatory) |
456 | { | 456 | { |
457 | struct device *dev = &pdev->dev; | 457 | struct device *dev = &pdev->dev; |
458 | struct clk *clk = devm_clk_get(dev, name); | 458 | struct clk *clk = devm_clk_get(dev, name); |
459 | if (IS_ERR(clk)) { | 459 | if (IS_ERR(clk) && mandatory) { |
460 | dev_err(dev, "failed to get %s (%ld)\n", name, PTR_ERR(clk)); | 460 | dev_err(dev, "failed to get %s (%ld)\n", name, PTR_ERR(clk)); |
461 | return PTR_ERR(clk); | 461 | return PTR_ERR(clk); |
462 | } | 462 | } |
463 | *clkp = clk; | 463 | if (IS_ERR(clk)) |
464 | DBG("skipping %s", name); | ||
465 | else | ||
466 | *clkp = clk; | ||
467 | |||
464 | return 0; | 468 | return 0; |
465 | } | 469 | } |
466 | 470 | ||
@@ -514,25 +518,26 @@ struct msm_kms *mdp5_kms_init(struct drm_device *dev) | |||
514 | goto fail; | 518 | goto fail; |
515 | } | 519 | } |
516 | 520 | ||
517 | ret = get_clk(pdev, &mdp5_kms->axi_clk, "bus_clk"); | 521 | /* mandatory clocks: */ |
522 | ret = get_clk(pdev, &mdp5_kms->axi_clk, "bus_clk", true); | ||
518 | if (ret) | 523 | if (ret) |
519 | goto fail; | 524 | goto fail; |
520 | ret = get_clk(pdev, &mdp5_kms->ahb_clk, "iface_clk"); | 525 | ret = get_clk(pdev, &mdp5_kms->ahb_clk, "iface_clk", true); |
521 | if (ret) | 526 | if (ret) |
522 | goto fail; | 527 | goto fail; |
523 | ret = get_clk(pdev, &mdp5_kms->src_clk, "core_clk_src"); | 528 | ret = get_clk(pdev, &mdp5_kms->src_clk, "core_clk_src", true); |
524 | if (ret) | 529 | if (ret) |
525 | goto fail; | 530 | goto fail; |
526 | ret = get_clk(pdev, &mdp5_kms->core_clk, "core_clk"); | 531 | ret = get_clk(pdev, &mdp5_kms->core_clk, "core_clk", true); |
527 | if (ret) | 532 | if (ret) |
528 | goto fail; | 533 | goto fail; |
529 | ret = get_clk(pdev, &mdp5_kms->lut_clk, "lut_clk"); | 534 | ret = get_clk(pdev, &mdp5_kms->vsync_clk, "vsync_clk", true); |
530 | if (ret) | ||
531 | DBG("failed to get (optional) lut_clk clock"); | ||
532 | ret = get_clk(pdev, &mdp5_kms->vsync_clk, "vsync_clk"); | ||
533 | if (ret) | 535 | if (ret) |
534 | goto fail; | 536 | goto fail; |
535 | 537 | ||
538 | /* optional clocks: */ | ||
539 | get_clk(pdev, &mdp5_kms->lut_clk, "lut_clk", false); | ||
540 | |||
536 | /* we need to set a default rate before enabling. Set a safe | 541 | /* we need to set a default rate before enabling. Set a safe |
537 | * rate first, then figure out hw revision, and then set a | 542 | * rate first, then figure out hw revision, and then set a |
538 | * more optimal rate: | 543 | * more optimal rate: |
@@ -549,15 +554,23 @@ struct msm_kms *mdp5_kms_init(struct drm_device *dev) | |||
549 | } | 554 | } |
550 | 555 | ||
551 | config = mdp5_cfg_get_config(mdp5_kms->cfg); | 556 | config = mdp5_cfg_get_config(mdp5_kms->cfg); |
557 | mdp5_kms->caps = config->hw->mdp.caps; | ||
552 | 558 | ||
553 | /* TODO: compute core clock rate at runtime */ | 559 | /* TODO: compute core clock rate at runtime */ |
554 | clk_set_rate(mdp5_kms->src_clk, config->hw->max_clk); | 560 | clk_set_rate(mdp5_kms->src_clk, config->hw->max_clk); |
555 | 561 | ||
556 | mdp5_kms->smp = mdp5_smp_init(mdp5_kms->dev, &config->hw->smp); | 562 | /* |
557 | if (IS_ERR(mdp5_kms->smp)) { | 563 | * Some chipsets have a Shared Memory Pool (SMP), while others |
558 | ret = PTR_ERR(mdp5_kms->smp); | 564 | * have dedicated latency buffering per source pipe instead; |
559 | mdp5_kms->smp = NULL; | 565 | * this section initializes the SMP: |
560 | goto fail; | 566 | */ |
567 | if (mdp5_kms->caps & MDP_CAP_SMP) { | ||
568 | mdp5_kms->smp = mdp5_smp_init(mdp5_kms->dev, &config->hw->smp); | ||
569 | if (IS_ERR(mdp5_kms->smp)) { | ||
570 | ret = PTR_ERR(mdp5_kms->smp); | ||
571 | mdp5_kms->smp = NULL; | ||
572 | goto fail; | ||
573 | } | ||
561 | } | 574 | } |
562 | 575 | ||
563 | mdp5_kms->ctlm = mdp5_ctlm_init(dev, mdp5_kms->mmio, mdp5_kms->cfg); | 576 | mdp5_kms->ctlm = mdp5_ctlm_init(dev, mdp5_kms->mmio, mdp5_kms->cfg); |
@@ -586,6 +599,7 @@ struct msm_kms *mdp5_kms_init(struct drm_device *dev) | |||
586 | if (IS_ERR(mmu)) { | 599 | if (IS_ERR(mmu)) { |
587 | ret = PTR_ERR(mmu); | 600 | ret = PTR_ERR(mmu); |
588 | dev_err(dev->dev, "failed to init iommu: %d\n", ret); | 601 | dev_err(dev->dev, "failed to init iommu: %d\n", ret); |
602 | iommu_domain_free(config->platform.iommu); | ||
589 | goto fail; | 603 | goto fail; |
590 | } | 604 | } |
591 | 605 | ||