Fix xlc build on AIX
authorAnthony Green <green@moxielogic.com>
Fri, 11 Feb 2011 12:32:51 +0000 (07:32 -0500)
committerAnthony Green <green@moxielogic.com>
Fri, 11 Feb 2011 12:32:51 +0000 (07:32 -0500)
16 files changed:
.pc/aix-ibm-xlc/src/powerpc/aix.S [new file with mode: 0644]
.pc/aix-ibm-xlc/src/powerpc/aix_closure.S [new file with mode: 0644]
.pc/fix-grammar/ChangeLog
.pc/fix-xfails/ChangeLog
.pc/hpux-mallinfo/ChangeLog
.pc/interix/ChangeLog
.pc/ios/ChangeLog
.pc/irix/ChangeLog
.pc/ppc64-darwin/ChangeLog
.pc/sparc-abi-check/ChangeLog
.pc/sparc-v8-aggregate-returns/ChangeLog
ChangeLog
patches/aix-ibm-xlc
patches/fix-grammar
src/powerpc/aix.S
src/powerpc/aix_closure.S

diff --git a/.pc/aix-ibm-xlc/src/powerpc/aix.S b/.pc/aix-ibm-xlc/src/powerpc/aix.S
new file mode 100644 (file)
index 0000000..c6f8764
--- /dev/null
@@ -0,0 +1,324 @@
+/* -----------------------------------------------------------------------
+   aix.S - Copyright (c) 2002,2009 Free Software Foundation, Inc.
+   based on darwin.S by John Hornkvist
+
+   PowerPC Assembly glue.
+
+   Permission is hereby granted, free of charge, to any person obtaining
+   a copy of this software and associated documentation files (the
+   ``Software''), to deal in the Software without restriction, including
+   without limitation the rights to use, copy, modify, merge, publish,
+   distribute, sublicense, and/or sell copies of the Software, and to
+   permit persons to whom the Software is furnished to do so, subject to
+   the following conditions:
+
+   The above copyright notice and this permission notice shall be included
+   in all copies or substantial portions of the Software.
+
+   THE SOFTWARE IS PROVIDED ``AS IS'', WITHOUT WARRANTY OF ANY KIND, EXPRESS
+   OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
+   IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR
+   OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+   ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+   OTHER DEALINGS IN THE SOFTWARE.
+   ----------------------------------------------------------------------- */
+
+       .set r0,0
+       .set r1,1
+       .set r2,2
+       .set r3,3
+       .set r4,4
+       .set r5,5
+       .set r6,6
+       .set r7,7
+       .set r8,8
+       .set r9,9
+       .set r10,10
+       .set r11,11
+       .set r12,12
+       .set r13,13
+       .set r14,14
+       .set r15,15
+       .set r16,16
+       .set r17,17
+       .set r18,18
+       .set r19,19
+       .set r20,20
+       .set r21,21
+       .set r22,22
+       .set r23,23
+       .set r24,24
+       .set r25,25
+       .set r26,26
+       .set r27,27
+       .set r28,28
+       .set r29,29
+       .set r30,30
+       .set r31,31
+       .set f0,0
+       .set f1,1
+       .set f2,2
+       .set f3,3
+       .set f4,4
+       .set f5,5
+       .set f6,6
+       .set f7,7
+       .set f8,8
+       .set f9,9
+       .set f10,10
+       .set f11,11
+       .set f12,12
+       .set f13,13
+       .set f14,14
+       .set f15,15
+       .set f16,16
+       .set f17,17
+       .set f18,18
+       .set f19,19
+       .set f20,20
+       .set f21,21
+
+#define LIBFFI_ASM
+#include <fficonfig.h>
+#include <ffi.h>
+#define JUMPTARGET(name) name
+#define L(x) x
+       .file "aix.S"
+       .toc
+
+       /* void ffi_call_AIX(extended_cif *ecif, unsigned long bytes,
+        *                   unsigned int flags, unsigned int *rvalue,
+        *                   void (*fn)(),
+        *                   void (*prep_args)(extended_cif*, unsigned *const));
+        * r3=ecif, r4=bytes, r5=flags, r6=rvalue, r7=fn, r8=prep_args
+        */
+
+.csect .text[PR]
+       .align 2
+       .globl ffi_call_AIX
+       .globl .ffi_call_AIX
+.csect ffi_call_AIX[DS]
+ffi_call_AIX:
+#ifdef __64BIT__
+       .llong .ffi_call_AIX, TOC[tc0], 0
+       .csect .text[PR]
+.ffi_call_AIX:
+       /* Save registers we use.  */
+       mflr    r0
+
+       std     r28,-32(r1)
+       std     r29,-24(r1)
+       std     r30,-16(r1)
+       std     r31, -8(r1)
+
+       std     r0, 16(r1)
+       mr      r28, r1         /* our AP.  */
+       stdux   r1, r1, r4
+
+       /* Save arguments over call...  */
+       mr      r31, r5 /* flags, */
+       mr      r30, r6 /* rvalue, */
+       mr      r29, r7 /* function address.  */
+       std     r2, 40(r1)
+
+       /* Call ffi_prep_args.  */
+       mr      r4, r1
+       bl      .ffi_prep_args
+
+       /* Now do the call.  */
+       ld      r0, 0(r29)
+       ld      r2, 8(r29)
+       ld      r11, 16(r29)
+       /* Set up cr1 with bits 4-7 of the flags.  */
+       mtcrf   0x40, r31
+       mtctr   r0
+       /* Load all those argument registers.  */
+       // We have set up a nice stack frame, just load it into registers.
+       ld      r3, 40+(1*8)(r1)
+       ld      r4, 40+(2*8)(r1)
+       ld      r5, 40+(3*8)(r1)
+       ld      r6, 40+(4*8)(r1)
+       nop
+       ld      r7, 40+(5*8)(r1)
+       ld      r8, 40+(6*8)(r1)
+       ld      r9, 40+(7*8)(r1)
+       ld      r10,40+(8*8)(r1)
+
+L1:
+       /* Load all the FP registers.  */
+       bf      6,L2 // 2f + 0x18
+       lfd     f1,-32-(13*8)(r28)
+       lfd     f2,-32-(12*8)(r28)
+       lfd     f3,-32-(11*8)(r28)
+       lfd     f4,-32-(10*8)(r28)
+       nop
+       lfd     f5,-32-(9*8)(r28)
+       lfd     f6,-32-(8*8)(r28)
+       lfd     f7,-32-(7*8)(r28)
+       lfd     f8,-32-(6*8)(r28)
+       nop
+       lfd     f9,-32-(5*8)(r28)
+       lfd     f10,-32-(4*8)(r28)
+       lfd     f11,-32-(3*8)(r28)
+       lfd     f12,-32-(2*8)(r28)
+       nop
+       lfd     f13,-32-(1*8)(r28)
+
+L2:
+       /* Make the call.  */
+       bctrl
+       ld      r2, 40(r1)
+
+       /* Now, deal with the return value.  */
+       mtcrf   0x01, r31
+
+       bt      30, L(done_return_value)
+       bt      29, L(fp_return_value)
+       std     r3, 0(r30)
+
+       /* Fall through...  */
+
+L(done_return_value):
+       /* Restore the registers we used and return.  */
+       mr      r1, r28
+       ld      r0, 16(r28)
+       ld      r28, -32(r1)
+       mtlr    r0
+       ld      r29, -24(r1)
+       ld      r30, -16(r1)
+       ld      r31, -8(r1)
+       blr
+
+L(fp_return_value):
+       bf      28, L(float_return_value)
+       stfd    f1, 0(r30)
+       bf      31, L(done_return_value)
+       stfd    f2, 8(r30)
+       b       L(done_return_value)
+L(float_return_value):
+       stfs    f1, 0(r30)
+       b       L(done_return_value)
+
+#else /* ! __64BIT__ */
+       
+       .long .ffi_call_AIX, TOC[tc0], 0
+       .csect .text[PR]
+.ffi_call_AIX:
+       /* Save registers we use.  */
+       mflr    r0
+
+       stw     r28,-16(r1)
+       stw     r29,-12(r1)
+       stw     r30, -8(r1)
+       stw     r31, -4(r1)
+
+       stw     r0, 8(r1)
+       mr      r28, r1         /* out AP.  */
+       stwux   r1, r1, r4
+
+       /* Save arguments over call...  */
+       mr      r31, r5 /* flags, */
+       mr      r30, r6 /* rvalue, */
+       mr      r29, r7 /* function address, */
+       stw     r2, 20(r1)
+
+       /* Call ffi_prep_args.  */
+       mr      r4, r1
+       bl      .ffi_prep_args
+
+       /* Now do the call.  */
+       lwz     r0, 0(r29)
+       lwz     r2, 4(r29)
+       lwz     r11, 8(r29)
+       /* Set up cr1 with bits 4-7 of the flags.  */
+       mtcrf   0x40, r31
+       mtctr   r0
+       /* Load all those argument registers.  */
+       // We have set up a nice stack frame, just load it into registers.
+       lwz     r3, 20+(1*4)(r1)
+       lwz     r4, 20+(2*4)(r1)
+       lwz     r5, 20+(3*4)(r1)
+       lwz     r6, 20+(4*4)(r1)
+       nop
+       lwz     r7, 20+(5*4)(r1)
+       lwz     r8, 20+(6*4)(r1)
+       lwz     r9, 20+(7*4)(r1)
+       lwz     r10,20+(8*4)(r1)
+
+L1:
+       /* Load all the FP registers.  */
+       bf      6,L2 // 2f + 0x18
+       lfd     f1,-16-(13*8)(r28)
+       lfd     f2,-16-(12*8)(r28)
+       lfd     f3,-16-(11*8)(r28)
+       lfd     f4,-16-(10*8)(r28)
+       nop
+       lfd     f5,-16-(9*8)(r28)
+       lfd     f6,-16-(8*8)(r28)
+       lfd     f7,-16-(7*8)(r28)
+       lfd     f8,-16-(6*8)(r28)
+       nop
+       lfd     f9,-16-(5*8)(r28)
+       lfd     f10,-16-(4*8)(r28)
+       lfd     f11,-16-(3*8)(r28)
+       lfd     f12,-16-(2*8)(r28)
+       nop
+       lfd     f13,-16-(1*8)(r28)
+
+L2:
+       /* Make the call.  */
+       bctrl
+       lwz     r2, 20(r1)
+
+       /* Now, deal with the return value.  */
+       mtcrf   0x01, r31
+
+       bt      30, L(done_return_value)
+       bt      29, L(fp_return_value)
+       stw     r3, 0(r30)
+       bf      28, L(done_return_value)
+       stw     r4, 4(r30)
+
+       /* Fall through...  */
+
+L(done_return_value):
+       /* Restore the registers we used and return.  */
+       mr      r1, r28
+       lwz     r0, 8(r28)
+       lwz     r28,-16(r1)
+       mtlr    r0
+       lwz     r29,-12(r1)
+       lwz     r30, -8(r1)
+       lwz     r31, -4(r1)
+       blr
+
+L(fp_return_value):
+       bf      28, L(float_return_value)
+       stfd    f1, 0(r30)
+       b       L(done_return_value)
+L(float_return_value):
+       stfs    f1, 0(r30)
+       b       L(done_return_value)
+#endif
+       .long 0
+       .byte 0,0,0,1,128,4,0,0
+//END(ffi_call_AIX)
+
+.csect .text[PR]
+       .align 2
+       .globl ffi_call_DARWIN
+       .globl .ffi_call_DARWIN
+.csect ffi_call_DARWIN[DS]
+ffi_call_DARWIN:
+#ifdef __64BIT__
+       .llong .ffi_call_DARWIN, TOC[tc0], 0
+#else
+       .long .ffi_call_DARWIN, TOC[tc0], 0
+#endif
+       .csect .text[PR]
+.ffi_call_DARWIN:
+       blr
+       .long 0
+       .byte 0,0,0,0,0,0,0,0
+//END(ffi_call_DARWIN)
diff --git a/.pc/aix-ibm-xlc/src/powerpc/aix_closure.S b/.pc/aix-ibm-xlc/src/powerpc/aix_closure.S
new file mode 100644 (file)
index 0000000..5c74448
--- /dev/null
@@ -0,0 +1,443 @@
+/* -----------------------------------------------------------------------
+   aix_closure.S - Copyright (c) 2002, 2003, 2009 Free Software Foundation, Inc.
+   based on darwin_closure.S
+
+   PowerPC Assembly glue.
+
+   Permission is hereby granted, free of charge, to any person obtaining
+   a copy of this software and associated documentation files (the
+   ``Software''), to deal in the Software without restriction, including
+   without limitation the rights to use, copy, modify, merge, publish,
+   distribute, sublicense, and/or sell copies of the Software, and to
+   permit persons to whom the Software is furnished to do so, subject to
+   the following conditions:
+
+   The above copyright notice and this permission notice shall be included
+   in all copies or substantial portions of the Software.
+
+   THE SOFTWARE IS PROVIDED ``AS IS'', WITHOUT WARRANTY OF ANY KIND, EXPRESS
+   OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+   MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
+   IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR
+   OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+   ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+   OTHER DEALINGS IN THE SOFTWARE.
+   ----------------------------------------------------------------------- */
+
+       .set r0,0
+       .set r1,1
+       .set r2,2
+       .set r3,3
+       .set r4,4
+       .set r5,5
+       .set r6,6
+       .set r7,7
+       .set r8,8
+       .set r9,9
+       .set r10,10
+       .set r11,11
+       .set r12,12
+       .set r13,13
+       .set r14,14
+       .set r15,15
+       .set r16,16
+       .set r17,17
+       .set r18,18
+       .set r19,19
+       .set r20,20
+       .set r21,21
+       .set r22,22
+       .set r23,23
+       .set r24,24
+       .set r25,25
+       .set r26,26
+       .set r27,27
+       .set r28,28
+       .set r29,29
+       .set r30,30
+       .set r31,31
+       .set f0,0
+       .set f1,1
+       .set f2,2
+       .set f3,3
+       .set f4,4
+       .set f5,5
+       .set f6,6
+       .set f7,7
+       .set f8,8
+       .set f9,9
+       .set f10,10
+       .set f11,11
+       .set f12,12
+       .set f13,13
+       .set f14,14
+       .set f15,15
+       .set f16,16
+       .set f17,17
+       .set f18,18
+       .set f19,19
+       .set f20,20
+       .set f21,21
+
+#define LIBFFI_ASM
+#define JUMPTARGET(name) name
+#define L(x) x
+       .file "aix_closure.S"
+       .toc
+LC..60:
+       .tc L..60[TC],L..60
+       .csect .text[PR]
+       .align 2
+
+.csect .text[PR]
+       .align 2
+       .globl ffi_closure_ASM
+       .globl .ffi_closure_ASM
+.csect ffi_closure_ASM[DS]
+ffi_closure_ASM:
+#ifdef __64BIT__
+       .llong .ffi_closure_ASM, TOC[tc0], 0
+       .csect .text[PR]
+.ffi_closure_ASM:
+/* we want to build up an area for the parameters passed */
+/* in registers (both floating point and integer) */
+
+       /* we store gpr 3 to gpr 10 (aligned to 4)
+       in the parents outgoing area  */
+       std   r3, 48+(0*8)(r1)
+       std   r4, 48+(1*8)(r1)
+       std   r5, 48+(2*8)(r1)
+       std   r6, 48+(3*8)(r1)
+       mflr  r0
+
+       std   r7, 48+(4*8)(r1)
+       std   r8, 48+(5*8)(r1)
+       std   r9, 48+(6*8)(r1)
+       std   r10, 48+(7*8)(r1)
+       std   r0, 16(r1)        /* save the return address */
+
+
+       /* 48  Bytes (Linkage Area) */
+       /* 64  Bytes (params) */
+       /* 16  Bytes (result) */
+       /* 104 Bytes (13*8 from FPR) */
+       /* 8   Bytes (alignment) */
+       /* 240 Bytes */
+
+       stdu  r1, -240(r1)      /* skip over caller save area
+                                  keep stack aligned to 16  */
+
+       /* next save fpr 1 to fpr 13 (aligned to 8) */
+       stfd  f1, 128+(0*8)(r1)
+       stfd  f2, 128+(1*8)(r1)
+       stfd  f3, 128+(2*8)(r1)
+       stfd  f4, 128+(3*8)(r1)
+       stfd  f5, 128+(4*8)(r1)
+       stfd  f6, 128+(5*8)(r1)
+       stfd  f7, 128+(6*8)(r1)
+       stfd  f8, 128+(7*8)(r1)
+       stfd  f9, 128+(8*8)(r1)
+       stfd  f10, 128+(9*8)(r1)
+       stfd  f11, 128+(10*8)(r1)
+       stfd  f12, 128+(11*8)(r1)
+       stfd  f13, 128+(12*8)(r1)
+
+       /* set up registers for the routine that actually does the work */
+       /* get the context pointer from the trampoline */
+       mr r3, r11
+
+       /* now load up the pointer to the result storage */
+       addi r4, r1, 112
+
+       /* now load up the pointer to the saved gpr registers */
+       addi r5, r1, 288
+
+       /* now load up the pointer to the saved fpr registers */
+       addi r6, r1, 128
+
+       /* make the call */
+       bl .ffi_closure_helper_DARWIN
+       nop
+
+       /* now r3 contains the return type */
+       /* so use it to look up in a table */
+       /* so we know how to deal with each type */
+
+       /* look up the proper starting point in table  */
+       /* by using return type as offset */
+       ld      r4, LC..60(2)   /* get address of jump table */
+       sldi    r3, r3, 4       /* now multiply return type by 16 */
+       ld      r0, 240+16(r1)  /* load return address */
+       add     r3, r3, r4      /* add contents of table to table address */
+       mtctr   r3
+       bctr                    /* jump to it */
+
+/* Each fragment must be exactly 16 bytes long (4 instructions).
+   Align to 16 byte boundary for cache and dispatch efficiency.  */
+       .align 4
+
+L..60:
+/* case FFI_TYPE_VOID */
+       mtlr r0
+       addi r1, r1, 240
+       blr
+       nop
+
+/* case FFI_TYPE_INT */
+       lwa r3, 112+4(r1)
+       mtlr r0
+       addi r1, r1, 240
+       blr
+
+/* case FFI_TYPE_FLOAT */
+       lfs f1, 112+0(r1)
+       mtlr r0
+       addi r1, r1, 240
+       blr
+
+/* case FFI_TYPE_DOUBLE */
+       lfd f1, 112+0(r1)
+       mtlr r0
+       addi r1, r1, 240
+       blr
+
+/* case FFI_TYPE_LONGDOUBLE */
+       lfd f1, 112+0(r1)
+       mtlr r0
+       lfd f2, 112+8(r1)
+       b L..finish
+
+/* case FFI_TYPE_UINT8 */
+       lbz r3, 112+7(r1)
+       mtlr r0
+       addi r1, r1, 240
+       blr
+
+/* case FFI_TYPE_SINT8 */
+       lbz r3, 112+7(r1)
+       mtlr r0
+       extsb r3, r3
+       b L..finish
+
+/* case FFI_TYPE_UINT16 */
+       lhz r3, 112+6(r1)
+       mtlr r0
+L..finish:
+       addi r1, r1, 240
+       blr
+
+/* case FFI_TYPE_SINT16 */
+       lha r3, 112+6(r1)
+       mtlr r0
+       addi r1, r1, 240
+       blr
+
+/* case FFI_TYPE_UINT32 */
+       lwz r3, 112+4(r1)
+       mtlr r0
+       addi r1, r1, 240
+       blr
+
+/* case FFI_TYPE_SINT32 */
+       lwa r3, 112+4(r1)
+       mtlr r0
+       addi r1, r1, 240
+       blr
+
+/* case FFI_TYPE_UINT64 */
+       ld r3, 112+0(r1)
+       mtlr r0
+       addi r1, r1, 240
+       blr
+
+/* case FFI_TYPE_SINT64 */
+       ld r3, 112+0(r1)
+       mtlr r0
+       addi r1, r1, 240
+       blr
+
+/* case FFI_TYPE_STRUCT */
+       mtlr r0
+       addi r1, r1, 240
+       blr
+       nop
+
+/* case FFI_TYPE_POINTER */
+       ld r3, 112+0(r1)
+       mtlr r0
+       addi r1, r1, 240
+       blr
+
+#else /* ! __64BIT__ */
+       
+       .long .ffi_closure_ASM, TOC[tc0], 0
+       .csect .text[PR]
+.ffi_closure_ASM:
+/* we want to build up an area for the parameters passed */
+/* in registers (both floating point and integer) */
+
+       /* we store gpr 3 to gpr 10 (aligned to 4)
+       in the parents outgoing area  */
+       stw   r3, 24+(0*4)(r1)
+       stw   r4, 24+(1*4)(r1)
+       stw   r5, 24+(2*4)(r1)
+       stw   r6, 24+(3*4)(r1)
+       mflr  r0
+
+       stw   r7, 24+(4*4)(r1)
+       stw   r8, 24+(5*4)(r1)
+       stw   r9, 24+(6*4)(r1)
+       stw   r10, 24+(7*4)(r1)
+       stw   r0, 8(r1)
+
+       /* 24 Bytes (Linkage Area) */
+       /* 32 Bytes (params) */
+       /* 16  Bytes (result) */
+       /* 104 Bytes (13*8 from FPR) */
+       /* 176 Bytes */
+
+       stwu  r1, -176(r1)      /* skip over caller save area
+                                  keep stack aligned to 16  */
+
+       /* next save fpr 1 to fpr 13 (aligned to 8) */
+       stfd  f1, 72+(0*8)(r1)
+       stfd  f2, 72+(1*8)(r1)
+       stfd  f3, 72+(2*8)(r1)
+       stfd  f4, 72+(3*8)(r1)
+       stfd  f5, 72+(4*8)(r1)
+       stfd  f6, 72+(5*8)(r1)
+       stfd  f7, 72+(6*8)(r1)
+       stfd  f8, 72+(7*8)(r1)
+       stfd  f9, 72+(8*8)(r1)
+       stfd  f10, 72+(9*8)(r1)
+       stfd  f11, 72+(10*8)(r1)
+       stfd  f12, 72+(11*8)(r1)
+       stfd  f13, 72+(12*8)(r1)
+
+       /* set up registers for the routine that actually does the work */
+       /* get the context pointer from the trampoline */
+       mr r3, r11
+
+       /* now load up the pointer to the result storage */
+       addi r4, r1, 56
+
+       /* now load up the pointer to the saved gpr registers */
+       addi r5, r1, 200
+
+       /* now load up the pointer to the saved fpr registers */
+       addi r6, r1, 72
+
+       /* make the call */
+       bl .ffi_closure_helper_DARWIN
+       nop
+
+       /* now r3 contains the return type */
+       /* so use it to look up in a table */
+       /* so we know how to deal with each type */
+
+       /* look up the proper starting point in table  */
+       /* by using return type as offset */
+       lwz     r4, LC..60(2)   /* get address of jump table */
+       slwi    r3, r3, 4       /* now multiply return type by 4 */
+       lwz     r0, 176+8(r1)   /* load return address */
+       add     r3, r3, r4      /* add contents of table to table address */
+       mtctr   r3
+       bctr                    /* jump to it */
+
+/* Each fragment must be exactly 16 bytes long (4 instructions).
+   Align to 16 byte boundary for cache and dispatch efficiency.  */
+       .align 4
+
+L..60:
+/* case FFI_TYPE_VOID */
+       mtlr r0
+       addi r1, r1, 176
+       blr
+       nop
+
+/* case FFI_TYPE_INT */
+       lwz r3, 56+0(r1)
+       mtlr r0
+       addi r1, r1, 176
+       blr
+
+/* case FFI_TYPE_FLOAT */
+       lfs f1, 56+0(r1)
+       mtlr r0
+       addi r1, r1, 176
+       blr
+
+/* case FFI_TYPE_DOUBLE */
+       lfd f1, 56+0(r1)
+       mtlr r0
+       addi r1, r1, 176
+       blr
+
+/* case FFI_TYPE_LONGDOUBLE */
+       lfd f1, 56+0(r1)
+       mtlr r0
+       lfd f2, 56+8(r1)
+       b L..finish
+
+/* case FFI_TYPE_UINT8 */
+       lbz r3, 56+3(r1)
+       mtlr r0
+       addi r1, r1, 176
+       blr
+
+/* case FFI_TYPE_SINT8 */
+       lbz r3, 56+3(r1)
+       mtlr r0
+       extsb r3, r3
+       b L..finish
+
+/* case FFI_TYPE_UINT16 */
+       lhz r3, 56+2(r1)
+       mtlr r0
+       addi r1, r1, 176
+       blr
+
+/* case FFI_TYPE_SINT16 */
+       lha r3, 56+2(r1)
+       mtlr r0
+       addi r1, r1, 176
+       blr
+
+/* case FFI_TYPE_UINT32 */
+       lwz r3, 56+0(r1)
+       mtlr r0
+       addi r1, r1, 176
+       blr
+
+/* case FFI_TYPE_SINT32 */
+       lwz r3, 56+0(r1)
+       mtlr r0
+       addi r1, r1, 176
+       blr
+
+/* case FFI_TYPE_UINT64 */
+       lwz r3, 56+0(r1)
+       mtlr r0
+       lwz r4, 56+4(r1)
+       b L..finish
+
+/* case FFI_TYPE_SINT64 */
+       lwz r3, 56+0(r1)
+       mtlr r0
+       lwz r4, 56+4(r1)
+       b L..finish
+
+/* case FFI_TYPE_STRUCT */
+       mtlr r0
+       addi r1, r1, 176
+       blr
+       nop
+
+/* case FFI_TYPE_POINTER */
+       lwz r3, 56+0(r1)
+       mtlr r0
+L..finish:
+       addi r1, r1, 176
+       blr
+#endif
+/* END(ffi_closure_ASM) */
index 06f43b4..e084246 100644 (file)
@@ -1,3 +1,12 @@
+2011-02-11  Anthony Green  <green@moxielogic.com>
+
+       From Tom Honermann <tom.honermann@oracle.com>:
+       * src/powerpc/aix.S (ffi_call_AIX): Support for xlc toolchain on
+       AIX.  Declare .ffi_prep_args.  Insert nops after branch
+       instructions so that the AIX linker can insert TOC reload
+       instructions.
+       * src/powerpc/aix_closure.S: Declare .ffi_closure_helper_DARWIN.
+
 2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
 
        * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
