Revert "i965/urb: fixes division by zero"
authorMatt Turner <mattst88@gmail.com>
Wed, 18 May 2016 19:48:20 +0000 (12:48 -0700)
committerMatt Turner <mattst88@gmail.com>
Wed, 18 May 2016 19:48:50 +0000 (12:48 -0700)
This reverts commit 2a8aa1e3deb99a1ae16d942318da648c1327ece5.

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

index 6d9aa028e95ed54bf43dcd2f4ed9960b2d01d86e..a412a4263b33f50dd6aeac95bc50c1ac98b48547 100644 (file)
@@ -292,11 +292,25 @@ gen7_upload_urb(struct brw_context *brw)
    if (remaining_space > total_wants)
       remaining_space = total_wants;
    if (remaining_space > 0) {
-      float ratio = ((float) remaining_space) / total_wants;
-      vs_chunks += lroundf(vs_wants * ratio);
-      hs_chunks += lroundf(hs_wants * ratio);
-      ds_chunks += lroundf(ds_wants * ratio);
-      gs_chunks += lroundf(gs_wants * ratio);
+      unsigned vs_additional = (unsigned)
+         roundf(vs_wants * (((float) remaining_space) / total_wants));
+      vs_chunks += vs_additional;
+      remaining_space -= vs_additional;
+      total_wants -= vs_wants;
+
+      unsigned hs_additional = (unsigned)
+         round(hs_wants * (((double) remaining_space) / total_wants));
+      hs_chunks += hs_additional;
+      remaining_space -= hs_additional;
+      total_wants -= hs_wants;
+
+      unsigned ds_additional = (unsigned)
+         round(ds_wants * (((double) remaining_space) / total_wants));
+      ds_chunks += ds_additional;
+      remaining_space -= ds_additional;
+      total_wants -= ds_wants;
+
+      gs_chunks += remaining_space;
    }
 
    /* Sanity check that we haven't over-allocated. */