arm-gen.c: replace register constants with enum values

and support sp in intr
This commit is contained in:
Daniel Glöckner 2016-10-09 00:11:51 +02:00
parent 6775c7cb3a
commit 52a152235e

View File

@ -79,6 +79,8 @@ enum {
TREG_F6, TREG_F6,
TREG_F7, TREG_F7,
#endif #endif
TREG_SP = 13,
TREG_LR,
}; };
#ifdef TCC_ARM_VFP #ifdef TCC_ARM_VFP
@ -406,24 +408,26 @@ static uint32_t vfpr(int r)
{ {
if(r<TREG_F0 || r>TREG_F7) if(r<TREG_F0 || r>TREG_F7)
tcc_error("compiler error! register %i is no vfp register",r); tcc_error("compiler error! register %i is no vfp register",r);
return r-5; return r - TREG_F0;
} }
#else #else
static uint32_t fpr(int r) static uint32_t fpr(int r)
{ {
if(r<TREG_F0 || r>TREG_F3) if(r<TREG_F0 || r>TREG_F3)
tcc_error("compiler error! register %i is no fpa register",r); tcc_error("compiler error! register %i is no fpa register",r);
return r-5; return r - TREG_F0;
} }
#endif #endif
static uint32_t intr(int r) static uint32_t intr(int r)
{ {
if(r==4) if(r == TREG_R12)
return 12; return 12;
if((r<0 || r>4) && r!=14) if(r >= TREG_R0 && r <= TREG_R3)
tcc_error("compiler error! register %i is no int register",r); return r - TREG_R0;
return r; if (r >= TREG_SP && r <= TREG_LR)
return r + (13 - TREG_SP);
tcc_error("compiler error! register %i is no int register",r);
} }
static void calcaddr(uint32_t *base, int *off, int *sgn, int maxoff, unsigned shift) static void calcaddr(uint32_t *base, int *off, int *sgn, int maxoff, unsigned shift)
@ -544,7 +548,8 @@ void load(int r, SValue *sv)
v1.type.t = VT_PTR; v1.type.t = VT_PTR;
v1.r = VT_LOCAL | VT_LVAL; v1.r = VT_LOCAL | VT_LVAL;
v1.c.i = sv->c.i; v1.c.i = sv->c.i;
load(base=14 /* lr */, &v1); load(TREG_LR, &v1);
base = 14; /* lr */
fc=sign=0; fc=sign=0;
v=VT_LOCAL; v=VT_LOCAL;
} else if(v == VT_CONST) { } else if(v == VT_CONST) {
@ -552,7 +557,8 @@ void load(int r, SValue *sv)
v1.r = fr&~VT_LVAL; v1.r = fr&~VT_LVAL;
v1.c.i = sv->c.i; v1.c.i = sv->c.i;
v1.sym=sv->sym; v1.sym=sv->sym;
load(base=14, &v1); load(TREG_LR, &v1);
base = 14; /* lr */
fc=sign=0; fc=sign=0;
v=VT_LOCAL; v=VT_LOCAL;
} else if(v < VT_CONST) { } else if(v < VT_CONST) {
@ -678,7 +684,7 @@ void store(int r, SValue *sv)
v = fr & VT_VALMASK; v = fr & VT_VALMASK;
if (fr & VT_LVAL || fr == VT_LOCAL) { if (fr & VT_LVAL || fr == VT_LOCAL) {
uint32_t base = 0xb; uint32_t base = 0xb; /* fp */
if(v < VT_CONST) { if(v < VT_CONST) {
base=intr(v); base=intr(v);
v=VT_LOCAL; v=VT_LOCAL;
@ -688,7 +694,8 @@ void store(int r, SValue *sv)
v1.r = fr&~VT_LVAL; v1.r = fr&~VT_LVAL;
v1.c.i = sv->c.i; v1.c.i = sv->c.i;
v1.sym=sv->sym; v1.sym=sv->sym;
load(base=14, &v1); load(TREG_LR, &v1);
base = 14; /* lr */
fc=sign=0; fc=sign=0;
v=VT_LOCAL; v=VT_LOCAL;
} }