index 92d896c..cc4e49f 100644 (file)
 
        * src/powerpc/asm.h: Fix grammar nit in comment.
 
+2011-02-11  Anthony Green  <green@moxielogic.com>
+
+       From Tom Honermann <tom.honermann@oracle.com>:
+       * src/powerpc/aix.S (ffi_call_AIX): Support for xlc toolchain on
+       AIX.  Declare .ffi_prep_args.  Insert nops after branch
+       instructions so that the AIX linker can insert TOC reload
+       instructions.
+       * src/powerpc/aix_closure.S: Declare .ffi_closure_helper_DARWIN.
+
 2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
 
        * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
index abb3be9..2eed7cf 100644 (file)
@@ -7,6 +7,15 @@
 
        * src/powerpc/asm.h: Fix grammar nit in comment.
 
+2011-02-11  Anthony Green  <green@moxielogic.com>
+
+       From Tom Honermann <tom.honermann@oracle.com>:
+       * src/powerpc/aix.S (ffi_call_AIX): Support for xlc toolchain on
+       AIX.  Declare .ffi_prep_args.  Insert nops after branch
+       instructions so that the AIX linker can insert TOC reload
+       instructions.
+       * src/powerpc/aix_closure.S: Declare .ffi_closure_helper_DARWIN.
+
 2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
 
        * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
