diff options
| -rw-r--r-- | drivers/gpu/drm/i915/i915_dma.c | 10 | ||||
| -rw-r--r-- | drivers/gpu/drm/i915/i915_drv.h | 2 | ||||
| -rw-r--r-- | drivers/gpu/drm/i915/i915_gem.c | 9 | 
3 files changed, 19 insertions, 2 deletions
| diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c index 553dd4bc307..afa8a12cd00 100644 --- a/drivers/gpu/drm/i915/i915_dma.c +++ b/drivers/gpu/drm/i915/i915_dma.c | |||
| @@ -717,7 +717,7 @@ static int i915_getparam(struct drm_device *dev, void *data, | |||
| 717 | value = dev->pci_device; | 717 | value = dev->pci_device; | 
| 718 | break; | 718 | break; | 
| 719 | case I915_PARAM_HAS_GEM: | 719 | case I915_PARAM_HAS_GEM: | 
| 720 | value = 1; | 720 | value = dev_priv->has_gem; | 
| 721 | break; | 721 | break; | 
| 722 | default: | 722 | default: | 
| 723 | DRM_ERROR("Unknown parameter %d\n", param->param); | 723 | DRM_ERROR("Unknown parameter %d\n", param->param); | 
| @@ -830,6 +830,14 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
| 830 | 830 | ||
| 831 | dev_priv->regs = ioremap(base, size); | 831 | dev_priv->regs = ioremap(base, size); | 
| 832 | 832 | ||
| 833 | #ifdef CONFIG_HIGHMEM64G | ||
| 834 | /* don't enable GEM on PAE - needs agp + set_memory_* interface fixes */ | ||
| 835 | dev_priv->has_gem = 0; | ||
| 836 | #else | ||
| 837 | /* enable GEM by default */ | ||
| 838 | dev_priv->has_gem = 1; | ||
| 839 | #endif | ||
| 840 | |||
| 833 | i915_gem_load(dev); | 841 | i915_gem_load(dev); | 
| 834 | 842 | ||
| 835 | /* Init HWS */ | 843 | /* Init HWS */ | 
| diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h index adc972cc6bf..b3cc4731aa7 100644 --- a/drivers/gpu/drm/i915/i915_drv.h +++ b/drivers/gpu/drm/i915/i915_drv.h | |||
| @@ -106,6 +106,8 @@ struct intel_opregion { | |||
| 106 | typedef struct drm_i915_private { | 106 | typedef struct drm_i915_private { | 
| 107 | struct drm_device *dev; | 107 | struct drm_device *dev; | 
| 108 | 108 | ||
| 109 | int has_gem; | ||
| 110 | |||
| 109 | void __iomem *regs; | 111 | void __iomem *regs; | 
| 110 | drm_local_map_t *sarea; | 112 | drm_local_map_t *sarea; | 
| 111 | 113 | ||
| diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c index ad672d85482..24fe8c10b4b 100644 --- a/drivers/gpu/drm/i915/i915_gem.c +++ b/drivers/gpu/drm/i915/i915_gem.c | |||
| @@ -2309,7 +2309,14 @@ i915_gem_busy_ioctl(struct drm_device *dev, void *data, | |||
| 2309 | } | 2309 | } | 
| 2310 | 2310 | ||
| 2311 | obj_priv = obj->driver_private; | 2311 | obj_priv = obj->driver_private; | 
| 2312 | args->busy = obj_priv->active; | 2312 | /* Don't count being on the flushing list against the object being | 
| 2313 | * done. Otherwise, a buffer left on the flushing list but not getting | ||
| 2314 | * flushed (because nobody's flushing that domain) won't ever return | ||
| 2315 | * unbusy and get reused by libdrm's bo cache. The other expected | ||
| 2316 | * consumer of this interface, OpenGL's occlusion queries, also specs | ||
| 2317 | * that the objects get unbusy "eventually" without any interference. | ||
| 2318 | */ | ||
| 2319 | args->busy = obj_priv->active && obj_priv->last_rendering_seqno != 0; | ||
| 2313 | 2320 | ||
| 2314 | drm_gem_object_unreference(obj); | 2321 | drm_gem_object_unreference(obj); | 
| 2315 | mutex_unlock(&dev->struct_mutex); | 2322 | mutex_unlock(&dev->struct_mutex); | 
