mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-05-08 22:50:27 +02:00
* lib/jit_rewind.c: New file implementing generic functions to "rewind", or rewrite IR code sequences. * include/lightning.h: Add several new codes, that previously were a function call, that would synthesize the operation. Now, there is a code for the operation, and a new flag to know an operation is synthesized. * include/lightning/jit_private.h: Add several new macros to help construct synthesized IR code sequences. * lib/Makefile.am: Update for lib/jit_rewind.c. * lib/jit_disasm.c: Update for a small rework on jit_node_t, so that --enable-devel-disassembler does not need a change in the layout of jit_node_t. * lib/jit_names.c: Update for the new codes. * lib/jit_print.c: Update to print more readable output, and flag synthesized IR code sequences. * lib/jit_aarch64-sz.c, lib/jit_aarch64.c, lib/jit_arm-sz.c, lib/jit_arm.c, lib/jit_x86-sz.c, lib/jit_x86.c: Update for new synthesized IR code sequences. * lib/jit_ppc-cpu.c, lib/jit_ppc-fpu., lib/jit_ppc-sz.c, lib/jit_ppc.c, lib/jit_mips-cpu.c, lib/jit_mips-fpu.c, lib/jit_mips-sz.c, lib/jit_mips.c, lib/jit_s390-fpu.c, lib/jit_s390-sz.c, lib/jit_s390.c: Update for new synthesized IR code sequences and correct bugs in the initial varargs implementation support. * lib/jit_alpha-sz.c, lib/jit_alpha.c, lib/jit_hppa-sz.c, lib/jit_hppa.c, lib/jit_ia64-sz.c, lib/jit_ia64.c, lib/jit_sparc-sz.c, lib/jit_sparc.c: Add generic, untested support for the new synthesized IR code sequences. Known most likely broken right now, and should be corrected once access to these hosts is available. * lib/lightning.c: Update for new IR codes, and add support for not yet existing instructions that change third argument. * size.c: Change to use different tables for LE and BE PowerPC. Correct a wrong endif for x32.
802 lines
16 KiB
C
802 lines
16 KiB
C
|
|
#if __WORDSIZE == 32
|
|
#define JIT_INSTR_MAX 104
|
|
0, /* data */
|
|
0, /* live */
|
|
6, /* align */
|
|
0, /* save */
|
|
0, /* load */
|
|
0, /* #name */
|
|
0, /* #note */
|
|
2, /* label */
|
|
42, /* prolog */
|
|
0, /* ellipsis */
|
|
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 */
|
|
44, /* va_start */
|
|
104, /* va_arg */
|
|
100, /* va_arg_d */
|
|
0, /* va_end */
|
|
8, /* addr */
|
|
24, /* addi */
|
|
8, /* addcr */
|
|
20, /* addci */
|
|
8, /* addxr */
|
|
12, /* addxi */
|
|
12, /* subr */
|
|
24, /* subi */
|
|
12, /* subcr */
|
|
20, /* subci */
|
|
12, /* subxr */
|
|
12, /* subxi */
|
|
28, /* rsbi */
|
|
8, /* mulr */
|
|
24, /* muli */
|
|
60, /* qmulr */
|
|
68, /* qmuli */
|
|
16, /* qmulr_u */
|
|
32, /* qmuli_u */
|
|
12, /* divr */
|
|
28, /* divi */
|
|
16, /* divr_u */
|
|
32, /* divi_u */
|
|
16, /* qdivr */
|
|
20, /* qdivi */
|
|
20, /* qdivr_u */
|
|
24, /* qdivi_u */
|
|
12, /* remr */
|
|
28, /* remi */
|
|
16, /* remr_u */
|
|
32, /* remi_u */
|
|
8, /* andr */
|
|
20, /* andi */
|
|
8, /* orr */
|
|
20, /* ori */
|
|
8, /* xorr */
|
|
24, /* xori */
|
|
6, /* lshr */
|
|
10, /* lshi */
|
|
6, /* rshr */
|
|
10, /* rshi */
|
|
6, /* rshr_u */
|
|
10, /* rshi_u */
|
|
4, /* negr */
|
|
12, /* comr */
|
|
20, /* ltr */
|
|
24, /* lti */
|
|
20, /* ltr_u */
|
|
24, /* lti_u */
|
|
20, /* ler */
|
|
24, /* lei */
|
|
20, /* ler_u */
|
|
24, /* lei_u */
|
|
20, /* eqr */
|
|
24, /* eqi */
|
|
20, /* ger */
|
|
24, /* gei */
|
|
20, /* ger_u */
|
|
24, /* gei_u */
|
|
20, /* gtr */
|
|
24, /* gti */
|
|
20, /* gtr_u */
|
|
24, /* gti_u */
|
|
20, /* ner */
|
|
24, /* nei */
|
|
4, /* movr */
|
|
16, /* movi */
|
|
4, /* extr_c */
|
|
4, /* extr_uc */
|
|
4, /* extr_s */
|
|
4, /* extr_us */
|
|
4, /* extr_i */
|
|
4, /* extr_ui */
|
|
4, /* htonr_us */
|
|
4, /* htonr_ui */
|
|
4, /* htonr_ul */
|
|
6, /* ldr_c */
|
|
18, /* ldi_c */
|
|
6, /* ldr_uc */
|
|
18, /* ldi_uc */
|
|
6, /* ldr_s */
|
|
18, /* ldi_s */
|
|
6, /* ldr_us */
|
|
18, /* ldi_us */
|
|
6, /* ldr_i */
|
|
18, /* ldi_i */
|
|
6, /* ldr_ui */
|
|
18, /* ldi_ui */
|
|
6, /* ldr_l */
|
|
18, /* ldi_l */
|
|
14, /* ldxr_c */
|
|
26, /* ldxi_c */
|
|
14, /* ldxr_uc */
|
|
26, /* ldxi_uc */
|
|
14, /* ldxr_s */
|
|
26, /* ldxi_s */
|
|
14, /* ldxr_us */
|
|
26, /* ldxi_us */
|
|
14, /* ldxr_i */
|
|
26, /* ldxi_i */
|
|
14, /* ldxr_ui */
|
|
26, /* ldxi_ui */
|
|
14, /* ldxr_l */
|
|
26, /* ldxi_l */
|
|
4, /* str_c */
|
|
16, /* sti_c */
|
|
4, /* str_s */
|
|
16, /* sti_s */
|
|
4, /* str_i */
|
|
16, /* sti_i */
|
|
6, /* str_l */
|
|
18, /* sti_l */
|
|
12, /* stxr_c */
|
|
28, /* stxi_c */
|
|
12, /* stxr_s */
|
|
28, /* stxi_s */
|
|
12, /* stxr_i */
|
|
28, /* stxi_i */
|
|
14, /* stxr_l */
|
|
30, /* stxi_l */
|
|
10, /* bltr */
|
|
14, /* blti */
|
|
10, /* bltr_u */
|
|
14, /* blti_u */
|
|
10, /* bler */
|
|
14, /* blei */
|
|
10, /* bler_u */
|
|
14, /* blei_u */
|
|
10, /* beqr */
|
|
26, /* beqi */
|
|
10, /* bger */
|
|
14, /* bgei */
|
|
10, /* bger_u */
|
|
14, /* bgei_u */
|
|
10, /* bgtr */
|
|
14, /* bgti */
|
|
10, /* bgtr_u */
|
|
14, /* bgti_u */
|
|
10, /* bner */
|
|
26, /* bnei */
|
|
18, /* bmsr */
|
|
18, /* bmsi */
|
|
18, /* bmcr */
|
|
18, /* bmci */
|
|
10, /* boaddr */
|
|
14, /* boaddi */
|
|
10, /* boaddr_u */
|
|
14, /* boaddi_u */
|
|
10, /* bxaddr */
|
|
14, /* bxaddi */
|
|
10, /* bxaddr_u */
|
|
14, /* bxaddi_u */
|
|
10, /* bosubr */
|
|
14, /* bosubi */
|
|
10, /* bosubr_u */
|
|
14, /* bosubi_u */
|
|
10, /* bxsubr */
|
|
14, /* bxsubi */
|
|
10, /* bxsubr_u */
|
|
14, /* bxsubi_u */
|
|
2, /* jmpr */
|
|
18, /* jmpi */
|
|
2, /* callr */
|
|
18, /* 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 */
|
|
40, /* epilog */
|
|
0, /* arg_f */
|
|
0, /* getarg_f */
|
|
0, /* putargr_f */
|
|
0, /* putargi_f */
|
|
6, /* addr_f */
|
|
26, /* addi_f */
|
|
8, /* subr_f */
|
|
26, /* subi_f */
|
|
28, /* rsbi_f */
|
|
6, /* mulr_f */
|
|
26, /* muli_f */
|
|
8, /* divr_f */
|
|
26, /* divi_f */
|
|
4, /* negr_f */
|
|
4, /* absr_f */
|
|
4, /* sqrtr_f */
|
|
16, /* ltr_f */
|
|
36, /* lti_f */
|
|
16, /* ler_f */
|
|
36, /* lei_f */
|
|
16, /* eqr_f */
|
|
36, /* eqi_f */
|
|
16, /* ger_f */
|
|
36, /* gei_f */
|
|
16, /* gtr_f */
|
|
36, /* gti_f */
|
|
16, /* ner_f */
|
|
36, /* nei_f */
|
|
16, /* unltr_f */
|
|
36, /* unlti_f */
|
|
16, /* unler_f */
|
|
36, /* unlei_f */
|
|
20, /* uneqr_f */
|
|
40, /* uneqi_f */
|
|
16, /* unger_f */
|
|
36, /* ungei_f */
|
|
16, /* ungtr_f */
|
|
36, /* ungti_f */
|
|
20, /* ltgtr_f */
|
|
40, /* ltgti_f */
|
|
16, /* ordr_f */
|
|
36, /* ordi_f */
|
|
16, /* unordr_f */
|
|
36, /* unordi_f */
|
|
4, /* truncr_f_i */
|
|
4, /* truncr_f_l */
|
|
4, /* extr_f */
|
|
4, /* extr_d_f */
|
|
2, /* movr_f */
|
|
20, /* movi_f */
|
|
4, /* ldr_f */
|
|
16, /* ldi_f */
|
|
12, /* ldxr_f */
|
|
24, /* ldxi_f */
|
|
4, /* str_f */
|
|
16, /* sti_f */
|
|
12, /* stxr_f */
|
|
24, /* stxi_f */
|
|
10, /* bltr_f */
|
|
30, /* blti_f */
|
|
10, /* bler_f */
|
|
30, /* blei_f */
|
|
10, /* beqr_f */
|
|
30, /* beqi_f */
|
|
10, /* bger_f */
|
|
30, /* bgei_f */
|
|
10, /* bgtr_f */
|
|
30, /* bgti_f */
|
|
10, /* bner_f */
|
|
30, /* bnei_f */
|
|
10, /* bunltr_f */
|
|
30, /* bunlti_f */
|
|
10, /* bunler_f */
|
|
30, /* bunlei_f */
|
|
18, /* buneqr_f */
|
|
38, /* buneqi_f */
|
|
10, /* bunger_f */
|
|
30, /* bungei_f */
|
|
10, /* bungtr_f */
|
|
30, /* bungti_f */
|
|
18, /* bltgtr_f */
|
|
38, /* bltgti_f */
|
|
10, /* bordr_f */
|
|
30, /* bordi_f */
|
|
10, /* bunordr_f */
|
|
30, /* 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 */
|
|
6, /* addr_d */
|
|
26, /* addi_d */
|
|
8, /* subr_d */
|
|
26, /* subi_d */
|
|
28, /* rsbi_d */
|
|
6, /* mulr_d */
|
|
26, /* muli_d */
|
|
8, /* divr_d */
|
|
26, /* divi_d */
|
|
4, /* negr_d */
|
|
4, /* absr_d */
|
|
4, /* sqrtr_d */
|
|
16, /* ltr_d */
|
|
36, /* lti_d */
|
|
16, /* ler_d */
|
|
36, /* lei_d */
|
|
16, /* eqr_d */
|
|
36, /* eqi_d */
|
|
16, /* ger_d */
|
|
36, /* gei_d */
|
|
16, /* gtr_d */
|
|
36, /* gti_d */
|
|
16, /* ner_d */
|
|
36, /* nei_d */
|
|
16, /* unltr_d */
|
|
36, /* unlti_d */
|
|
16, /* unler_d */
|
|
36, /* unlei_d */
|
|
20, /* uneqr_d */
|
|
40, /* uneqi_d */
|
|
16, /* unger_d */
|
|
36, /* ungei_d */
|
|
16, /* ungtr_d */
|
|
36, /* ungti_d */
|
|
20, /* ltgtr_d */
|
|
40, /* ltgti_d */
|
|
16, /* ordr_d */
|
|
36, /* ordi_d */
|
|
16, /* unordr_d */
|
|
36, /* unordi_d */
|
|
4, /* truncr_d_i */
|
|
4, /* truncr_d_l */
|
|
4, /* extr_d */
|
|
4, /* extr_f_d */
|
|
2, /* movr_d */
|
|
24, /* movi_d */
|
|
4, /* ldr_d */
|
|
16, /* ldi_d */
|
|
12, /* ldxr_d */
|
|
24, /* ldxi_d */
|
|
4, /* str_d */
|
|
16, /* sti_d */
|
|
12, /* stxr_d */
|
|
24, /* stxi_d */
|
|
10, /* bltr_d */
|
|
30, /* blti_d */
|
|
10, /* bler_d */
|
|
30, /* blei_d */
|
|
10, /* beqr_d */
|
|
34, /* beqi_d */
|
|
10, /* bger_d */
|
|
30, /* bgei_d */
|
|
10, /* bgtr_d */
|
|
30, /* bgti_d */
|
|
10, /* bner_d */
|
|
30, /* bnei_d */
|
|
10, /* bunltr_d */
|
|
30, /* bunlti_d */
|
|
10, /* bunler_d */
|
|
30, /* bunlei_d */
|
|
18, /* buneqr_d */
|
|
38, /* buneqi_d */
|
|
10, /* bunger_d */
|
|
30, /* bungei_d */
|
|
10, /* bungtr_d */
|
|
30, /* bungti_d */
|
|
18, /* bltgtr_d */
|
|
38, /* bltgti_d */
|
|
10, /* bordr_d */
|
|
30, /* bordi_d */
|
|
10, /* bunordr_d */
|
|
30, /* 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 */
|
|
|
|
#if __WORDSIZE == 64
|
|
#define JIT_INSTR_MAX 104
|
|
0, /* data */
|
|
0, /* live */
|
|
6, /* align */
|
|
0, /* save */
|
|
0, /* load */
|
|
0, /* #name */
|
|
0, /* #note */
|
|
2, /* label */
|
|
42, /* prolog */
|
|
0, /* ellipsis */
|
|
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 */
|
|
44, /* va_start */
|
|
104, /* va_arg */
|
|
100, /* va_arg_d */
|
|
0, /* va_end */
|
|
8, /* addr */
|
|
24, /* addi */
|
|
8, /* addcr */
|
|
20, /* addci */
|
|
8, /* addxr */
|
|
12, /* addxi */
|
|
12, /* subr */
|
|
24, /* subi */
|
|
12, /* subcr */
|
|
20, /* subci */
|
|
12, /* subxr */
|
|
12, /* subxi */
|
|
28, /* rsbi */
|
|
8, /* mulr */
|
|
24, /* muli */
|
|
60, /* qmulr */
|
|
68, /* qmuli */
|
|
16, /* qmulr_u */
|
|
32, /* qmuli_u */
|
|
12, /* divr */
|
|
28, /* divi */
|
|
16, /* divr_u */
|
|
32, /* divi_u */
|
|
16, /* qdivr */
|
|
20, /* qdivi */
|
|
20, /* qdivr_u */
|
|
24, /* qdivi_u */
|
|
12, /* remr */
|
|
28, /* remi */
|
|
16, /* remr_u */
|
|
32, /* remi_u */
|
|
8, /* andr */
|
|
20, /* andi */
|
|
8, /* orr */
|
|
20, /* ori */
|
|
8, /* xorr */
|
|
24, /* xori */
|
|
6, /* lshr */
|
|
10, /* lshi */
|
|
6, /* rshr */
|
|
10, /* rshi */
|
|
6, /* rshr_u */
|
|
10, /* rshi_u */
|
|
4, /* negr */
|
|
12, /* comr */
|
|
20, /* ltr */
|
|
24, /* lti */
|
|
20, /* ltr_u */
|
|
24, /* lti_u */
|
|
20, /* ler */
|
|
24, /* lei */
|
|
20, /* ler_u */
|
|
24, /* lei_u */
|
|
20, /* eqr */
|
|
24, /* eqi */
|
|
20, /* ger */
|
|
24, /* gei */
|
|
20, /* ger_u */
|
|
24, /* gei_u */
|
|
20, /* gtr */
|
|
24, /* gti */
|
|
20, /* gtr_u */
|
|
24, /* gti_u */
|
|
20, /* ner */
|
|
24, /* nei */
|
|
4, /* movr */
|
|
16, /* movi */
|
|
4, /* extr_c */
|
|
4, /* extr_uc */
|
|
4, /* extr_s */
|
|
4, /* extr_us */
|
|
4, /* extr_i */
|
|
4, /* extr_ui */
|
|
4, /* htonr_us */
|
|
4, /* htonr_ui */
|
|
4, /* htonr_ul */
|
|
6, /* ldr_c */
|
|
18, /* ldi_c */
|
|
6, /* ldr_uc */
|
|
18, /* ldi_uc */
|
|
6, /* ldr_s */
|
|
18, /* ldi_s */
|
|
6, /* ldr_us */
|
|
18, /* ldi_us */
|
|
6, /* ldr_i */
|
|
18, /* ldi_i */
|
|
6, /* ldr_ui */
|
|
18, /* ldi_ui */
|
|
6, /* ldr_l */
|
|
18, /* ldi_l */
|
|
14, /* ldxr_c */
|
|
26, /* ldxi_c */
|
|
14, /* ldxr_uc */
|
|
26, /* ldxi_uc */
|
|
14, /* ldxr_s */
|
|
26, /* ldxi_s */
|
|
14, /* ldxr_us */
|
|
26, /* ldxi_us */
|
|
14, /* ldxr_i */
|
|
26, /* ldxi_i */
|
|
14, /* ldxr_ui */
|
|
26, /* ldxi_ui */
|
|
14, /* ldxr_l */
|
|
26, /* ldxi_l */
|
|
4, /* str_c */
|
|
16, /* sti_c */
|
|
4, /* str_s */
|
|
16, /* sti_s */
|
|
4, /* str_i */
|
|
16, /* sti_i */
|
|
6, /* str_l */
|
|
18, /* sti_l */
|
|
12, /* stxr_c */
|
|
28, /* stxi_c */
|
|
12, /* stxr_s */
|
|
28, /* stxi_s */
|
|
12, /* stxr_i */
|
|
28, /* stxi_i */
|
|
14, /* stxr_l */
|
|
30, /* stxi_l */
|
|
10, /* bltr */
|
|
14, /* blti */
|
|
10, /* bltr_u */
|
|
14, /* blti_u */
|
|
10, /* bler */
|
|
14, /* blei */
|
|
10, /* bler_u */
|
|
14, /* blei_u */
|
|
10, /* beqr */
|
|
26, /* beqi */
|
|
10, /* bger */
|
|
14, /* bgei */
|
|
10, /* bger_u */
|
|
14, /* bgei_u */
|
|
10, /* bgtr */
|
|
14, /* bgti */
|
|
10, /* bgtr_u */
|
|
14, /* bgti_u */
|
|
10, /* bner */
|
|
26, /* bnei */
|
|
18, /* bmsr */
|
|
18, /* bmsi */
|
|
18, /* bmcr */
|
|
18, /* bmci */
|
|
10, /* boaddr */
|
|
14, /* boaddi */
|
|
10, /* boaddr_u */
|
|
14, /* boaddi_u */
|
|
10, /* bxaddr */
|
|
14, /* bxaddi */
|
|
10, /* bxaddr_u */
|
|
14, /* bxaddi_u */
|
|
10, /* bosubr */
|
|
14, /* bosubi */
|
|
10, /* bosubr_u */
|
|
14, /* bosubi_u */
|
|
10, /* bxsubr */
|
|
14, /* bxsubi */
|
|
10, /* bxsubr_u */
|
|
14, /* bxsubi_u */
|
|
2, /* jmpr */
|
|
18, /* jmpi */
|
|
2, /* callr */
|
|
18, /* 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 */
|
|
40, /* epilog */
|
|
0, /* arg_f */
|
|
0, /* getarg_f */
|
|
0, /* putargr_f */
|
|
0, /* putargi_f */
|
|
6, /* addr_f */
|
|
26, /* addi_f */
|
|
8, /* subr_f */
|
|
26, /* subi_f */
|
|
28, /* rsbi_f */
|
|
6, /* mulr_f */
|
|
26, /* muli_f */
|
|
8, /* divr_f */
|
|
26, /* divi_f */
|
|
4, /* negr_f */
|
|
4, /* absr_f */
|
|
4, /* sqrtr_f */
|
|
16, /* ltr_f */
|
|
36, /* lti_f */
|
|
16, /* ler_f */
|
|
36, /* lei_f */
|
|
16, /* eqr_f */
|
|
36, /* eqi_f */
|
|
16, /* ger_f */
|
|
36, /* gei_f */
|
|
16, /* gtr_f */
|
|
36, /* gti_f */
|
|
16, /* ner_f */
|
|
36, /* nei_f */
|
|
16, /* unltr_f */
|
|
36, /* unlti_f */
|
|
16, /* unler_f */
|
|
36, /* unlei_f */
|
|
20, /* uneqr_f */
|
|
40, /* uneqi_f */
|
|
16, /* unger_f */
|
|
36, /* ungei_f */
|
|
16, /* ungtr_f */
|
|
36, /* ungti_f */
|
|
20, /* ltgtr_f */
|
|
40, /* ltgti_f */
|
|
16, /* ordr_f */
|
|
36, /* ordi_f */
|
|
16, /* unordr_f */
|
|
36, /* unordi_f */
|
|
4, /* truncr_f_i */
|
|
4, /* truncr_f_l */
|
|
4, /* extr_f */
|
|
4, /* extr_d_f */
|
|
2, /* movr_f */
|
|
20, /* movi_f */
|
|
4, /* ldr_f */
|
|
16, /* ldi_f */
|
|
12, /* ldxr_f */
|
|
24, /* ldxi_f */
|
|
4, /* str_f */
|
|
16, /* sti_f */
|
|
12, /* stxr_f */
|
|
24, /* stxi_f */
|
|
10, /* bltr_f */
|
|
30, /* blti_f */
|
|
10, /* bler_f */
|
|
30, /* blei_f */
|
|
10, /* beqr_f */
|
|
30, /* beqi_f */
|
|
10, /* bger_f */
|
|
30, /* bgei_f */
|
|
10, /* bgtr_f */
|
|
30, /* bgti_f */
|
|
10, /* bner_f */
|
|
30, /* bnei_f */
|
|
10, /* bunltr_f */
|
|
30, /* bunlti_f */
|
|
10, /* bunler_f */
|
|
30, /* bunlei_f */
|
|
18, /* buneqr_f */
|
|
38, /* buneqi_f */
|
|
10, /* bunger_f */
|
|
30, /* bungei_f */
|
|
10, /* bungtr_f */
|
|
30, /* bungti_f */
|
|
18, /* bltgtr_f */
|
|
38, /* bltgti_f */
|
|
10, /* bordr_f */
|
|
30, /* bordi_f */
|
|
10, /* bunordr_f */
|
|
30, /* 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 */
|
|
6, /* addr_d */
|
|
26, /* addi_d */
|
|
8, /* subr_d */
|
|
26, /* subi_d */
|
|
28, /* rsbi_d */
|
|
6, /* mulr_d */
|
|
26, /* muli_d */
|
|
8, /* divr_d */
|
|
26, /* divi_d */
|
|
4, /* negr_d */
|
|
4, /* absr_d */
|
|
4, /* sqrtr_d */
|
|
16, /* ltr_d */
|
|
36, /* lti_d */
|
|
16, /* ler_d */
|
|
36, /* lei_d */
|
|
16, /* eqr_d */
|
|
36, /* eqi_d */
|
|
16, /* ger_d */
|
|
36, /* gei_d */
|
|
16, /* gtr_d */
|
|
36, /* gti_d */
|
|
16, /* ner_d */
|
|
36, /* nei_d */
|
|
16, /* unltr_d */
|
|
36, /* unlti_d */
|
|
16, /* unler_d */
|
|
36, /* unlei_d */
|
|
20, /* uneqr_d */
|
|
40, /* uneqi_d */
|
|
16, /* unger_d */
|
|
36, /* ungei_d */
|
|
16, /* ungtr_d */
|
|
36, /* ungti_d */
|
|
20, /* ltgtr_d */
|
|
40, /* ltgti_d */
|
|
16, /* ordr_d */
|
|
36, /* ordi_d */
|
|
16, /* unordr_d */
|
|
36, /* unordi_d */
|
|
4, /* truncr_d_i */
|
|
4, /* truncr_d_l */
|
|
4, /* extr_d */
|
|
4, /* extr_f_d */
|
|
2, /* movr_d */
|
|
24, /* movi_d */
|
|
4, /* ldr_d */
|
|
16, /* ldi_d */
|
|
12, /* ldxr_d */
|
|
24, /* ldxi_d */
|
|
4, /* str_d */
|
|
16, /* sti_d */
|
|
12, /* stxr_d */
|
|
24, /* stxi_d */
|
|
10, /* bltr_d */
|
|
30, /* blti_d */
|
|
10, /* bler_d */
|
|
30, /* blei_d */
|
|
10, /* beqr_d */
|
|
34, /* beqi_d */
|
|
10, /* bger_d */
|
|
30, /* bgei_d */
|
|
10, /* bgtr_d */
|
|
30, /* bgti_d */
|
|
10, /* bner_d */
|
|
30, /* bnei_d */
|
|
10, /* bunltr_d */
|
|
30, /* bunlti_d */
|
|
10, /* bunler_d */
|
|
30, /* bunlei_d */
|
|
18, /* buneqr_d */
|
|
38, /* buneqi_d */
|
|
10, /* bunger_d */
|
|
30, /* bungei_d */
|
|
10, /* bungtr_d */
|
|
30, /* bungti_d */
|
|
18, /* bltgtr_d */
|
|
38, /* bltgti_d */
|
|
10, /* bordr_d */
|
|
30, /* bordi_d */
|
|
10, /* bunordr_d */
|
|
30, /* 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 */
|