index c3de5e5..3a18564 100644 (file)
 
        * src/powerpc/asm.h: Fix grammar nit in comment.
 
+2011-02-11  Anthony Green  <green@moxielogic.com>
+
+       From Tom Honermann <tom.honermann@oracle.com>:
+       * src/powerpc/aix.S (ffi_call_AIX): Support for xlc toolchain on
+       AIX.  Declare .ffi_prep_args.  Insert nops after branch
+       instructions so that the AIX linker can insert TOC reload
+       instructions.
+       * src/powerpc/aix_closure.S: Declare .ffi_closure_helper_DARWIN.
+
 2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
 
        * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
index 46b65aa..480d625 100644 (file)
 
        * src/powerpc/asm.h: Fix grammar nit in comment.
 
+2011-02-11  Anthony Green  <green@moxielogic.com>
+
+       From Tom Honermann <tom.honermann@oracle.com>:
+       * src/powerpc/aix.S (ffi_call_AIX): Support for xlc toolchain on
+       AIX.  Declare .ffi_prep_args.  Insert nops after branch
+       instructions so that the AIX linker can insert TOC reload
+       instructions.
+       * src/powerpc/aix_closure.S: Declare .ffi_closure_helper_DARWIN.
+
 2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
 
        * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
index f3df0e6..c974316 100644 (file)
 
        * src/powerpc/asm.h: Fix grammar nit in comment.
 
