Skip to content

Commit

Permalink
liblink, cmd/5a: fix reglist parsing/printing after changing REG_R0 t…
Browse files Browse the repository at this point in the history
…o 32

Fixes #9759.

Change-Id: I263f1251b9401371231374551c4f71c70cb6e359
Signed-off-by: Shenghou Ma <[email protected]>
Reviewed-on: https://go-review.googlesource.com/3931
Reviewed-by: Dave Cheney <[email protected]>
  • Loading branch information
minux committed Feb 5, 2015
1 parent 706cc13 commit da4abda
Show file tree
Hide file tree
Showing 5 changed files with 16 additions and 15 deletions.
10 changes: 5 additions & 5 deletions src/cmd/5a/a.y
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@
%union
{
Sym *sym;
int32 lval;
int64 lval;
double dval;
char sval[8];
Addr addr;
Expand Down Expand Up @@ -460,20 +460,20 @@ fcon:
reglist:
spreg
{
$$ = 1 << $1;
$$ = 1ULL << $1;
}
| spreg '-' spreg
{
int i;
$$=0;
for(i=$1; i<=$3; i++)
$$ |= 1<<i;
$$ |= 1ULL<<i;
for(i=$3; i<=$1; i++)
$$ |= 1<<i;
$$ |= 1ULL<<i;
}
| spreg comma reglist
{
$$ = (1<<$1) | $3;
$$ = (1ULL<<$1) | $3;
}

gen:
Expand Down
10 changes: 5 additions & 5 deletions src/cmd/5a/y.tab.c
Original file line number Diff line number Diff line change
Expand Up @@ -204,7 +204,7 @@ typedef union YYSTYPE
#line 39 "a.y"
{
Sym *sym;
int32 lval;
int64 lval;
double dval;
char sval[8];
Addr addr;
Expand Down Expand Up @@ -2223,7 +2223,7 @@ yyparse ()
case 64:
#line 462 "a.y"
{
(yyval.lval) = 1 << (yyvsp[(1) - (1)].lval);
(yyval.lval) = 1ULL << (yyvsp[(1) - (1)].lval);
}
break;

Expand All @@ -2233,16 +2233,16 @@ yyparse ()
int i;
(yyval.lval)=0;
for(i=(yyvsp[(1) - (3)].lval); i<=(yyvsp[(3) - (3)].lval); i++)
(yyval.lval) |= 1<<i;
(yyval.lval) |= 1ULL<<i;
for(i=(yyvsp[(3) - (3)].lval); i<=(yyvsp[(1) - (3)].lval); i++)
(yyval.lval) |= 1<<i;
(yyval.lval) |= 1ULL<<i;
}
break;

case 66:
#line 475 "a.y"
{
(yyval.lval) = (1<<(yyvsp[(1) - (3)].lval)) | (yyvsp[(3) - (3)].lval);
(yyval.lval) = (1ULL<<(yyvsp[(1) - (3)].lval)) | (yyvsp[(3) - (3)].lval);
}
break;

Expand Down
2 changes: 1 addition & 1 deletion src/cmd/5a/y.tab.h
Original file line number Diff line number Diff line change
Expand Up @@ -149,7 +149,7 @@ typedef union YYSTYPE
#line 39 "a.y"
{
Sym *sym;
int32 lval;
int64 lval;
double dval;
char sval[8];
Addr addr;
Expand Down
4 changes: 2 additions & 2 deletions src/liblink/asm5.c
Original file line number Diff line number Diff line change
Expand Up @@ -1820,14 +1820,14 @@ if(0 /*debug['G']*/) print("%ux: %s: arm %d\n", (uint32)(p->pc), p->from.sym->na
switch(o->type) {
case 38: /* movm $con,oreg -> stm */
o1 = (0x4 << 25);
o1 |= p->from.offset & 0xffff;
o1 |= (p->from.offset >> REG_R0) & 0xffff;
o1 |= (p->to.reg&15) << 16;
aclass(ctxt, &p->to);
break;

case 39: /* movm oreg,$con -> ldm */
o1 = (0x4 << 25) | (1 << 20);
o1 |= p->to.offset & 0xffff;
o1 |= (p->to.offset >> REG_R0) & 0xffff;
o1 |= (p->from.reg&15) << 16;
aclass(ctxt, &p->from);
break;
Expand Down
5 changes: 3 additions & 2 deletions src/liblink/list5.c
Original file line number Diff line number Diff line change
Expand Up @@ -222,7 +222,8 @@ RAconv(Fmt *fp)
{
char str[STRINGSZ];
Addr *a;
int i, v;
int i;
vlong v;

a = va_arg(fp->args, Addr*);
sprint(str, "GOK-reglist");
Expand All @@ -232,7 +233,7 @@ RAconv(Fmt *fp)
break;
if(a->sym != nil)
break;
v = a->offset;
v = a->offset >> REG_R0;
strcpy(str, "");
for(i=0; i<NREG; i++) {
if(v & (1<<i)) {
Expand Down

0 comments on commit da4abda

Please sign in to comment.