ref: 75e90d91c0c50fb64812e61c21da8cbc8f1d3e5e
parent: d710ee583d7591cfaba91d7ee39676dbcae1a116
author: Ori Bernstein <[email protected]>
date: Mon Dec 28 06:44:06 EST 2015
Fix alignment in argument passing. The alignment of a compound type is equal to the maximum alignment of its members, so your array shouldn't be aligned. When setting up arguments, though, I was accidentally using the size of the type instead of the alignment. Fixes #30
--- a/6/isel.c
+++ b/6/isel.c
@@ -415,6 +415,7 @@
dp = inr(s, to);
i = 0;
+ align = 8;
if (align == 0)
align = 8;
if (sz <= 128) { /* arbitrary threshold; should be tuned */
@@ -933,7 +934,7 @@
nargs = countargs(fn->type);
for (i = 0; i < fn->nargs; i++) {
arg = fn->args[i];
- argoff = align(argoff, min(size(arg), Ptrsz));
+ argoff = alignto(argoff, decltype(arg));
if (i >= nargs)
vararg = 1;
if (stacknode(arg)) {
--- /dev/null
+++ b/test/arraypass.myr
@@ -1,0 +1,12 @@
+use std
+
+const keq = {a, b
+ std.put("{}\n", b[0])
+}
+
+const main = {args : byte[:][:]
+ var k : byte[5]
+
+ k = [1,2,3,4,5]
+ keq(k, k)
+}
--- a/test/tests
+++ b/test/tests
@@ -115,6 +115,7 @@
F matchmixed
B bigliteral P 34359738368
B arraylit-ni E 2
+B arraypass P 1
B livearraylit E 21
# B arraylit E 3 ## BUGGERED
B structlit E 42