1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-05-07 08:40:21 +02:00

Build and pass all tests on 32 and 64 bit sparc

* include/lightning/jit_private.h: Add new register classes to
	flag float registers and double only registers, required for sparc64
	where only low 32 bit fpr registers can be used for single precision
	operations.
	Add new 128 bit jit_regset_t type for sparc64 register set.

	* include/lightning/jit_sparc.h, lib/jit_sparc-cpu.c, lib/jit_sparc-fpu.c,
	lib/jit_sparc-sz.c, lib/jit_sparc.c: Update for 64 bits sparc.

	* lib/lightning.c: Update for new jit_regset_t required for sparc64.
This commit is contained in:
Paulo Andrade 2018-04-20 10:37:37 -03:00
parent ed5589ce59
commit 2cea99361b
8 changed files with 2754 additions and 246 deletions

View file

@ -1,5 +1,4 @@
#if __WORDSIZE == 32
#if WORDSIZE == 32
#define JIT_INSTR_MAX 40
0, /* data */
0, /* live */
@ -400,3 +399,405 @@
0, /* movr_d_w */
0, /* movi_d_w */
#endif /* __WORDSIZE */
#if __WORDSIZE == 64
#define JIT_INSTR_MAX 64
0, /* data */
0, /* live */
4, /* align */
0, /* save */
0, /* load */
0, /* #name */
0, /* #note */
4, /* label */
36, /* prolog */
0, /* ellipsis */
0, /* va_push */
0, /* allocai */
0, /* allocar */
0, /* arg */
0, /* getarg_c */
0, /* getarg_uc */
0, /* getarg_s */
0, /* getarg_us */
0, /* getarg_i */
0, /* getarg_ui */
0, /* getarg_l */
0, /* putargr */
0, /* putargi */
4, /* va_start */
8, /* va_arg */
8, /* va_arg_d */
0, /* va_end */
4, /* addr */
28, /* addi */
24, /* addcr */
48, /* addci */
52, /* addxr */
52, /* addxi */
4, /* subr */
28, /* subi */
24, /* subcr */
48, /* subci */
52, /* subxr */
52, /* subxi */
32, /* rsbi */
4, /* mulr */
28, /* muli */
48, /* qmulr */
64, /* qmuli */
48, /* qmulr_u */
64, /* qmuli_u */
4, /* divr */
28, /* divi */
4, /* divr_u */
28, /* divi_u */
20, /* qdivr */
16, /* qdivi */
20, /* qdivr_u */
16, /* qdivi_u */
12, /* remr */
36, /* remi */
12, /* remr_u */
36, /* remi_u */
4, /* andr */
28, /* andi */
4, /* orr */
28, /* ori */
4, /* xorr */
28, /* xori */
4, /* lshr */
4, /* lshi */
4, /* rshr */
4, /* rshi */
4, /* rshr_u */
4, /* rshi_u */
4, /* negr */
4, /* comr */
16, /* ltr */
16, /* lti */
16, /* ltr_u */
16, /* lti_u */
16, /* ler */
16, /* lei */
16, /* ler_u */
16, /* lei_u */
16, /* eqr */
16, /* eqi */
16, /* ger */
16, /* gei */
16, /* ger_u */
16, /* gei_u */
16, /* gtr */
16, /* gti */
16, /* gtr_u */
16, /* gti_u */
16, /* ner */
16, /* nei */
4, /* movr */
24, /* movi */
8, /* extr_c */
4, /* extr_uc */
8, /* extr_s */
8, /* extr_us */
8, /* extr_i */
8, /* extr_ui */
8, /* htonr_us */
8, /* htonr_ui */
4, /* htonr_ul */
4, /* ldr_c */
28, /* ldi_c */
4, /* ldr_uc */
28, /* ldi_uc */
4, /* ldr_s */
28, /* ldi_s */
4, /* ldr_us */
28, /* ldi_us */
4, /* ldr_i */
28, /* ldi_i */
4, /* ldr_ui */
28, /* ldi_ui */
4, /* ldr_l */
28, /* ldi_l */
4, /* ldxr_c */
24, /* ldxi_c */
4, /* ldxr_uc */
24, /* ldxi_uc */
4, /* ldxr_s */
24, /* ldxi_s */
4, /* ldxr_us */
24, /* ldxi_us */
4, /* ldxr_i */
24, /* ldxi_i */
4, /* ldxr_ui */
24, /* ldxi_ui */
4, /* ldxr_l */
24, /* ldxi_l */
4, /* str_c */
28, /* sti_c */
4, /* str_s */
28, /* sti_s */
4, /* str_i */
28, /* sti_i */
4, /* str_l */
28, /* sti_l */
4, /* stxr_c */
24, /* stxi_c */
4, /* stxr_s */
24, /* stxi_s */
4, /* stxr_i */
24, /* stxi_i */
4, /* stxr_l */
24, /* stxi_l */
12, /* bltr */
12, /* blti */
12, /* bltr_u */
12, /* blti_u */
12, /* bler */
12, /* blei */
12, /* bler_u */
12, /* blei_u */
12, /* beqr */
36, /* beqi */
12, /* bger */
12, /* bgei */
12, /* bger_u */
12, /* bgei_u */
12, /* bgtr */
12, /* bgti */
12, /* bgtr_u */
12, /* bgti_u */
12, /* bner */
36, /* bnei */
12, /* bmsr */
12, /* bmsi */
12, /* bmcr */
12, /* bmci */
12, /* boaddr */
12, /* boaddi */
12, /* boaddr_u */
12, /* boaddi_u */
12, /* bxaddr */
12, /* bxaddi */
12, /* bxaddr_u */
12, /* bxaddi_u */
12, /* bosubr */
12, /* bosubi */
12, /* bosubr_u */
12, /* bosubi_u */
12, /* bxsubr */
12, /* bxsubi */
12, /* bxsubr_u */
12, /* bxsubi_u */
8, /* jmpr */
32, /* jmpi */
8, /* callr */
32, /* calli */
0, /* prepare */
0, /* pushargr */
0, /* pushargi */
0, /* finishr */
0, /* finishi */
0, /* ret */
0, /* retr */
0, /* reti */
0, /* retval_c */
0, /* retval_uc */
0, /* retval_s */
0, /* retval_us */
0, /* retval_i */
0, /* retval_ui */
0, /* retval_l */
44, /* epilog */
0, /* arg_f */
0, /* getarg_f */
0, /* putargr_f */
0, /* putargi_f */
16, /* addr_f */
40, /* addi_f */
24, /* subr_f */
40, /* subi_f */
40, /* rsbi_f */
16, /* mulr_f */
40, /* muli_f */
16, /* divr_f */
40, /* divi_f */
12, /* negr_f */
12, /* absr_f */
12, /* sqrtr_f */
24, /* ltr_f */
48, /* lti_f */
24, /* ler_f */
48, /* lei_f */
24, /* eqr_f */
48, /* eqi_f */
24, /* ger_f */
48, /* gei_f */
24, /* gtr_f */
48, /* gti_f */
24, /* ner_f */
48, /* nei_f */
24, /* unltr_f */
48, /* unlti_f */
24, /* unler_f */
48, /* unlei_f */
24, /* uneqr_f */
48, /* uneqi_f */
24, /* unger_f */
48, /* ungei_f */
24, /* ungtr_f */
48, /* ungti_f */
24, /* ltgtr_f */
48, /* ltgti_f */
24, /* ordr_f */
48, /* ordi_f */
24, /* unordr_f */
48, /* unordi_f */
16, /* truncr_f_i */
16, /* truncr_f_l */
20, /* extr_f */
12, /* extr_d_f */
16, /* movr_f */
32, /* movi_f */
8, /* ldr_f */
32, /* ldi_f */
8, /* ldxr_f */
28, /* ldxi_f */
8, /* str_f */
32, /* sti_f */
8, /* stxr_f */
28, /* stxi_f */
20, /* bltr_f */
44, /* blti_f */
20, /* bler_f */
44, /* blei_f */
28, /* beqr_f */
60, /* beqi_f */
20, /* bger_f */
44, /* bgei_f */
20, /* bgtr_f */
44, /* bgti_f */
20, /* bner_f */
44, /* bnei_f */
20, /* bunltr_f */
44, /* bunlti_f */
20, /* bunler_f */
44, /* bunlei_f */
20, /* buneqr_f */
44, /* buneqi_f */
20, /* bunger_f */
44, /* bungei_f */
20, /* bungtr_f */
44, /* bungti_f */
20, /* bltgtr_f */
44, /* bltgti_f */
20, /* bordr_f */
44, /* bordi_f */
20, /* bunordr_f */
44, /* bunordi_f */
0, /* pushargr_f */
0, /* pushargi_f */
0, /* retr_f */
0, /* reti_f */
0, /* retval_f */
0, /* arg_d */
0, /* getarg_d */
0, /* putargr_d */
0, /* putargi_d */
4, /* addr_d */
32, /* addi_d */
4, /* subr_d */
32, /* subi_d */
32, /* rsbi_d */
4, /* mulr_d */
32, /* muli_d */
4, /* divr_d */
32, /* divi_d */
4, /* negr_d */
4, /* absr_d */
4, /* sqrtr_d */
16, /* ltr_d */
48, /* lti_d */
16, /* ler_d */
48, /* lei_d */
16, /* eqr_d */
48, /* eqi_d */
16, /* ger_d */
48, /* gei_d */
16, /* gtr_d */
48, /* gti_d */
16, /* ner_d */
48, /* nei_d */
16, /* unltr_d */
48, /* unlti_d */
16, /* unler_d */
48, /* unlei_d */
16, /* uneqr_d */
48, /* uneqi_d */
16, /* unger_d */
48, /* ungei_d */
16, /* ungtr_d */
48, /* ungti_d */
16, /* ltgtr_d */
48, /* ltgti_d */
16, /* ordr_d */
48, /* ordi_d */
16, /* unordr_d */
48, /* unordi_d */
16, /* truncr_d_i */
12, /* truncr_d_l */
12, /* extr_d */
8, /* extr_f_d */
4, /* movr_d */
32, /* movi_d */
4, /* ldr_d */
28, /* ldi_d */
4, /* ldxr_d */
24, /* ldxi_d */
4, /* str_d */
28, /* sti_d */
4, /* stxr_d */
24, /* stxi_d */
12, /* bltr_d */
40, /* blti_d */
12, /* bler_d */
40, /* blei_d */
12, /* beqr_d */
40, /* beqi_d */
12, /* bger_d */
40, /* bgei_d */
12, /* bgtr_d */
40, /* bgti_d */
12, /* bner_d */
44, /* bnei_d */
12, /* bunltr_d */
44, /* bunlti_d */
12, /* bunler_d */
44, /* bunlei_d */
12, /* buneqr_d */
44, /* buneqi_d */
12, /* bunger_d */
44, /* bungei_d */
12, /* bungtr_d */
44, /* bungti_d */
12, /* bltgtr_d */
40, /* bltgti_d */
12, /* bordr_d */
40, /* bordi_d */
12, /* bunordr_d */
44, /* bunordi_d */
0, /* pushargr_d */
0, /* pushargi_d */
0, /* retr_d */
0, /* reti_d */
0, /* retval_d */
0, /* movr_w_f */
0, /* movr_ww_d */
0, /* movr_w_d */
0, /* movr_f_w */
0, /* movi_f_w */
0, /* movr_d_ww */
0, /* movi_d_ww */
0, /* movr_d_w */
0, /* movi_d_w */
#endif /* __WORDSIZE */