|
@@ -29,6 +29,26 @@
|
|
#include "i915_trace.h"
|
|
#include "i915_trace.h"
|
|
#include "intel_drv.h"
|
|
#include "intel_drv.h"
|
|
|
|
|
|
|
|
+/* XXX kill agp_type! */
|
|
|
|
+static unsigned int cache_level_to_agp_type(struct drm_device *dev,
|
|
|
|
+ enum i915_cache_level cache_level)
|
|
|
|
+{
|
|
|
|
+ switch (cache_level) {
|
|
|
|
+ case I915_CACHE_LLC_MLC:
|
|
|
|
+ if (INTEL_INFO(dev)->gen >= 6)
|
|
|
|
+ return AGP_USER_CACHED_MEMORY_LLC_MLC;
|
|
|
|
+ /* Older chipsets do not have this extra level of CPU
|
|
|
|
+ * cacheing, so fallthrough and request the PTE simply
|
|
|
|
+ * as cached.
|
|
|
|
+ */
|
|
|
|
+ case I915_CACHE_LLC:
|
|
|
|
+ return AGP_USER_CACHED_MEMORY;
|
|
|
|
+ default:
|
|
|
|
+ case I915_CACHE_NONE:
|
|
|
|
+ return AGP_USER_MEMORY;
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+
|
|
void i915_gem_restore_gtt_mappings(struct drm_device *dev)
|
|
void i915_gem_restore_gtt_mappings(struct drm_device *dev)
|
|
{
|
|
{
|
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
@@ -39,6 +59,9 @@ void i915_gem_restore_gtt_mappings(struct drm_device *dev)
|
|
(dev_priv->mm.gtt_end - dev_priv->mm.gtt_start) / PAGE_SIZE);
|
|
(dev_priv->mm.gtt_end - dev_priv->mm.gtt_start) / PAGE_SIZE);
|
|
|
|
|
|
list_for_each_entry(obj, &dev_priv->mm.gtt_list, gtt_list) {
|
|
list_for_each_entry(obj, &dev_priv->mm.gtt_list, gtt_list) {
|
|
|
|
+ unsigned int agp_type =
|
|
|
|
+ cache_level_to_agp_type(dev, obj->cache_level);
|
|
|
|
+
|
|
i915_gem_clflush_object(obj);
|
|
i915_gem_clflush_object(obj);
|
|
|
|
|
|
if (dev_priv->mm.gtt->needs_dmar) {
|
|
if (dev_priv->mm.gtt->needs_dmar) {
|
|
@@ -46,15 +69,14 @@ void i915_gem_restore_gtt_mappings(struct drm_device *dev)
|
|
|
|
|
|
intel_gtt_insert_sg_entries(obj->sg_list,
|
|
intel_gtt_insert_sg_entries(obj->sg_list,
|
|
obj->num_sg,
|
|
obj->num_sg,
|
|
- obj->gtt_space->start
|
|
|
|
- >> PAGE_SHIFT,
|
|
|
|
- obj->agp_type);
|
|
|
|
|
|
+ obj->gtt_space->start >> PAGE_SHIFT,
|
|
|
|
+ agp_type);
|
|
} else
|
|
} else
|
|
intel_gtt_insert_pages(obj->gtt_space->start
|
|
intel_gtt_insert_pages(obj->gtt_space->start
|
|
>> PAGE_SHIFT,
|
|
>> PAGE_SHIFT,
|
|
obj->base.size >> PAGE_SHIFT,
|
|
obj->base.size >> PAGE_SHIFT,
|
|
obj->pages,
|
|
obj->pages,
|
|
- obj->agp_type);
|
|
|
|
|
|
+ agp_type);
|
|
}
|
|
}
|
|
|
|
|
|
intel_gtt_chipset_flush();
|
|
intel_gtt_chipset_flush();
|
|
@@ -64,6 +86,7 @@ int i915_gem_gtt_bind_object(struct drm_i915_gem_object *obj)
|
|
{
|
|
{
|
|
struct drm_device *dev = obj->base.dev;
|
|
struct drm_device *dev = obj->base.dev;
|
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
|
|
+ unsigned int agp_type = cache_level_to_agp_type(dev, obj->cache_level);
|
|
int ret;
|
|
int ret;
|
|
|
|
|
|
if (dev_priv->mm.gtt->needs_dmar) {
|
|
if (dev_priv->mm.gtt->needs_dmar) {
|
|
@@ -77,12 +100,12 @@ int i915_gem_gtt_bind_object(struct drm_i915_gem_object *obj)
|
|
intel_gtt_insert_sg_entries(obj->sg_list,
|
|
intel_gtt_insert_sg_entries(obj->sg_list,
|
|
obj->num_sg,
|
|
obj->num_sg,
|
|
obj->gtt_space->start >> PAGE_SHIFT,
|
|
obj->gtt_space->start >> PAGE_SHIFT,
|
|
- obj->agp_type);
|
|
|
|
|
|
+ agp_type);
|
|
} else
|
|
} else
|
|
intel_gtt_insert_pages(obj->gtt_space->start >> PAGE_SHIFT,
|
|
intel_gtt_insert_pages(obj->gtt_space->start >> PAGE_SHIFT,
|
|
obj->base.size >> PAGE_SHIFT,
|
|
obj->base.size >> PAGE_SHIFT,
|
|
obj->pages,
|
|
obj->pages,
|
|
- obj->agp_type);
|
|
|
|
|
|
+ agp_type);
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
}
|
|
}
|