ilo: 3DSTATE_INDEX_BUFFER may be wrongly skipped
authorChia-I Wu <olvaffe@gmail.com>
Fri, 9 Aug 2013 16:48:28 +0000 (00:48 +0800)
committerChia-I Wu <olvaffe@gmail.com>
Sat, 10 Aug 2013 05:01:41 +0000 (13:01 +0800)
In finalize_index_buffer(), when the current index buffer was destroyed due to
u_upload_data(), it may happen that the new index buffer is at the same
address as the old one.  Comparing the pointers to the two buffers could fail
to work, and 3DSTATE_INDEX_BUFFER would be incorrectly skipped.

Holding a reference to the current index buffer before calling u_upload_data()
should fix the problem.

src/gallium/drivers/ilo/ilo_state.c

index 86470a784f80b2ffb66650d38dd1b59e38aa70e9..ce6930c4aec78dd04cce4e1b01dc87f69b51cf7e 100644 (file)
@@ -128,13 +128,15 @@ finalize_constant_buffers(struct ilo_context *ilo)
 static void
 finalize_index_buffer(struct ilo_context *ilo)
 {
-   const struct pipe_resource *current_hw_res = ilo->ib.hw_resource;
    const bool need_upload = (ilo->draw->indexed &&
          (ilo->ib.user_buffer || ilo->ib.offset % ilo->ib.index_size));
+   struct pipe_resource *current_hw_res = NULL;
 
    if (!(ilo->dirty & ILO_DIRTY_IB) && !need_upload)
       return;
 
+   pipe_resource_reference(&current_hw_res, ilo->ib.hw_resource);
+
    if (need_upload) {
       const unsigned offset = ilo->ib.index_size * ilo->draw->start;
       const unsigned size = ilo->ib.index_size * ilo->draw->count;
@@ -175,6 +177,8 @@ finalize_index_buffer(struct ilo_context *ilo)
       ilo->dirty &= ~ILO_DIRTY_IB;
    else
       ilo->ib.hw_index_size = ilo->ib.index_size;
+
+   pipe_resource_reference(&current_hw_res, NULL);
 }
 
 /**