Mercurial > pub > dyncall > dyncall
diff dyncallback/dyncall_callback_mips_n64.S @ 305:b104c5beec8b
- softfloat support for mips64/n64 abi
author | Tassilo Philipp |
---|---|
date | Wed, 23 May 2018 11:41:34 +0200 |
parents | d55f9d508074 |
children |
line wrap: on
line diff
--- a/dyncallback/dyncall_callback_mips_n64.S Wed May 23 11:39:40 2018 +0200 +++ b/dyncallback/dyncall_callback_mips_n64.S Wed May 23 11:41:34 2018 +0200 @@ -6,7 +6,7 @@ Description: Callback Thunk - Implementation for mips64 n64 License: - Copyright (c) 2016 Tassilo Philipp <tphilipp@potion-studios.com> + Copyright (c) 2016-2018 Tassilo Philipp <tphilipp@potion-studios.com> Permission to use, copy, modify, and distribute this software for any purpose with or without fee is hereby granted, provided that the above @@ -28,6 +28,18 @@ $t8+64 -> userdata */ +/* Frame size is 160b for hard- and 128b for soft-float, as follows: */ +/* DCargs(fregs:64? + iregs:64 + regcnts:8 + sp:8) + rval:8 + ra:8 */ +#if defined(DC__ABI_HARDFLOAT) +SP_SP = 160 +#else +SP_SP = 96 +#endif +SP_LR = SP_SP-8 +SP_RVAL = SP_SP-16 +SP_ARG_SP = SP_SP-24 +SP_ARG_RC = SP_SP-32 + .section .mdebug.abi64 .previous .abicalls @@ -39,17 +51,15 @@ .set noreorder /* Prolog. */ - /* Frame size of 160b comes from following: */ - /* DCargs(fregs:64 + iregs:64 + regcounts:8 + stackptr:8) + retval:8 + ra:8 */ - daddiu $sp, $sp, -160 /* open frame */ - sd $ra, 152($sp) /* save link register */ + daddiu $sp, $sp, -SP_SP /* open frame */ + sd $ra, SP_LR($sp) /* save link register */ - .frame $fp,160,$31 /* specify our frame: fp,size,lr; creates virt $fp */ + .frame $fp,SP_SP,$31 /* specify our frame: fp,size,lr; creates virt $fp */ /* code below doesn't use $fp though, as n/a with -O1 */ /* Init return value */ - sd $zero, 144($sp) + sd $zero, SP_RVAL($sp) - /* Store float and int args where our DCargs member arrays are, in local area. */ + /* Store reg args where our DCargs member arrays are, in local stack area */ sd $4, 0($sp) sd $5, 8($sp) sd $6, 16($sp) @@ -58,6 +68,7 @@ sd $9, 40($sp) sd $10, 48($sp) sd $11, 56($sp) +#if defined(DC__ABI_HARDFLOAT) s.d $f12, 64($sp) s.d $f13, 72($sp) s.d $f14, 80($sp) @@ -66,31 +77,34 @@ s.d $f17, 104($sp) s.d $f18, 112($sp) s.d $f19, 120($sp) +#endif /* Init DCarg's reg_counts and stackptr. */ - sd $zero, 128($sp) /* reg_count */ - daddiu $4, $sp, 160 - sd $4, 136($sp) /* stackptr */ + sd $zero, SP_ARG_RC($sp) /* reg_count */ + daddiu $4, $sp, SP_SP + sd $4, SP_ARG_SP($sp) /* stackptr */ /* Prepare callback handler call. */ - move $4, $24 /* Param 0 = DCCallback*, $24 ($t8) holds pointer to thunk */ - move $5, $sp /* Param 1 = DCArgs*, pointer to where pointer to args is stored */ - daddiu $6, $sp, 144 /* Param 2 = results pointer to 8b of local data on stack */ - ld $7, 64($24) /* Param 3 = userdata pointer */ + move $4, $24 /* Param 0 = DCCallback*, $24/$t8 holds DCThunk* */ + move $5, $sp /* Param 1 = ptr to where DCArgs* is stored */ + daddiu $6, $sp, SP_RVAL /* Param 2 = results ptr to 8b of local stack data */ + ld $7, 64($24) /* Param 3 = userdata pointer */ - ld $25, 56($24) /* store handler entry in $25 ($t9), required for PIC */ - jalr $25 /* jump */ - nop /* branch delay nop */ + ld $25, 56($24) /* store handler entry in $25/$t9, required for PIC */ + jalr $25 /* jump */ + nop /* branch delay nop */ /* Copy result in corresponding registers $2-$3 ($v0-$v1) and $f0 */ - ld $2, 144($sp) /* note: ignoring second possible retval in $3, here */ - l.d $f0, 144($sp) + ld $2, SP_RVAL($sp) /* note: ignoring 2nd possible retval in $3, here */ +#if defined(DC__ABI_HARDFLOAT) + l.d $f0, SP_RVAL($sp) +#endif /* Epilog. Tear down frame and return. */ - ld $ra, 152($sp) /* restore return address */ - daddiu $sp, $sp, 160 /* close frame */ - j $ra /* return */ - nop /* branch delay nop */ + ld $ra, SP_LR($sp) /* restore return address */ + daddiu $sp, $sp, SP_SP /* close frame */ + j $ra /* return */ + nop /* branch delay nop */ .set reorder .end dcCallbackThunkEntry