Mesa (master): pan/midgard: Fix a divide by zero in emit_alu_bundle

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Fri Apr 3 17:37:55 UTC 2020


Module: Mesa
Branch: master
Commit: 319158a814ae0833573d5e4ff7150504aebae59b
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=319158a814ae0833573d5e4ff7150504aebae59b

Author: Icecream95 <ixn at keemail.me>
Date:   Wed Apr  1 15:32:19 2020 +1300

pan/midgard: Fix a divide by zero in emit_alu_bundle

util_dynarray_grow_bytes divides by eltsize, but it's possible for
bundle->padding to be zero.

I changed the other call to util_dynarray_grow_bytes for consistency.

Reviewed-by: Alyssa Rosenzweig <alyssa.rosenzweig at collabora.com>
Tested-by: Marge Bot <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/4397>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/4397>

---

 src/panfrost/midgard/midgard_emit.c | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/src/panfrost/midgard/midgard_emit.c b/src/panfrost/midgard/midgard_emit.c
index 2b18aac3553..0c5d60efa4a 100644
--- a/src/panfrost/midgard/midgard_emit.c
+++ b/src/panfrost/midgard/midgard_emit.c
@@ -372,11 +372,11 @@ emit_alu_bundle(compiler_context *ctx,
                         source = &scalarized;
                 }
 
-                memcpy(util_dynarray_grow_bytes(emission, 1, size), source, size);
+                memcpy(util_dynarray_grow_bytes(emission, size, 1), source, size);
         }
 
         /* Emit padding (all zero) */
-        memset(util_dynarray_grow_bytes(emission, 1, bundle->padding), 0, bundle->padding);
+        memset(util_dynarray_grow_bytes(emission, bundle->padding, 1), 0, bundle->padding);
 
         /* Tack on constants */
 



More information about the mesa-commit mailing list