+2011-02-11  Anthony Green  <green@moxielogic.com>
+
+       From Tom Honermann <tom.honermann@oracle.com>:
+       * src/powerpc/aix.S (ffi_call_AIX): Support for xlc toolchain on
+       AIX.  Declare .ffi_prep_args.  Insert nops after branch
+       instructions so that the AIX linker can insert TOC reload
+       instructions.
+       * src/powerpc/aix_closure.S: Declare .ffi_closure_helper_DARWIN.
+
 2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
 
        * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
index 853c1fb..05d6c42 100644 (file)
 
        * src/powerpc/asm.h: Fix grammar nit in comment.
 
+2011-02-11  Anthony Green  <green@moxielogic.com>
+
+       From Tom Honermann <tom.honermann@oracle.com>:
+       * src/powerpc/aix.S (ffi_call_AIX): Support for xlc toolchain on
+       AIX.  Declare .ffi_prep_args.  Insert nops after branch
+       instructions so that the AIX linker can insert TOC reload
+       instructions.
+       * src/powerpc/aix_closure.S: Declare .ffi_closure_helper_DARWIN.
+
 2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
 
        * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
index 4ef7ee6..4b5511e 100644 (file)
 
        * src/powerpc/asm.h: Fix grammar nit in comment.
 
+2011-02-11  Anthony Green  <green@moxielogic.com>
+
+       From Tom Honermann <tom.honermann@oracle.com>:
+       * src/powerpc/aix.S (ffi_call_AIX): Support for xlc toolchain on
+       AIX.  Declare .ffi_prep_args.  Insert nops after branch
+       instructions so that the AIX linker can insert TOC reload
+       instructions.
+       * src/powerpc/aix_closure.S: Declare .ffi_closure_helper_DARWIN.
+
 2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
 
        * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
index 801315f..36f506c 100644 (file)
@@ -2,6 +2,15 @@
 
        * src/powerpc/asm.h: Fix grammar nit in comment.
 
+2011-02-11  Anthony Green  <green@moxielogic.com>
+
+       From Tom Honermann <tom.honermann@oracle.com>:
+       * src/powerpc/aix.S (ffi_call_AIX): Support for xlc toolchain on
+       AIX.  Declare .ffi_prep_args.  Insert nops after branch
+       instructions so that the AIX linker can insert TOC reload
+       instructions.
+       * src/powerpc/aix_closure.S: Declare .ffi_closure_helper_DARWIN.
+
 2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
 
        * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
index fe22904..142950d 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
 
        * src/powerpc/asm.h: Fix grammar nit in comment.
 
+2011-02-11  Anthony Green  <green@moxielogic.com>
+
+       From Tom Honermann <tom.honermann@oracle.com>:
+       * src/powerpc/aix.S (ffi_call_AIX): Support for xlc toolchain on
+       AIX.  Declare .ffi_prep_args.  Insert nops after branch
+       instructions so that the AIX linker can insert TOC reload
+       instructions.
+       * src/powerpc/aix_closure.S: Declare .ffi_closure_helper_DARWIN.
+
 2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
 
        * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
