Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 228769
b: refs/heads/master
c: 87ca9c8
h: refs/heads/master
i:
  228767: 96888c2
v: v3
  • Loading branch information
Chris Wilson committed Dec 2, 2010
1 parent 529a745 commit 89d31c5
Show file tree
Hide file tree
Showing 4 changed files with 14 additions and 4 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 257e48f1474a1f5bfa6fcafb12f77a8479063293
refs/heads/master: 87ca9c8a7ea9c8c7ce1561edaad1aa8570f1a01e
6 changes: 6 additions & 0 deletions trunk/drivers/gpu/drm/i915/i915_drv.h
Original file line number Diff line number Diff line change
Expand Up @@ -728,6 +728,12 @@ struct drm_i915_gem_object {
*/
unsigned int dirty : 1;

/**
* This is set if the object has been written to since the last
* GPU flush.
*/
unsigned int pending_gpu_write : 1;

/**
* Fence register bits (if any) for this object. Will be set
* as needed when mapped into the GTT.
Expand Down
9 changes: 6 additions & 3 deletions trunk/drivers/gpu/drm/i915/i915_gem.c
Original file line number Diff line number Diff line change
Expand Up @@ -1643,6 +1643,7 @@ i915_gem_object_move_to_inactive(struct drm_i915_gem_object *obj)
obj->last_fenced_ring = NULL;

obj->active = 0;
obj->pending_gpu_write = false;
drm_gem_object_unreference(&obj->base);

WARN_ON(i915_verify_lists(dev));
Expand Down Expand Up @@ -2810,9 +2811,11 @@ i915_gem_object_set_to_gtt_domain(struct drm_i915_gem_object *obj, bool write)
return -EINVAL;

i915_gem_object_flush_gpu_write_domain(obj);
ret = i915_gem_object_wait_rendering(obj, true);
if (ret)
return ret;
if (obj->pending_gpu_write || write) {
ret = i915_gem_object_wait_rendering(obj, true);
if (ret)
return ret;
}

i915_gem_object_flush_cpu_write_domain(obj);

Expand Down
1 change: 1 addition & 0 deletions trunk/drivers/gpu/drm/i915/i915_gem_execbuffer.c
Original file line number Diff line number Diff line change
Expand Up @@ -775,6 +775,7 @@ i915_gem_execbuffer_move_to_active(struct list_head *objects,
i915_gem_object_move_to_active(obj, ring);
if (obj->base.write_domain) {
obj->dirty = 1;
obj->pending_gpu_write = true;
list_move_tail(&obj->gpu_write_list,
&ring->gpu_write_list);
intel_mark_busy(ring->dev, obj);
Expand Down

0 comments on commit 89d31c5

Please sign in to comment.