Commit 6c0bcb18 authored by Russ Cox's avatar Russ Cox

cmd/gc: fix method value closures on nacl amd64p32

The code was assuming that pointer alignment is the
maximum alignment, but on NaCl uint64 alignment is
even more strict.

Brad checked in the test earlier today; this fixes the build.

Fixes #7863.

TBR=iant
CC=golang-codereviews
https://golang.org/cl/98630046
parent eeb87c36
...@@ -374,6 +374,8 @@ makepartialcall(Node *fn, Type *t0, Node *meth) ...@@ -374,6 +374,8 @@ makepartialcall(Node *fn, Type *t0, Node *meth)
cv = nod(OCLOSUREVAR, N, N); cv = nod(OCLOSUREVAR, N, N);
cv->xoffset = widthptr; cv->xoffset = widthptr;
cv->type = rcvrtype; cv->type = rcvrtype;
if(cv->type->align > widthptr)
cv->xoffset = cv->type->align;
ptr = nod(ONAME, N, N); ptr = nod(ONAME, N, N);
ptr->sym = lookup("rcvr"); ptr->sym = lookup("rcvr");
ptr->class = PAUTO; ptr->class = PAUTO;
......
...@@ -1438,6 +1438,8 @@ funccompile(Node *n, int isclosure) ...@@ -1438,6 +1438,8 @@ funccompile(Node *n, int isclosure)
// record offset to actual frame pointer. // record offset to actual frame pointer.
// for closure, have to skip over leading pointers and PC slot. // for closure, have to skip over leading pointers and PC slot.
// TODO(rsc): this is the old jit closure handling code.
// with the new closures, isclosure is always 0; delete this block.
nodfp->xoffset = 0; nodfp->xoffset = 0;
if(isclosure) { if(isclosure) {
NodeList *l; NodeList *l;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment