From d669d153f2100a81a300aacda2a00ebad1c5727a Mon Sep 17 00:00:00 2001 From: Owain Ainsworth Date: Fri, 23 Apr 2010 17:13:36 +0000 Subject: Add a barrier before we submit the ringbuffer and before we do anything that kills gtt mappings. In both of these case we want all writes to hit the bus before we do whatever we're about to do. Doesn't solve any problems that I know of but it may help. --- sys/dev/pci/drm/i915_drv.c | 6 ++++++ 1 file changed, 6 insertions(+) (limited to 'sys/dev/pci/drm') diff --git a/sys/dev/pci/drm/i915_drv.c b/sys/dev/pci/drm/i915_drv.c index ea650513445..2ef59c22776 100644 --- a/sys/dev/pci/drm/i915_drv.c +++ b/sys/dev/pci/drm/i915_drv.c @@ -787,6 +787,7 @@ inteldrm_advance_ring(struct drm_i915_private *dev_priv) { INTELDRM_VPRINTF("%s: %x, %x\n", __func__, dev_priv->ring.wspace, dev_priv->ring.woffset); + DRM_MEMORYBARRIER(); I915_WRITE(PRB0_TAIL, dev_priv->ring.tail); } @@ -1672,6 +1673,7 @@ i915_gem_object_unbind(struct drm_obj *obj, int interruptible) /* if it's purgeable don't bother dirtying the pages */ if (i915_obj_purgeable(obj_priv)) atomic_clearbits_int(&obj_priv->io_flags, I915_DIRTY); + /* * unload the map, then unwire the backing object. */ @@ -2234,6 +2236,10 @@ inteldrm_wipe_mappings(struct drm_obj *obj) struct drm_i915_private *dev_priv = dev->dev_private; struct vm_page *pg; + /* make sure any writes hit the bus before we do whatever change + * that prompted us to kill the mappings. + */ + DRM_MEMORYBARRIER(); /* nuke all our mappings. XXX optimise. */ for (pg = &dev_priv->pgs[atop(obj_priv->gtt_offset)]; pg != &dev_priv->pgs[atop(obj_priv->gtt_offset + obj->size)]; pg++) -- cgit v1.2.3