]> git.rm.cloudns.org Git - xonotic/gmqcc.git/commitdiff
use type_sizeof in some places where previously manual size checking has been done
authorWolfgang Bumiller <wolfgang.linux@bumiller.com>
Tue, 10 Jul 2012 17:29:01 +0000 (19:29 +0200)
committerWolfgang Bumiller <wolfgang.linux@bumiller.com>
Tue, 10 Jul 2012 17:29:01 +0000 (19:29 +0200)
ir.c

diff --git a/ir.c b/ir.c
index e8b7382912775c341acc8cbf9a50981c05aec8e5..fbf07bc9552756642ea269677413920b0730a1f7 100644 (file)
--- a/ir.c
+++ b/ir.c
@@ -2363,10 +2363,8 @@ static bool gen_global_function(ir_builder *ir, ir_value *global)
     for (i = 0;i < 8; ++i) {
         if (i >= fun.nargs)
             fun.argsize[i] = 0;
-        else if (irfun->params[i] == TYPE_VECTOR)
-            fun.argsize[i] = 3;
         else
-            fun.argsize[i] = 1;
+            fun.argsize[i] = type_sizeof[irfun->params[i]];
     }
 
     fun.firstlocal = code_globals_elements;
@@ -2454,18 +2452,29 @@ static bool ir_builder_gen_global(ir_builder *self, ir_value *global)
     }
     case TYPE_VECTOR:
     {
+        size_t d;
         if (code_defs_add(def) < 0)
             return false;
 
         if (global->isconst) {
             iptr = (int32_t*)&global->constval.vvec;
             global->code.globaladdr = code_globals_add(iptr[0]);
-            if (code_globals_add(iptr[1]) < 0 || code_globals_add(iptr[2]) < 0)
+            if (global->code.globaladdr < 0)
                 return false;
+            for (d = 1; d < type_sizeof[global->vtype]; ++d)
+            {
+                if (code_globals_add(iptr[d]) < 0)
+                    return false;
+            }
         } else {
             global->code.globaladdr = code_globals_add(0);
-            if (code_globals_add(0) < 0 || code_globals_add(0) < 0)
+            if (global->code.globaladdr < 0)
                 return false;
+            for (d = 1; d < type_sizeof[global->vtype]; ++d)
+            {
+                if (code_globals_add(0) < 0)
+                    return false;
+            }
         }
         return global->code.globaladdr >= 0;
     }