i965: fix googleearth in classic mode.
authorDave Airlie <airlied@panoply-rh.(none)>
Tue, 6 May 2008 08:52:47 +0000 (18:52 +1000)
committerDave Airlie <airlied@panoply-rh.(none)>
Tue, 6 May 2008 08:52:47 +0000 (18:52 +1000)
In classic mode googleearth triggered a case where vbos weren't getting accounted properly.

src/mesa/drivers/dri/i965/brw_draw_upload.c

index aa985d68b69c1c6892e024eba1a78b60900897cc..2d99238ddcd0541c4097c4e019d5bfab98c8de0a 100644 (file)
@@ -404,6 +404,7 @@ int brw_prepare_vertices( struct brw_context *brw,
        */
       copy_array_to_vbo_array(brw, upload[0], interleave);
 
+      ret |= dri_bufmgr_check_aperture_space(upload[0]->bo);
       for (i = 1; i < nr_uploads; i++) {
         /* Then, just point upload[i] at upload[0]'s buffer. */
         upload[i]->stride = interleave;
@@ -416,13 +417,13 @@ int brw_prepare_vertices( struct brw_context *brw,
    else {
       /* Upload non-interleaved arrays */
       for (i = 0; i < nr_uploads; i++) {
-        copy_array_to_vbo_array(brw, upload[i], upload[i]->element_size);
+          copy_array_to_vbo_array(brw, upload[i], upload[i]->element_size);
+          if (upload[i]->bo) {
+              ret |= dri_bufmgr_check_aperture_space(upload[i]->bo);
+          }
       }
    }
 
-   if (brw->vb.upload.bo) {
-     ret |= dri_bufmgr_check_aperture_space(brw->vb.upload.bo);
-   }
 
    if (ret)
      return 1;