aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/i915_gem_gtt.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/drm/i915/i915_gem_gtt.c')
-rw-r--r--drivers/gpu/drm/i915/i915_gem_gtt.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/drivers/gpu/drm/i915/i915_gem_gtt.c b/drivers/gpu/drm/i915/i915_gem_gtt.c
index 5101ab6869b4..216e7a19e63d 100644
--- a/drivers/gpu/drm/i915/i915_gem_gtt.c
+++ b/drivers/gpu/drm/i915/i915_gem_gtt.c
@@ -28,6 +28,9 @@
28#include "i915_trace.h" 28#include "i915_trace.h"
29#include "intel_drv.h" 29#include "intel_drv.h"
30 30
31#define GEN6_PPGTT_PD_ENTRIES 512
32#define I915_PPGTT_PT_ENTRIES (PAGE_SIZE / sizeof(gen6_gtt_pte_t))
33
31/* PPGTT stuff */ 34/* PPGTT stuff */
32#define GEN6_GTT_ADDR_ENCODE(addr) ((addr) | (((addr) >> 28) & 0xff0)) 35#define GEN6_GTT_ADDR_ENCODE(addr) ((addr) | (((addr) >> 28) & 0xff0))
33 36
@@ -278,7 +281,7 @@ static int gen6_ppgtt_init(struct i915_hw_ppgtt *ppgtt)
278 } else { 281 } else {
279 ppgtt->pte_encode = gen6_pte_encode; 282 ppgtt->pte_encode = gen6_pte_encode;
280 } 283 }
281 ppgtt->num_pd_entries = I915_PPGTT_PD_ENTRIES; 284 ppgtt->num_pd_entries = GEN6_PPGTT_PD_ENTRIES;
282 ppgtt->enable = gen6_ppgtt_enable; 285 ppgtt->enable = gen6_ppgtt_enable;
283 ppgtt->clear_range = gen6_ppgtt_clear_range; 286 ppgtt->clear_range = gen6_ppgtt_clear_range;
284 ppgtt->insert_entries = gen6_ppgtt_insert_entries; 287 ppgtt->insert_entries = gen6_ppgtt_insert_entries;
@@ -688,7 +691,7 @@ void i915_gem_init_global_gtt(struct drm_device *dev)
688 if (INTEL_INFO(dev)->gen <= 7) { 691 if (INTEL_INFO(dev)->gen <= 7) {
689 /* PPGTT pdes are stolen from global gtt ptes, so shrink the 692 /* PPGTT pdes are stolen from global gtt ptes, so shrink the
690 * aperture accordingly when using aliasing ppgtt. */ 693 * aperture accordingly when using aliasing ppgtt. */
691 gtt_size -= I915_PPGTT_PD_ENTRIES*PAGE_SIZE; 694 gtt_size -= GEN6_PPGTT_PD_ENTRIES * PAGE_SIZE;
692 } 695 }
693 696
694 i915_gem_setup_global_gtt(dev, 0, mappable_size, gtt_size); 697 i915_gem_setup_global_gtt(dev, 0, mappable_size, gtt_size);
@@ -699,7 +702,7 @@ void i915_gem_init_global_gtt(struct drm_device *dev)
699 702
700 DRM_ERROR("Aliased PPGTT setup failed %d\n", ret); 703 DRM_ERROR("Aliased PPGTT setup failed %d\n", ret);
701 drm_mm_takedown(&dev_priv->mm.gtt_space); 704 drm_mm_takedown(&dev_priv->mm.gtt_space);
702 gtt_size += I915_PPGTT_PD_ENTRIES*PAGE_SIZE; 705 gtt_size += GEN6_PPGTT_PD_ENTRIES * PAGE_SIZE;
703 } 706 }
704 i915_gem_setup_global_gtt(dev, 0, mappable_size, gtt_size); 707 i915_gem_setup_global_gtt(dev, 0, mappable_size, gtt_size);
705} 708}