Commit e8d65b92 authored by Russ Cox's avatar Russ Cox

liblink: fix arm build errors

This was supposed to be in CL 135490044
but got lost in a transfer from machine to machine.

TBR=khr
R=khr
CC=golang-codereviews
https://golang.org/cl/135560043
parent b4c28d91
...@@ -309,6 +309,7 @@ static Optab optab[] = ...@@ -309,6 +309,7 @@ static Optab optab[] =
{ AUSEFIELD, C_ADDR, C_NONE, C_NONE, 0, 0, 0 }, { AUSEFIELD, C_ADDR, C_NONE, C_NONE, 0, 0, 0 },
{ APCDATA, C_LCON, C_NONE, C_LCON, 0, 0, 0 }, { APCDATA, C_LCON, C_NONE, C_LCON, 0, 0, 0 },
{ AFUNCDATA, C_LCON, C_NONE, C_ADDR, 0, 0, 0 }, { AFUNCDATA, C_LCON, C_NONE, C_ADDR, 0, 0, 0 },
{ ANOP, C_NONE, C_NONE, C_NONE, 0, 0, 0 },
{ ADUFFZERO, C_NONE, C_NONE, C_SBRA, 5, 4, 0 }, // same as ABL { ADUFFZERO, C_NONE, C_NONE, C_SBRA, 5, 4, 0 }, // same as ABL
{ ADUFFCOPY, C_NONE, C_NONE, C_SBRA, 5, 4, 0 }, // same as ABL { ADUFFCOPY, C_NONE, C_NONE, C_SBRA, 5, 4, 0 }, // same as ABL
...@@ -686,7 +687,7 @@ span5(Link *ctxt, LSym *cursym) ...@@ -686,7 +687,7 @@ span5(Link *ctxt, LSym *cursym)
continue; continue;
} }
} }
if(m == 0 && (p->as != AFUNCDATA && p->as != APCDATA && p->as != ADATABUNDLEEND)) { if(m == 0 && (p->as != AFUNCDATA && p->as != APCDATA && p->as != ADATABUNDLEEND && p->as != ANOP)) {
ctxt->diag("zero-width instruction\n%P", p); ctxt->diag("zero-width instruction\n%P", p);
continue; continue;
} }
...@@ -765,7 +766,7 @@ span5(Link *ctxt, LSym *cursym) ...@@ -765,7 +766,7 @@ span5(Link *ctxt, LSym *cursym)
} }
if(m/4 > nelem(out)) if(m/4 > nelem(out))
ctxt->diag("instruction size too large: %d > %d", m/4, nelem(out)); ctxt->diag("instruction size too large: %d > %d", m/4, nelem(out));
if(m == 0 && (p->as != AFUNCDATA && p->as != APCDATA && p->as != ADATABUNDLEEND)) { if(m == 0 && (p->as != AFUNCDATA && p->as != APCDATA && p->as != ADATABUNDLEEND && p->as != ANOP)) {
if(p->as == ATEXT) { if(p->as == ATEXT) {
ctxt->autosize = p->to.offset + 4; ctxt->autosize = p->to.offset + 4;
continue; continue;
...@@ -1479,6 +1480,7 @@ buildop(Link *ctxt) ...@@ -1479,6 +1480,7 @@ buildop(Link *ctxt)
case ACLZ: case ACLZ:
case AFUNCDATA: case AFUNCDATA:
case APCDATA: case APCDATA:
case ANOP:
case ADATABUNDLE: case ADATABUNDLE:
case ADATABUNDLEEND: case ADATABUNDLEEND:
break; break;
......
...@@ -466,12 +466,10 @@ addstacksplit(Link *ctxt, LSym *cursym) ...@@ -466,12 +466,10 @@ addstacksplit(Link *ctxt, LSym *cursym)
p->as = ACMP; p->as = ACMP;
p->from.type = D_CONST; p->from.type = D_CONST;
p->from.offset = 0; p->from.offset = 0;
p->to.type = D_REG; p->reg = 1;
p->to.reg = 1;
p = appendp(ctxt, p); p = appendp(ctxt, p);
p->as = AB; p->as = ABEQ;
p->scond = C_SCOND_EQ;
p->to.type = D_BRANCH; p->to.type = D_BRANCH;
p1 = p; p1 = p;
...@@ -495,12 +493,10 @@ addstacksplit(Link *ctxt, LSym *cursym) ...@@ -495,12 +493,10 @@ addstacksplit(Link *ctxt, LSym *cursym)
p->as = ACMP; p->as = ACMP;
p->from.type = D_REG; p->from.type = D_REG;
p->from.offset = 2; p->from.offset = 2;
p->to.type = D_REG; p->reg = 3;
p->to.reg = 3;
p = appendp(ctxt, p); p = appendp(ctxt, p);
p->as = AB; p->as = ABNE;
p->scond = C_SCOND_NE;
p->to.type = D_BRANCH; p->to.type = D_BRANCH;
p2 = p; p2 = p;
......
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