From 0c313f491b6d9e1c5eb98888e1b8cd750d5dbd15 Mon Sep 17 00:00:00 2001 From: Pursuer <1596067968@qq.com> Date: Wed, 9 Jan 2019 02:06:26 +0800 Subject: [PATCH] Insert arm-xxx_FILES into Makefile to suport CROSS_TARGET and Remove duplicate function lexpand_nr --- Makefile | 6 ++++++ arm-gen.c | 4 ++-- tcc.h | 4 +++- tccgen.c | 30 +----------------------------- 4 files changed, 12 insertions(+), 32 deletions(-) diff --git a/Makefile b/Makefile index 02d36258..d5e10c8c 100644 --- a/Makefile +++ b/Makefile @@ -164,6 +164,12 @@ x86_64-win32_FILES = $(x86_64_FILES) tccpe.c x86_64-osx_FILES = $(x86_64_FILES) arm_FILES = $(CORE_FILES) arm-gen.c arm-link.c arm-asm.c arm-wince_FILES = $(arm_FILES) tccpe.c +arm-eabihf_FILES = $(arm_FILES) +arm-fpa_FILES = $(arm_FILES) +arm-fpa-ld_FILES = $(arm_FILES) +arm-vfp_FILES = $(arm_FILES) +arm-eabi_FILES = $(arm_FILES) +arm-eabihf_FILES = $(arm_FILES) arm64_FILES = $(CORE_FILES) arm64-gen.c arm64-link.c c67_FILES = $(CORE_FILES) c67-gen.c c67-link.c tcccoff.c diff --git a/arm-gen.c b/arm-gen.c index c5de0659..e766ce43 100644 --- a/arm-gen.c +++ b/arm-gen.c @@ -1141,7 +1141,7 @@ again: /* XXX: implicit cast ? */ size=4; if ((pplan->sval->type.t & VT_BTYPE) == VT_LLONG) { - lexpand_nr(); + lexpand(); size = 8; r = gv(RC_INT); o(0xE52D0004|(intr(r)<<12)); /* push r */ @@ -1165,7 +1165,7 @@ again: case CORE_CLASS: if ((pplan->sval->type.t & VT_BTYPE) == VT_LLONG) { - lexpand_nr(); + lexpand(); gv(regmask(pplan->end)); pplan->sval->r2 = vtop->r; vtop--; diff --git a/tcc.h b/tcc.h index cc85291f..165249fe 100644 --- a/tcc.h +++ b/tcc.h @@ -1321,9 +1321,11 @@ ST_FUNC void vpush_global_sym(CType *type, int v); ST_FUNC void vrote(SValue *e, int n); ST_FUNC void vrott(int n); ST_FUNC void vrotb(int n); +#if PTR_SIZE == 4 +ST_FUNC void lexpand(void); +#endif #ifdef TCC_TARGET_ARM ST_FUNC int get_reg_ex(int rc, int rc2); -ST_FUNC void lexpand_nr(void); #endif ST_FUNC void vpushv(SValue *v); ST_FUNC void save_reg(int r); diff --git a/tccgen.c b/tccgen.c index 9f671e09..9b3749d0 100644 --- a/tccgen.c +++ b/tccgen.c @@ -1521,7 +1521,7 @@ static int reg_fret(int t) #if PTR_SIZE == 4 /* expand 64bit on stack in two ints */ -static void lexpand(void) +ST_FUNC void lexpand(void) { int u, v; u = vtop->type.t & (VT_DEFSIGN | VT_UNSIGNED); @@ -1542,34 +1542,6 @@ static void lexpand(void) } #endif -#ifdef TCC_TARGET_ARM -/* expand long long on stack */ -ST_FUNC void lexpand_nr(void) -{ - int u,v; - - u = vtop->type.t & (VT_DEFSIGN | VT_UNSIGNED); - vdup(); - vtop->r2 = VT_CONST; - vtop->type.t = VT_INT | u; - v=vtop[-1].r & (VT_VALMASK | VT_LVAL); - if (v == VT_CONST) { - vtop[-1].c.i = vtop->c.i; - vtop->c.i = vtop->c.i >> 32; - vtop->r = VT_CONST; - } else if (v == (VT_LVAL|VT_CONST) || v == (VT_LVAL|VT_LOCAL)) { - vtop->c.i += 4; - vtop->r = vtop[-1].r; - } else if (v > VT_CONST) { - vtop--; - lexpand(); - } else - vtop->r = vtop[-1].r2; - vtop[-1].r2 = VT_CONST; - vtop[-1].type.t = VT_INT | u; -} -#endif - #if PTR_SIZE == 4 /* build a long long from two ints */ static void lbuild(int t)