index 19f4973..14e70a8 100644 (file)
@@ -2,7 +2,16 @@ Index: libffi/ChangeLog
 ===================================================================
 --- libffi.orig/ChangeLog
 +++ libffi/ChangeLog
-@@ -1,3 +1,7 @@
+@@ -1,3 +1,16 @@
++2011-02-11  Anthony Green  <green@moxielogic.com>
++
++      From Tom Honermann <tom.honermann@oracle.com>:
++      * src/powerpc/aix.S (ffi_call_AIX): Support for xlc toolchain on
++      AIX.  Declare .ffi_prep_args.  Insert nops after branch
++      instructions so that the AIX linker can insert TOC reload
++      instructions.
++      * src/powerpc/aix_closure.S: Declare .ffi_closure_helper_DARWIN.
++
 +2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
 +
 +      * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
@@ -98,3 +107,52 @@ Index: libffi/include/ffi.h.in
  #  define FFI_SIZEOF_ARG        8
  # endif
  #endif
+Index: libffi/src/powerpc/aix.S
+===================================================================
+--- libffi.orig/src/powerpc/aix.S
++++ libffi/src/powerpc/aix.S
+@@ -1,5 +1,5 @@
+ /* -----------------------------------------------------------------------
+-   aix.S - Copyright (c) 2002,2009 Free Software Foundation, Inc.
++   aix.S - Copyright (c) 2002, 2009 Free Software Foundation, Inc.
+    based on darwin.S by John Hornkvist
+    PowerPC Assembly glue.
+@@ -79,6 +79,8 @@
+       .set f20,20
+       .set f21,21
++      .extern .ffi_prep_args
++
+ #define LIBFFI_ASM
+ #include <fficonfig.h>
+ #include <ffi.h>
+@@ -125,6 +127,7 @@ ffi_call_AIX:
+       /* Call ffi_prep_args.  */
+       mr      r4, r1
+       bl      .ffi_prep_args
++      nop
+       /* Now do the call.  */
+       ld      r0, 0(r29)
+@@ -226,6 +229,7 @@ L(float_return_value):
+       /* Call ffi_prep_args.  */
+       mr      r4, r1
+       bl      .ffi_prep_args
++      nop
+       /* Now do the call.  */
+       lwz     r0, 0(r29)
+Index: libffi/src/powerpc/aix_closure.S
+===================================================================
+--- libffi.orig/src/powerpc/aix_closure.S
++++ libffi/src/powerpc/aix_closure.S
+@@ -79,6 +79,8 @@
+       .set f20,20
+       .set f21,21
++      .extern .ffi_closure_helper_DARWIN
++
+ #define LIBFFI_ASM
+ #define JUMPTARGET(name) name
+ #define L(x) x
index 1602632..0785f19 100644 (file)
@@ -20,6 +20,6 @@ Index: libffi/ChangeLog
 +
 +      * src/powerpc/asm.h: Fix grammar nit in comment.
 +
