diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/gallium/drivers/r300/r300_flush.c | 8 | ||||
| -rw-r--r-- | src/gallium/drivers/r300/r300_render.c | 22 | ||||
| -rw-r--r-- | src/gallium/drivers/r300/r300_state.c | 10 | 
3 files changed, 14 insertions, 26 deletions
| diff --git a/src/gallium/drivers/r300/r300_flush.c b/src/gallium/drivers/r300/r300_flush.c index ae7b5759e7..fe182b6615 100644 --- a/src/gallium/drivers/r300/r300_flush.c +++ b/src/gallium/drivers/r300/r300_flush.c @@ -43,14 +43,6 @@ static void r300_flush(struct pipe_context* pipe,      u_upload_flush(r300->upload_vb);      u_upload_flush(r300->upload_ib); -    /* We probably need to flush Draw, but we may have been called from -     * within Draw. This feels kludgy, but it might be the best thing. -     * -     * Of course, the best thing is to kill Draw with fire. :3 */ -    if (r300->draw && !r300->draw->flushing) { -        draw_flush(r300->draw); -    } -      if (r300->dirty_hw) {          r300_emit_hyperz_end(r300);          r300_emit_query_end(r300); diff --git a/src/gallium/drivers/r300/r300_render.c b/src/gallium/drivers/r300/r300_render.c index 987fbaf6a4..7c4294bc9f 100644 --- a/src/gallium/drivers/r300/r300_render.c +++ b/src/gallium/drivers/r300/r300_render.c @@ -681,11 +681,13 @@ static void r300_swtcl_draw_vbo(struct pipe_context* pipe,      r300_update_derived_state(r300);      for (i = 0; i < r300->vertex_buffer_count; i++) { -        void* buf = pipe_buffer_map(pipe, -                                    r300->vertex_buffer[i].buffer, -                                    PIPE_TRANSFER_READ, -                                    &vb_transfer[i]); -        draw_set_mapped_vertex_buffer(r300->draw, i, buf); +        if (r300->vertex_buffer[i].buffer) { +            void *buf = pipe_buffer_map(pipe, +                                  r300->vertex_buffer[i].buffer, +                                  PIPE_TRANSFER_READ, +                                  &vb_transfer[i]); +            draw_set_mapped_vertex_buffer(r300->draw, i, buf); +        }      }      if (info->indexed && r300->index_buffer.buffer) { @@ -709,9 +711,11 @@ static void r300_swtcl_draw_vbo(struct pipe_context* pipe,      draw_flush(r300->draw);      for (i = 0; i < r300->vertex_buffer_count; i++) { -        pipe_buffer_unmap(pipe, r300->vertex_buffer[i].buffer, -                          vb_transfer[i]); -        draw_set_mapped_vertex_buffer(r300->draw, i, NULL); +        if (r300->vertex_buffer[i].buffer) { +            pipe_buffer_unmap(pipe, r300->vertex_buffer[i].buffer, +                              vb_transfer[i]); +            draw_set_mapped_vertex_buffer(r300->draw, i, NULL); +        }      }      if (ib_transfer) { @@ -796,6 +800,8 @@ static void* r300_render_map_vertices(struct vbuf_render* render)                                            PIPE_TRANSFER_WRITE,  					  &r300render->vbo_transfer); +    assert(r300render->vbo_ptr); +      return ((uint8_t*)r300render->vbo_ptr + r300render->vbo_offset);  } diff --git a/src/gallium/drivers/r300/r300_state.c b/src/gallium/drivers/r300/r300_state.c index bccd7d7859..fced77e6f1 100644 --- a/src/gallium/drivers/r300/r300_state.c +++ b/src/gallium/drivers/r300/r300_state.c @@ -446,7 +446,6 @@ static void r300_set_clip_state(struct pipe_context* pipe,          r300->clip_state.dirty = TRUE;      } else { -        draw_flush(r300->draw);          draw_set_clip_state(r300->draw, state);      }  } @@ -728,10 +727,6 @@ static void          return;      } -    if (r300->draw) { -        draw_flush(r300->draw); -    } -      /* If nr_cbufs is changed from zero to non-zero or vice versa... */      if (!!old_state->nr_cbufs != !!state->nr_cbufs) {          r300->blend_state.dirty = TRUE; @@ -1096,7 +1091,6 @@ static void r300_bind_rs_state(struct pipe_context* pipe, void* state)      boolean last_two_sided_color = r300->two_sided_color;      if (r300->draw && rs) { -        draw_flush(r300->draw);          draw_set_rasterizer_state(r300->draw, &rs->rs_draw, state);      } @@ -1385,7 +1379,6 @@ static void r300_set_viewport_state(struct pipe_context* pipe,      r300->viewport = *state;      if (r300->draw) { -        draw_flush(r300->draw);          draw_set_viewport_state(r300->draw, state);          viewport->vte_control = R300_VTX_XY_FMT | R300_VTX_Z_FMT;          return; @@ -1486,7 +1479,6 @@ static void r300_set_vertex_buffers(struct pipe_context* pipe,      } else {          /* SW TCL. */ -        draw_flush(r300->draw);          draw_set_vertex_buffers(r300->draw, count, buffers);      } @@ -1671,7 +1663,6 @@ static void r300_bind_vertex_elements_state(struct pipe_context *pipe,      r300->velems = velems;      if (r300->draw) { -        draw_flush(r300->draw);          draw_set_vertex_elements(r300->draw, velems->count, velems->velem);          return;      } @@ -1737,7 +1728,6 @@ static void r300_bind_vs_state(struct pipe_context* pipe, void* shader)          r300->pvs_flush.dirty = TRUE;      } else { -        draw_flush(r300->draw);          draw_bind_vertex_shader(r300->draw,                  (struct draw_vertex_shader*)vs->draw_vs);      } | 
