📄 hipe_ppc_bifs.m4
字号:
changecom(`/*', `*/')dnl/* * $Id$ */include(`hipe/hipe_ppc_asm.m4')#`include' "hipe_literals.h" .text .p2align 2/* * XXX: TODO: * - All standard BIF interfaces save RA in the PCB now. This * is needed for those BIFs that can trigger a walk of the * native stack, which includes those that can do a gc. * Ideally this overhead should only be imposed for those BIFs * that actually need it, but that set changes from time to * time, and is difficult for us to track. * - Can a GC:ing BIF change P_NRA(P) due to the stack trap thingy? */`#if defined(HEAP_FRAG_ELIM_TEST)#define TEST_GOT_MBUF LOAD r4, P_MBUF(P); CMPI r4, 0; bne- 3f; 2:#define JOIN3(A,B,C) A##B##C#define HANDLE_GOT_MBUF(ARITY) 3: bl CSYM(JOIN3(nbif_,ARITY,_gc_after_bif)); b 2b#else#define TEST_GOT_MBUF /*empty*/#define HANDLE_GOT_MBUF(ARITY) /*empty*/#endif'/* * standard_bif_interface_1(nbif_name, cbif_name) * standard_bif_interface_2(nbif_name, cbif_name) * standard_bif_interface_3(nbif_name, cbif_name) * * Generate native interface for a BIF with 1-3 parameters and * standard failure mode (may fail, but not with RESCHEDULE). */define(standard_bif_interface_1,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,1,0) /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_BIF bl CSYM($2) TEST_GOT_MBUF /* Restore registers. Check for exception. */ CMPI r3, THE_NON_VALUE RESTORE_CONTEXT_BIF beq- 1f NBIF_RET(1)1: /* workaround for bc:s small offset operand */ b CSYM(nbif_1_simple_exception) HANDLE_GOT_MBUF(1) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(standard_bif_interface_2,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,2,0) NBIF_ARG(r5,2,1) /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_BIF bl CSYM($2) TEST_GOT_MBUF /* Restore registers. Check for exception. */ CMPI r3, THE_NON_VALUE RESTORE_CONTEXT_BIF beq- 1f NBIF_RET(2)1: /* workaround for bc:s small offset operand */ b CSYM(nbif_2_simple_exception) HANDLE_GOT_MBUF(2) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(standard_bif_interface_3,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,3,0) NBIF_ARG(r5,3,1) NBIF_ARG(r6,3,2) /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_BIF bl CSYM($2) TEST_GOT_MBUF /* Restore registers. Check for exception. */ CMPI r3, THE_NON_VALUE RESTORE_CONTEXT_BIF beq- 1f NBIF_RET(3)1: /* workaround for bc:s small offset operand */ b CSYM(nbif_3_simple_exception) HANDLE_GOT_MBUF(3) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')/* * expensive_bif_interface_1(nbif_name, cbif_name) * expensive_bif_interface_2(nbif_name, cbif_name) * * Generate native interface for a BIF with 1-2 parameters and * an expensive failure mode (may fail with RESCHEDULE). */define(expensive_bif_interface_1,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,1,0) /* Save actual parameters in case we must reschedule. */ NBIF_SAVE_RESCHED_ARGS(1) /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_BIF bl CSYM($2) TEST_GOT_MBUF /* Restore registers. Check for exception. */ CMPI r3, THE_NON_VALUE RESTORE_CONTEXT_BIF beq- 1f NBIF_RET(1)1: /* XXX: may need to change for PPC64 */ addi r5, 0, lo16(ASYM($1)) addis r5, r5, ha16(ASYM($1)) b CSYM(nbif_1_hairy_exception) HANDLE_GOT_MBUF(1) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(expensive_bif_interface_2,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,2,0) NBIF_ARG(r5,2,1) /* Save actual parameters in case we must reschedule. */ NBIF_SAVE_RESCHED_ARGS(2) /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_BIF bl CSYM($2) TEST_GOT_MBUF /* Restore registers. Check for exception. */ CMPI r3, THE_NON_VALUE RESTORE_CONTEXT_BIF beq- 1f NBIF_RET(2)1: /* XXX: may need to change for PPC64 */ addi r5, 0, lo16(ASYM($1)) addis r5, r5, ha16(ASYM($1)) b CSYM(nbif_2_hairy_exception) HANDLE_GOT_MBUF(2) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')/* * gc_bif_interface_0(nbif_name, cbif_name) * gc_bif_interface_1(nbif_name, cbif_name) * gc_bif_interface_2(nbif_name, cbif_name) * * Generate native interface for a BIF with 0-2 parameters and * standard failure mode (may fail, but not with RESCHEDULE). * The BIF may do a GC. */define(gc_bif_interface_0,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_GC bl CSYM($2) TEST_GOT_MBUF /* Restore registers. */ RESTORE_CONTEXT_GC NBIF_RET(0) HANDLE_GOT_MBUF(0) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(gc_bif_interface_1,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,1,0) /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_GC bl CSYM($2) TEST_GOT_MBUF /* Restore registers. Check for exception. */ CMPI r3, THE_NON_VALUE RESTORE_CONTEXT_GC beq- 1f NBIF_RET(1)1: /* workaround for bc:s small offset operand */ b CSYM(nbif_1_simple_exception) HANDLE_GOT_MBUF(1) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(gc_bif_interface_2,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,2,0) NBIF_ARG(r5,2,1) /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_GC bl CSYM($2) TEST_GOT_MBUF /* Restore registers. Check for exception. */ CMPI r3, THE_NON_VALUE RESTORE_CONTEXT_GC beq- 1f NBIF_RET(2)1: /* workaround for bc:s small offset operand */ b CSYM(nbif_2_simple_exception) HANDLE_GOT_MBUF(2) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')/* * gc_nofail_primop_interface_1(nbif_name, cbif_name) * * Generate native interface for a primop with implicit P * parameter, 0-3 ordinary parameters and no failure mode. * The primop may do a GC. */define(gc_nofail_primop_interface_1,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,1,0) /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_GC bl CSYM($2) /* Restore registers. */ RESTORE_CONTEXT_GC NBIF_RET(1) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')/* * nofail_primop_interface_0(nbif_name, cbif_name) * nofail_primop_interface_1(nbif_name, cbif_name) * nofail_primop_interface_2(nbif_name, cbif_name) * nofail_primop_interface_3(nbif_name, cbif_name) * * Generate native interface for a primop with implicit P * parameter, 0-3 ordinary parameters and no failure mode. * Also used for guard BIFs. */define(nofail_primop_interface_0,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_BIF bl CSYM($2) TEST_GOT_MBUF /* Restore registers. */ RESTORE_CONTEXT_BIF NBIF_RET(0) HANDLE_GOT_MBUF(0) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(nofail_primop_interface_1,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,1,0) /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_BIF bl CSYM($2) TEST_GOT_MBUF /* Restore registers. */ RESTORE_CONTEXT_BIF NBIF_RET(1) HANDLE_GOT_MBUF(1) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(nofail_primop_interface_2,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,2,0) NBIF_ARG(r5,2,1) /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_BIF bl CSYM($2) TEST_GOT_MBUF /* Restore registers. */ RESTORE_CONTEXT_BIF NBIF_RET(2) HANDLE_GOT_MBUF(2) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(nofail_primop_interface_3,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,3,0) NBIF_ARG(r5,3,1) NBIF_ARG(r6,3,2) /* Save caller-save registers and call the C function. */ SAVE_CONTEXT_BIF bl CSYM($2) TEST_GOT_MBUF /* Restore registers. */ RESTORE_CONTEXT_BIF NBIF_RET(3) HANDLE_GOT_MBUF(3) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')/* * nocons_nofail_primop_interface_0(nbif_name, cbif_name) * nocons_nofail_primop_interface_1(nbif_name, cbif_name) * nocons_nofail_primop_interface_2(nbif_name, cbif_name) * nocons_nofail_primop_interface_3(nbif_name, cbif_name) * nocons_nofail_primop_interface_5(nbif_name, cbif_name) * * Generate native interface for a primop with implicit P * parameter, 0-3 or 5 ordinary parameters, and no failure mode. * The primop cannot CONS or gc. */define(nocons_nofail_primop_interface_0,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P /* Perform a quick save;call;restore;ret sequence. */ QUICK_CALL_RET(CSYM($2),0) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(nocons_nofail_primop_interface_1,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,1,0) /* Perform a quick save;call;restore;ret sequence. */ QUICK_CALL_RET(CSYM($2),1) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(nocons_nofail_primop_interface_2,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,2,0) NBIF_ARG(r5,2,1) /* Perform a quick save;call;restore;ret sequence. */ QUICK_CALL_RET(CSYM($2),2) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(nocons_nofail_primop_interface_3,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,3,0) NBIF_ARG(r5,3,1) NBIF_ARG(r6,3,2) /* Perform a quick save;call;restore;ret sequence. */ QUICK_CALL_RET(CSYM($2),3) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(nocons_nofail_primop_interface_5,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ mr r3, P NBIF_ARG(r4,5,0) NBIF_ARG(r5,5,1) NBIF_ARG(r6,5,2) NBIF_ARG(r7,5,3) NBIF_ARG(r8,5,4) /* Perform a quick save;call;restore;ret sequence. */ QUICK_CALL_RET(CSYM($2),5) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')/* * noproc_primop_interface_0(nbif_name, cbif_name) * noproc_primop_interface_1(nbif_name, cbif_name) * noproc_primop_interface_2(nbif_name, cbif_name) * noproc_primop_interface_3(nbif_name, cbif_name) * noproc_primop_interface_5(nbif_name, cbif_name) * * Generate native interface for a primop with no implicit P * parameter, 0-3 or 5 ordinary parameters, and no failure mode. * The primop cannot CONS or gc. */define(noproc_primop_interface_0,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* XXX: this case is always trivial; how to suppress the branch? */ /* Perform a quick save;call;restore;ret sequence. */ QUICK_CALL_RET(CSYM($2),0) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(noproc_primop_interface_1,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ NBIF_ARG(r3,1,0) /* Perform a quick save;call;restore;ret sequence. */ QUICK_CALL_RET(CSYM($2),1) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(noproc_primop_interface_2,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ NBIF_ARG(r3,2,0) NBIF_ARG(r4,2,1) /* Perform a quick save;call;restore;ret sequence. */ QUICK_CALL_RET(CSYM($2),2) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(noproc_primop_interface_3,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ NBIF_ARG(r3,3,0) NBIF_ARG(r4,3,1) NBIF_ARG(r5,3,2) /* Perform a quick save;call;restore;ret sequence. */ QUICK_CALL_RET(CSYM($2),3) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')define(noproc_primop_interface_5,`#ifndef HAVE_$1#`define' HAVE_$1 GLOBAL(ASYM($1))ASYM($1): /* Set up C argument registers. */ NBIF_ARG(r3,5,0) NBIF_ARG(r4,5,1) NBIF_ARG(r5,5,2) NBIF_ARG(r6,5,3) NBIF_ARG(r7,5,4) /* Perform a quick save;call;restore;ret sequence. */ QUICK_CALL_RET(CSYM($2),5) SET_SIZE(ASYM($1)) TYPE_FUNCTION(ASYM($1))#endif')/* * Implement standard_bif_interface_0 as nofail_primop_interface_0. */define(standard_bif_interface_0,`nofail_primop_interface_0($1, $2)')include(`hipe/hipe_bif_list.m4')
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -