|
@@ -177,7 +177,7 @@ static int init_ring_common(struct drm_device *dev,
|
|
|
|
|
|
I915_WRITE_CTL(ring,
|
|
|
((ring->gem_object->size - PAGE_SIZE) & RING_NR_PAGES)
|
|
|
- | RING_NO_REPORT | RING_VALID);
|
|
|
+ | RING_REPORT_64K | RING_VALID);
|
|
|
|
|
|
head = I915_READ_HEAD(ring) & HEAD_ADDR;
|
|
|
/* If the head is still not zero, the ring is dead */
|
|
@@ -692,6 +692,17 @@ int intel_wait_ring_buffer(struct drm_device *dev,
|
|
|
{
|
|
|
unsigned long end;
|
|
|
drm_i915_private_t *dev_priv = dev->dev_private;
|
|
|
+ u32 head;
|
|
|
+
|
|
|
+ head = intel_read_status_page(ring, 4);
|
|
|
+ if (head) {
|
|
|
+ ring->head = head & HEAD_ADDR;
|
|
|
+ ring->space = ring->head - (ring->tail + 8);
|
|
|
+ if (ring->space < 0)
|
|
|
+ ring->space += ring->size;
|
|
|
+ if (ring->space >= n)
|
|
|
+ return 0;
|
|
|
+ }
|
|
|
|
|
|
trace_i915_ring_wait_begin (dev);
|
|
|
end = jiffies + 3 * HZ;
|