- 2011-02-08  Uli Link  <ul.mcamafia@linkitup.de>
+ 2011-02-11  Anthony Green  <green@moxielogic.com>
  
-       * include/ffi.h.in (FFI_64_BIT_MAX): Define and use.
+       From Tom Honermann <tom.honermann@oracle.com>:
index c6f8764..213f2db 100644 (file)
@@ -1,5 +1,5 @@
 /* -----------------------------------------------------------------------
-   aix.S - Copyright (c) 2002,2009 Free Software Foundation, Inc.
+   aix.S - Copyright (c) 2002, 2009 Free Software Foundation, Inc.
    based on darwin.S by John Hornkvist
 
    PowerPC Assembly glue.
@@ -79,6 +79,8 @@
        .set f20,20
        .set f21,21
 
+       .extern .ffi_prep_args
+
 #define LIBFFI_ASM
 #include <fficonfig.h>
 #include <ffi.h>
@@ -125,6 +127,7 @@ ffi_call_AIX:
        /* Call ffi_prep_args.  */
        mr      r4, r1
        bl      .ffi_prep_args
+       nop
 
        /* Now do the call.  */
        ld      r0, 0(r29)
@@ -226,6 +229,7 @@ L(float_return_value):
        /* Call ffi_prep_args.  */
        mr      r4, r1
        bl      .ffi_prep_args
+       nop
 
        /* Now do the call.  */
        lwz     r0, 0(r29)
index 5c74448..c906017 100644 (file)
@@ -79,6 +79,8 @@
        .set f20,20
        .set f21,21
 
+       .extern .ffi_closure_helper_DARWIN
+
 #define LIBFFI_ASM
 #define JUMPTARGET(name) name
 #define L(x) x