diff options
Diffstat (limited to 'drivers')
| -rw-r--r-- | drivers/gpu/drm/radeon/ni.c | 33 | ||||
| -rw-r--r-- | drivers/gpu/drm/radeon/radeon_benchmark.c | 21 | ||||
| -rw-r--r-- | drivers/gpu/drm/radeon/si.c | 1 |
3 files changed, 38 insertions, 17 deletions
diff --git a/drivers/gpu/drm/radeon/ni.c b/drivers/gpu/drm/radeon/ni.c index d4c633e12863..27769e724b6d 100644 --- a/drivers/gpu/drm/radeon/ni.c +++ b/drivers/gpu/drm/radeon/ni.c | |||
| @@ -468,13 +468,19 @@ static void cayman_gpu_init(struct radeon_device *rdev) | |||
| 468 | (rdev->pdev->device == 0x9907) || | 468 | (rdev->pdev->device == 0x9907) || |
| 469 | (rdev->pdev->device == 0x9908) || | 469 | (rdev->pdev->device == 0x9908) || |
| 470 | (rdev->pdev->device == 0x9909) || | 470 | (rdev->pdev->device == 0x9909) || |
| 471 | (rdev->pdev->device == 0x990B) || | ||
| 472 | (rdev->pdev->device == 0x990C) || | ||
| 473 | (rdev->pdev->device == 0x990F) || | ||
| 471 | (rdev->pdev->device == 0x9910) || | 474 | (rdev->pdev->device == 0x9910) || |
| 472 | (rdev->pdev->device == 0x9917)) { | 475 | (rdev->pdev->device == 0x9917) || |
| 476 | (rdev->pdev->device == 0x9999)) { | ||
| 473 | rdev->config.cayman.max_simds_per_se = 6; | 477 | rdev->config.cayman.max_simds_per_se = 6; |
| 474 | rdev->config.cayman.max_backends_per_se = 2; | 478 | rdev->config.cayman.max_backends_per_se = 2; |
| 475 | } else if ((rdev->pdev->device == 0x9903) || | 479 | } else if ((rdev->pdev->device == 0x9903) || |
| 476 | (rdev->pdev->device == 0x9904) || | 480 | (rdev->pdev->device == 0x9904) || |
| 477 | (rdev->pdev->device == 0x990A) || | 481 | (rdev->pdev->device == 0x990A) || |
| 482 | (rdev->pdev->device == 0x990D) || | ||
| 483 | (rdev->pdev->device == 0x990E) || | ||
| 478 | (rdev->pdev->device == 0x9913) || | 484 | (rdev->pdev->device == 0x9913) || |
| 479 | (rdev->pdev->device == 0x9918)) { | 485 | (rdev->pdev->device == 0x9918)) { |
| 480 | rdev->config.cayman.max_simds_per_se = 4; | 486 | rdev->config.cayman.max_simds_per_se = 4; |
| @@ -483,6 +489,9 @@ static void cayman_gpu_init(struct radeon_device *rdev) | |||
| 483 | (rdev->pdev->device == 0x9990) || | 489 | (rdev->pdev->device == 0x9990) || |
| 484 | (rdev->pdev->device == 0x9991) || | 490 | (rdev->pdev->device == 0x9991) || |
| 485 | (rdev->pdev->device == 0x9994) || | 491 | (rdev->pdev->device == 0x9994) || |
| 492 | (rdev->pdev->device == 0x9995) || | ||
| 493 | (rdev->pdev->device == 0x9996) || | ||
| 494 | (rdev->pdev->device == 0x999A) || | ||
| 486 | (rdev->pdev->device == 0x99A0)) { | 495 | (rdev->pdev->device == 0x99A0)) { |
| 487 | rdev->config.cayman.max_simds_per_se = 3; | 496 | rdev->config.cayman.max_simds_per_se = 3; |
| 488 | rdev->config.cayman.max_backends_per_se = 1; | 497 | rdev->config.cayman.max_backends_per_se = 1; |
| @@ -616,11 +625,22 @@ static void cayman_gpu_init(struct radeon_device *rdev) | |||
| 616 | WREG32(DMA_TILING_CONFIG + DMA0_REGISTER_OFFSET, gb_addr_config); | 625 | WREG32(DMA_TILING_CONFIG + DMA0_REGISTER_OFFSET, gb_addr_config); |
| 617 | WREG32(DMA_TILING_CONFIG + DMA1_REGISTER_OFFSET, gb_addr_config); | 626 | WREG32(DMA_TILING_CONFIG + DMA1_REGISTER_OFFSET, gb_addr_config); |
| 618 | 627 | ||
| 619 | tmp = gb_addr_config & NUM_PIPES_MASK; | 628 | if ((rdev->config.cayman.max_backends_per_se == 1) && |
| 620 | tmp = r6xx_remap_render_backend(rdev, tmp, | 629 | (rdev->flags & RADEON_IS_IGP)) { |
| 621 | rdev->config.cayman.max_backends_per_se * | 630 | if ((disabled_rb_mask & 3) == 1) { |
| 622 | rdev->config.cayman.max_shader_engines, | 631 | /* RB0 disabled, RB1 enabled */ |
| 623 | CAYMAN_MAX_BACKENDS, disabled_rb_mask); | 632 | tmp = 0x11111111; |
| 633 | } else { | ||
| 634 | /* RB1 disabled, RB0 enabled */ | ||
| 635 | tmp = 0x00000000; | ||
| 636 | } | ||
| 637 | } else { | ||
| 638 | tmp = gb_addr_config & NUM_PIPES_MASK; | ||
| 639 | tmp = r6xx_remap_render_backend(rdev, tmp, | ||
| 640 | rdev->config.cayman.max_backends_per_se * | ||
| 641 | rdev->config.cayman.max_shader_engines, | ||
| 642 | CAYMAN_MAX_BACKENDS, disabled_rb_mask); | ||
| 643 | } | ||
| 624 | WREG32(GB_BACKEND_MAP, tmp); | 644 | WREG32(GB_BACKEND_MAP, tmp); |
| 625 | 645 | ||
| 626 | cgts_tcc_disable = 0xffff0000; | 646 | cgts_tcc_disable = 0xffff0000; |
| @@ -1771,6 +1791,7 @@ int cayman_resume(struct radeon_device *rdev) | |||
| 1771 | int cayman_suspend(struct radeon_device *rdev) | 1791 | int cayman_suspend(struct radeon_device *rdev) |
| 1772 | { | 1792 | { |
| 1773 | r600_audio_fini(rdev); | 1793 | r600_audio_fini(rdev); |
| 1794 | radeon_vm_manager_fini(rdev); | ||
| 1774 | cayman_cp_enable(rdev, false); | 1795 | cayman_cp_enable(rdev, false); |
| 1775 | cayman_dma_stop(rdev); | 1796 | cayman_dma_stop(rdev); |
| 1776 | evergreen_irq_suspend(rdev); | 1797 | evergreen_irq_suspend(rdev); |
diff --git a/drivers/gpu/drm/radeon/radeon_benchmark.c b/drivers/gpu/drm/radeon/radeon_benchmark.c index bedda9caadd9..6e05a2e75a46 100644 --- a/drivers/gpu/drm/radeon/radeon_benchmark.c +++ b/drivers/gpu/drm/radeon/radeon_benchmark.c | |||
| @@ -122,10 +122,7 @@ static void radeon_benchmark_move(struct radeon_device *rdev, unsigned size, | |||
| 122 | goto out_cleanup; | 122 | goto out_cleanup; |
| 123 | } | 123 | } |
| 124 | 124 | ||
| 125 | /* r100 doesn't have dma engine so skip the test */ | 125 | if (rdev->asic->copy.dma) { |
| 126 | /* also, VRAM-to-VRAM test doesn't make much sense for DMA */ | ||
| 127 | /* skip it as well if domains are the same */ | ||
| 128 | if ((rdev->asic->copy.dma) && (sdomain != ddomain)) { | ||
| 129 | time = radeon_benchmark_do_move(rdev, size, saddr, daddr, | 126 | time = radeon_benchmark_do_move(rdev, size, saddr, daddr, |
| 130 | RADEON_BENCHMARK_COPY_DMA, n); | 127 | RADEON_BENCHMARK_COPY_DMA, n); |
| 131 | if (time < 0) | 128 | if (time < 0) |
| @@ -135,13 +132,15 @@ static void radeon_benchmark_move(struct radeon_device *rdev, unsigned size, | |||
| 135 | sdomain, ddomain, "dma"); | 132 | sdomain, ddomain, "dma"); |
| 136 | } | 133 | } |
| 137 | 134 | ||
| 138 | time = radeon_benchmark_do_move(rdev, size, saddr, daddr, | 135 | if (rdev->asic->copy.blit) { |
| 139 | RADEON_BENCHMARK_COPY_BLIT, n); | 136 | time = radeon_benchmark_do_move(rdev, size, saddr, daddr, |
| 140 | if (time < 0) | 137 | RADEON_BENCHMARK_COPY_BLIT, n); |
| 141 | goto out_cleanup; | 138 | if (time < 0) |
| 142 | if (time > 0) | 139 | goto out_cleanup; |
| 143 | radeon_benchmark_log_results(n, size, time, | 140 | if (time > 0) |
| 144 | sdomain, ddomain, "blit"); | 141 | radeon_benchmark_log_results(n, size, time, |
| 142 | sdomain, ddomain, "blit"); | ||
| 143 | } | ||
| 145 | 144 | ||
| 146 | out_cleanup: | 145 | out_cleanup: |
| 147 | if (sobj) { | 146 | if (sobj) { |
diff --git a/drivers/gpu/drm/radeon/si.c b/drivers/gpu/drm/radeon/si.c index 9128120da044..bafbe3216952 100644 --- a/drivers/gpu/drm/radeon/si.c +++ b/drivers/gpu/drm/radeon/si.c | |||
| @@ -4469,6 +4469,7 @@ int si_resume(struct radeon_device *rdev) | |||
| 4469 | 4469 | ||
| 4470 | int si_suspend(struct radeon_device *rdev) | 4470 | int si_suspend(struct radeon_device *rdev) |
| 4471 | { | 4471 | { |
| 4472 | radeon_vm_manager_fini(rdev); | ||
| 4472 | si_cp_enable(rdev, false); | 4473 | si_cp_enable(rdev, false); |
| 4473 | cayman_dma_stop(rdev); | 4474 | cayman_dma_stop(rdev); |
| 4474 | si_irq_suspend(rdev); | 4475 | si_irq_suspend(rdev); |
