Modify the ffi_closure structures to hold table/table entry pointers instead of a...
authorLandon Fuller <landonf@bikemonkey.org>
Sat, 12 Feb 2011 16:14:54 +0000 (11:14 -0500)
committerLandon Fuller <landonf@bikemonkey.org>
Sat, 12 Feb 2011 16:14:54 +0000 (11:14 -0500)
This re-integrates commit da2773e02ab26cc11a7f.

include/ffi.h.in

index 96b8fd3..747dd17 100644 (file)
@@ -270,7 +270,12 @@ size_t ffi_java_raw_size (ffi_cif *cif);
 __declspec(align(8))
 #endif
 typedef struct {
+#if @FFI_EXEC_TRAMPOLINE_TABLE@
+  void *trampoline_table;
+  void *trampoline_table_entry;
+#else
   char tramp[FFI_TRAMPOLINE_SIZE];
+#endif
   ffi_cif   *cif;
   void     (*fun)(ffi_cif*,void*,void**,void*);
   void      *user_data;
@@ -303,7 +308,12 @@ ffi_prep_closure_loc (ffi_closure*,
 # pragma pack 8
 #endif
 typedef struct {
+#if @FFI_EXEC_TRAMPOLINE_TABLE@
+  void *trampoline_table;
+  void *trampoline_table_entry;
+#else
   char tramp[FFI_TRAMPOLINE_SIZE];
+#endif
 
   ffi_cif   *cif;
 
@@ -324,7 +334,12 @@ typedef struct {
 } ffi_raw_closure;
 
 typedef struct {
+#if @FFI_EXEC_TRAMPOLINE_TABLE@
+  void *trampoline_table;
+  void *trampoline_table_entry;
+#else
   char tramp[FFI_TRAMPOLINE_SIZE];
+#endif
 
   ffi_cif   *cif;