diff dyncall/dyncall_callvm_ppc64.c @ 533:71c884e610f0

- integration of patches from Raphael Luba, Thekla, Inc.: * integration of aggregate-by-value (struct, union) support patch for x64 (win and sysv) * windows/x64 asm additions to specify how stack unwinds (help for debuggers, exception handling, etc.) * see Changelog for details - new calling convention modes for thiscalls (platform agnostic, was specific before) * new signature character for platform agnostic thiscalls ('*' / DC_SIGCHAR_CC_THISCALL) - dcCallF(), dcVCallF(), dcArgF() and dcVArgF(): * added support for aggregates-by-value (wasn't part of patch) * change that those functions don't implicitly call dcReset() anymore, which was unflexible (breaking change) - added macros to feature test implementation for aggregate-by-value and syscall support - changed libdyncall_s.lib and libdyncallback_s.lib order in callback test makefiles, as some toolchains are picky about order - doc: * man page updates to describe aggregate interface * manual overview changes to highlight platforms with aggregate-by-value support - test/plain: replaced tests w/ old/stale sctruct interface with new aggregate one
author Tassilo Philipp
date Thu, 21 Apr 2022 13:35:47 +0200
parents ddfb9577a00e
children
line wrap: on
line diff
--- a/dyncall/dyncall_callvm_ppc64.c	Sat Apr 16 15:00:58 2022 +0200
+++ b/dyncall/dyncall_callvm_ppc64.c	Thu Apr 21 13:35:47 2022 +0200
@@ -259,7 +259,7 @@
   if (size < 64) {
 	dcVecSkip(&self->mVecHead, 64-size);
   }
-
+ 
   dcCall_ppc64( target, &self->mRegData, dcVecSize(&self->mVecHead) , dcVecData(&self->mVecHead));
 }
 
@@ -285,7 +285,7 @@
 , &dc_callvm_argFloat_ppc64
 , &dc_callvm_argDouble_ppc64
 , &dc_callvm_argPointer_ppc64
-, NULL /* argStruct */
+, NULL /* argAggr */
 , (DCvoidvmfunc*)       &dc_callvm_call_ppc64
 , (DCboolvmfunc*)       &dc_callvm_call_ppc64
 , (DCcharvmfunc*)       &dc_callvm_call_ppc64
@@ -296,7 +296,8 @@
 , (DCfloatvmfunc*)      &dc_callvm_call_ppc64
 , (DCdoublevmfunc*)     &dc_callvm_call_ppc64
 , (DCpointervmfunc*)    &dc_callvm_call_ppc64
-, NULL /* callStruct */
+, NULL /* callAggr */
+, NULL /* beginAggr */
 };
 
 #if DC__ABI_PPC64_ELF_V == 2
@@ -314,7 +315,7 @@
 , &dc_callvm_argFloat_ppc64_ellipsis
 , &dc_callvm_argDouble_ppc64_ellipsis
 , &dc_callvm_argPointer_ppc64
-, NULL /* argStruct */
+, NULL /* argAggr */
 , (DCvoidvmfunc*)       &dc_callvm_call_ppc64
 , (DCboolvmfunc*)       &dc_callvm_call_ppc64
 , (DCcharvmfunc*)       &dc_callvm_call_ppc64
@@ -325,7 +326,8 @@
 , (DCfloatvmfunc*)      &dc_callvm_call_ppc64
 , (DCdoublevmfunc*)     &dc_callvm_call_ppc64
 , (DCpointervmfunc*)    &dc_callvm_call_ppc64
-, NULL /* callStruct */
+, NULL /* callAggr */
+, NULL /* beginAggr */
 };
 #endif
 
@@ -343,7 +345,7 @@
 , &dc_callvm_argFloat_ppc64
 , &dc_callvm_argDouble_ppc64
 , &dc_callvm_argPointer_ppc64
-, NULL /* argStruct */
+, NULL /* argAggr */
 , (DCvoidvmfunc*)       &dc_callvm_call_ppc64_syscall
 , (DCboolvmfunc*)       &dc_callvm_call_ppc64_syscall
 , (DCcharvmfunc*)       &dc_callvm_call_ppc64_syscall
@@ -354,7 +356,8 @@
 , (DCfloatvmfunc*)      &dc_callvm_call_ppc64_syscall
 , (DCdoublevmfunc*)     &dc_callvm_call_ppc64_syscall
 , (DCpointervmfunc*)    &dc_callvm_call_ppc64_syscall
-, NULL /* callStruct */
+, NULL /* callAggr */
+, NULL /* beginAggr */
 };
 
 void dc_callvm_mode_ppc64(DCCallVM* in_self, DCint mode)