From 0ec4e5f630ed68ece3f176b174cfd66eff023904 Mon Sep 17 00:00:00 2001 From: Axel Davy Date: Tue, 13 Dec 2016 01:16:21 +0100 Subject: [PATCH] st/nine: Dirty MANAGED buffers at Lock time Tests suggest MANAGED buffers are made dirty at Lock time, not at Unlock time. Signed-off-by: Axel Davy --- src/gallium/state_trackers/nine/buffer9.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/gallium/state_trackers/nine/buffer9.c b/src/gallium/state_trackers/nine/buffer9.c index b22713b..ca4e438 100644 --- a/src/gallium/state_trackers/nine/buffer9.c +++ b/src/gallium/state_trackers/nine/buffer9.c @@ -244,6 +244,9 @@ NineBuffer9_Lock( struct NineBuffer9 *This, nine_csmt_process(This->base.base.device); } else u_box_union_2d(&This->managed.dirty_box, &This->managed.dirty_box, &box); + /* Tests trying to draw while the buffer is locked show that + * MANAGED buffers are made dirty at Lock time */ + BASEBUF_REGISTER_UPDATE(This); } *ppbData = (char *)This->managed.data + OffsetToLock; DBG("returning pointer %p\n", *ppbData); @@ -412,8 +415,6 @@ NineBuffer9_Unlock( struct NineBuffer9 *This ) nine_context_get_pipe_release(device); } else if (This->maps[This->nmaps].should_destroy_buf) nine_upload_release_buffer(device->buffer_upload, This->maps[This->nmaps].buf); - } else { - BASEBUF_REGISTER_UPDATE(This); } return D3D_OK; } -- 2.7.4