mirror of
https://github.com/mirror/tinycc.git
synced 2025-01-27 06:10:06 +08:00
arm-gen.c: replace register constants with enum values
and support sp in intr
This commit is contained in:
parent
6775c7cb3a
commit
52a152235e
27
arm-gen.c
27
arm-gen.c
@ -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;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user