olga / rpms / glibc

Forked from rpms/glibc 5 years ago
Clone
00db10
# commit 7b88401f3b25325b1381798a0eccb3efe7751fec
00db10
# Author: Alan Modra <amodra@gmail.com>
00db10
# Date:   Sat Aug 17 18:31:45 2013 +0930
00db10
# 
00db10
#     PowerPC floating point little-endian [12 of 15]
00db10
#     http://sourceware.org/ml/libc-alpha/2013-08/msg00087.html
00db10
#     
00db10
#     Fixes for little-endian in 32-bit assembly.
00db10
#     
00db10
#         * sysdeps/powerpc/sysdep.h (LOWORD, HIWORD, HISHORT): Define.
00db10
#         * sysdeps/powerpc/powerpc32/fpu/s_copysign.S: Load little-endian
00db10
#         words of double from correct stack offsets.
00db10
#         * sysdeps/powerpc/powerpc32/fpu/s_copysignl.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/fpu/s_lrint.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/fpu/s_lround.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power4/fpu/s_llrint.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power4/fpu/s_llrintf.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power5+/fpu/s_llround.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power5+/fpu/s_lround.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power5/fpu/s_isnan.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power6/fpu/s_isnan.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power6/fpu/s_llrint.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power6/fpu/s_llrintf.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power6/fpu/s_llround.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power7/fpu/s_finite.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power7/fpu/s_isinf.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc32/power7/fpu/s_isnan.S: Likewise.
00db10
#         * sysdeps/powerpc/powerpc64/power7/fpu/s_finite.S: Use HISHORT.
00db10
#         * sysdeps/powerpc/powerpc64/power7/fpu/s_isinf.S: Likewise.
00db10
# 
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_copysign.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_copysign.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_copysign.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_copysign.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -29,7 +29,7 @@
00db10
 	stwu	r1,-16(r1)
00db10
 	cfi_adjust_cfa_offset (16)
00db10
 	stfd	fp2,8(r1)
00db10
-	lwz	r3,8(r1)
00db10
+	lwz	r3,8+HIWORD(r1)
00db10
 	cmpwi   r3,0
00db10
 	addi    r1,r1,16
00db10
 	cfi_adjust_cfa_offset (-16)
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_copysignl.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_copysignl.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_copysignl.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_copysignl.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -30,7 +30,7 @@
00db10
 	fmr	fp0,fp1
00db10
 	fabs	fp1,fp1
00db10
 	fcmpu	cr7,fp0,fp1
00db10
-	lwz	r3,8(r1)
00db10
+	lwz	r3,8+HIWORD(r1)
00db10
 	cmpwi	cr6,r3,0
00db10
 	addi	r1,r1,16
00db10
 	cfi_adjust_cfa_offset (-16)
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_lrint.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_lrint.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_lrint.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_lrint.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -24,10 +24,10 @@
00db10
 	stwu	r1,-16(r1)
00db10
 	fctiw	fp13,fp1
00db10
 	stfd	fp13,8(r1)
00db10
-	nop	/* Insure the following load is in a different dispatch group */
00db10
+	nop	/* Ensure the following load is in a different dispatch group */
00db10
 	nop	/* to avoid pipe stall on POWER4&5.  */
00db10
 	nop
00db10
-	lwz	r3,12(r1)
00db10
+	lwz	r3,8+LOWORD(r1)
00db10
 	addi	r1,r1,16
00db10
 	blr
00db10
 	END (__lrint)
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_lround.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_lround.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_lround.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/fpu/s_lround.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -67,7 +67,7 @@
00db10
 	nop	/* Ensure the following load is in a different dispatch  */
00db10
 	nop	/* group to avoid pipe stall on POWER4&5.  */
00db10
 	nop
00db10
-	lwz	r3,12(r1)	/* Load return as integer.  */
00db10
+	lwz	r3,8+LOWORD(r1)	/* Load return as integer.  */
00db10
 .Lout:
00db10
 	addi	r1,r1,16
00db10
 	blr
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power4/fpu/s_llrint.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power4/fpu/s_llrint.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power4/fpu/s_llrint.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power4/fpu/s_llrint.S	2014-05-27 22:48:09.000000000 -0500
00db10
@@ -29,8 +29,8 @@
00db10
 	nop	/* Insure the following load is in a different dispatch group */
00db10
 	nop	/* to avoid pipe stall on POWER4&5.  */
00db10
 	nop
00db10
-	lwz	r3,8(r1)
00db10
-	lwz	r4,12(r1)
00db10
+	lwz	r3,8+HIWORD(r1)
00db10
+	lwz	r4,8+LOWORD(r1)
00db10
 	addi	r1,r1,16	
00db10
 	blr
00db10
 	END (__llrint)
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power4/fpu/s_llrintf.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power4/fpu/s_llrintf.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power4/fpu/s_llrintf.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power4/fpu/s_llrintf.S	2014-05-27 22:48:44.000000000 -0500
00db10
@@ -28,8 +28,8 @@
00db10
 	nop	/* Insure the following load is in a different dispatch group */
00db10
 	nop	/* to avoid pipe stall on POWER4&5.  */
00db10
 	nop
00db10
-	lwz	r3,8(r1)
00db10
-	lwz	r4,12(r1)
00db10
+	lwz	r3,8+HIWORD(r1)
00db10
+	lwz	r4,8+LOWORD(r1)
00db10
 	addi	r1,r1,16	
00db10
 	blr
00db10
 	END (__llrintf)
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5/fpu/s_isnan.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5/fpu/s_isnan.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5/fpu/s_isnan.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5/fpu/s_isnan.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -27,8 +27,8 @@
00db10
 	ori	r1,r1,0
00db10
 	stfd	fp1,24(r1)	/* copy FPR to GPR */
00db10
 	ori	r1,r1,0
00db10
-	lwz	r4,24(r1)
00db10
-	lwz	r5,28(r1)
00db10
+	lwz	r4,24+HIWORD(r1)
00db10
+	lwz	r5,24+LOWORD(r1)
00db10
 	lis	r0,0x7ff0	/* const long r0 0x7ff00000 00000000 */
00db10
 	clrlwi	r4,r4,1		/* x = fabs(x) */
00db10
 	cmpw	cr7,r4,r0	/* if (fabs(x) =< inf) */
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5+/fpu/s_llround.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5+/fpu/s_llround.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5+/fpu/s_llround.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5+/fpu/s_llround.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -39,8 +39,8 @@
00db10
 	nop	/* Ensure the following load is in a different dispatch  */
00db10
 	nop	/* group to avoid pipe stall on POWER4&5.  */
00db10
 	nop
00db10
-	lwz	r4,12(r1)
00db10
-	lwz	r3,8(r1)
00db10
+	lwz	r3,8+HIWORD(r1)
00db10
+	lwz	r4,8+LOWORD(r1)
00db10
 	addi	r1,r1,16
00db10
 	blr
00db10
 	END (__llround)
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5+/fpu/s_lround.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5+/fpu/s_lround.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5+/fpu/s_lround.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power5+/fpu/s_lround.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -38,7 +38,7 @@
00db10
 	nop	/* Ensure the following load is in a different dispatch  */
00db10
 	nop	/* group to avoid pipe stall on POWER4&5.  */
00db10
 	nop
00db10
-	lwz	r3,12(r1)
00db10
+	lwz	r3,8+LOWORD(r1)
00db10
 	addi	r1,r1,16
00db10
 	blr
00db10
 	END (__lround)
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_isnan.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_isnan.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_isnan.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_isnan.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -27,8 +27,8 @@
00db10
 	ori	r1,r1,0
00db10
 	stfd	fp1,24(r1)	/* copy FPR to GPR */
00db10
 	ori	r1,r1,0
00db10
-	lwz	r4,24(r1)
00db10
-	lwz	r5,28(r1)
00db10
+	lwz	r4,24+HIWORD(r1)
00db10
+	lwz	r5,24+LOWORD(r1)
00db10
 	lis	r0,0x7ff0	/* const long r0 0x7ff00000 00000000 */
00db10
 	clrlwi	r4,r4,1		/* x = fabs(x) */
00db10
 	cmpw	cr7,r4,r0	/* if (fabs(x) =< inf) */
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llrint.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llrint.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llrint.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llrint.S	2014-05-27 22:46:52.000000000 -0500
00db10
@@ -29,8 +29,8 @@
00db10
 /* Insure the following load is in a different dispatch group by
00db10
    inserting "group ending nop".  */
00db10
 	ori	r1,r1,0
00db10
-	lwz	r3,8(r1)
00db10
-	lwz	r4,12(r1)
00db10
+	lwz	r3,8+HIWORD(r1)
00db10
+	lwz	r4,8+LOWORD(r1)
00db10
 	addi	r1,r1,16	
00db10
 	blr
00db10
 	END (__llrint)
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llrintf.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llrintf.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llrintf.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llrintf.S	2014-05-27 22:47:29.000000000 -0500
00db10
@@ -28,8 +28,8 @@
00db10
 /* Insure the following load is in a different dispatch group by
00db10
    inserting "group ending nop".  */
00db10
 	ori	r1,r1,0
00db10
-	lwz	r3,8(r1)
00db10
-	lwz	r4,12(r1)
00db10
+	lwz	r3,8+HIWORD(r1)
00db10
+	lwz	r4,8+LOWORD(r1)
00db10
 	addi	r1,r1,16	
00db10
 	blr
00db10
 	END (__llrintf)
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llround.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llround.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llround.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/fpu/s_llround.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -39,8 +39,8 @@
00db10
 /* Insure the following load is in a different dispatch group by
00db10
    inserting "group ending nop".  */
00db10
 	ori	r1,r1,0
00db10
-	lwz	r4,12(r1)
00db10
-	lwz	r3,8(r1)
00db10
+	lwz	r3,8+HIWORD(r1)
00db10
+	lwz	r4,8+LOWORD(r1)
00db10
 	addi	r1,r1,16
00db10
 	blr
00db10
 	END (__llround)
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_finite.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_finite.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_finite.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_finite.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -54,9 +54,8 @@
00db10
 	stfd    fp1,8(r1)     /* Transfer FP to GPR's.  */
00db10
 
00db10
 	ori	2,2,0	      /* Force a new dispatch group.  */
00db10
-	lhz     r0,8(r1)      /* Fetch the upper portion of the high word of
00db10
-			      the FP value (where the exponent and sign bits
00db10
-			      are).  */
00db10
+	lhz	r0,8+HISHORT(r1) /* Fetch the upper 16 bits of the FP value
00db10
+				    (biased exponent and sign bit).  */
00db10
 	clrlwi	r0,r0,17      /* r0 = abs(r0).  */
00db10
 	addi	r1,r1,16      /* Reset the stack pointer.  */
00db10
 	cmpwi	cr7,r0,0x7ff0 /* r4 == 0x7ff0?.  */
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_isinf.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_isinf.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_isinf.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_isinf.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -48,14 +48,13 @@
00db10
 	li	r3,0
00db10
 	bflr    29	      /* If not INF, return.  */
00db10
 
00db10
-	/* Either we have -INF/+INF or a denormal.  */
00db10
+	/* Either we have +INF or -INF.  */
00db10
 
00db10
 	stwu    r1,-16(r1)    /* Allocate stack space.  */
00db10
 	stfd    fp1,8(r1)     /* Transfer FP to GPR's.  */
00db10
 	ori	2,2,0	      /* Force a new dispatch group.  */
00db10
-	lhz	r4,8(r1)      /* Fetch the upper portion of the high word of
00db10
-			      the FP value (where the exponent and sign bits
00db10
-			      are).  */
00db10
+	lhz	r4,8+HISHORT(r1) /* Fetch the upper 16 bits of the FP value
00db10
+				    (biased exponent and sign bit).  */
00db10
 	addi	r1,r1,16      /* Reset the stack pointer.  */
00db10
 	cmpwi	cr7,r4,0x7ff0 /* r4 == 0x7ff0?  */
00db10
 	li	r3,1
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_isnan.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_isnan.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_isnan.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/fpu/s_isnan.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -53,8 +53,8 @@
00db10
 	stwu	r1,-16(r1)    /* Allocate stack space.  */
00db10
 	stfd	fp1,8(r1)     /* Transfer FP to GPR's.  */
00db10
 	ori	2,2,0	      /* Force a new dispatch group.  */
00db10
-	lwz     r4,8(r1)      /* Load the upper half of the FP value.  */
00db10
-	lwz     r5,12(r1)     /* Load the lower half of the FP value.  */
00db10
+	lwz     r4,8+HIWORD(r1) /* Load the upper half of the FP value.  */
00db10
+	lwz     r5,8+LOWORD(r1) /* Load the lower half of the FP value.  */
00db10
 	addi	r1,r1,16      /* Reset the stack pointer.  */
00db10
 	lis     r0,0x7ff0     /* Load the upper portion for an INF/NaN.  */
00db10
 	clrlwi  r4,r4,1	      /* r4 = abs(r4).  */
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc64/power7/fpu/s_finite.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc64/power7/fpu/s_finite.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc64/power7/fpu/s_finite.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc64/power7/fpu/s_finite.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -39,10 +39,8 @@
00db10
 
00db10
 	stfd    fp1,-16(r1)   /* Transfer FP to GPR's.  */
00db10
 	ori	2,2,0	      /* Force a new dispatch group.  */
00db10
-
00db10
-	lhz     r4,-16(r1)    /* Fetch the upper portion of the high word of
00db10
-			      the FP value (where the exponent and sign bits
00db10
-			      are).  */
00db10
+	lhz     r4,-16+HISHORT(r1)  /* Fetch the upper 16 bits of the FP value
00db10
+				    (biased exponent and sign bit).  */
00db10
 	clrlwi  r4,r4,17      /* r4 = abs(r4).  */
00db10
 	cmpwi   cr7,r4,0x7ff0 /* r4 == 0x7ff0?  */
00db10
 	bltlr   cr7	      /* LT means finite, other non-finite.  */
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/powerpc64/power7/fpu/s_isinf.S glibc-2.17-c758a686/sysdeps/powerpc/powerpc64/power7/fpu/s_isinf.S
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/powerpc64/power7/fpu/s_isinf.S	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc64/power7/fpu/s_isinf.S	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -38,9 +38,8 @@
00db10
 
00db10
 	stfd    fp1,-16(r1)   /* Transfer FP to GPR's.  */
00db10
 	ori	2,2,0	      /* Force a new dispatch group.  */
00db10
-	lhz	r4,-16(r1)    /* Fetch the upper portion of the high word of
00db10
-			      the FP value (where the exponent and sign bits
00db10
-			      are).  */
00db10
+	lhz	r4,-16+HISHORT(r1)  /* Fetch the upper 16 bits of the FP value
00db10
+				    (biased exponent and sign bit).  */
00db10
 	cmpwi	cr7,r4,0x7ff0 /* r4 == 0x7ff0?  */
00db10
 	li	r3,1
00db10
 	beqlr   cr7	      /* EQ means INF, otherwise -INF.  */
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/sysdep.h glibc-2.17-c758a686/sysdeps/powerpc/sysdep.h
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/sysdep.h	2014-05-27 22:45:44.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/sysdep.h	2014-05-27 22:45:46.000000000 -0500
00db10
@@ -144,6 +144,21 @@
00db10
 
00db10
 #define VRSAVE	256
00db10
 
00db10
+/* The 32-bit words of a 64-bit dword are at these offsets in memory.  */
00db10
+#if defined __LITTLE_ENDIAN__ || defined _LITTLE_ENDIAN
00db10
+# define LOWORD 0
00db10
+# define HIWORD 4
00db10
+#else
00db10
+# define LOWORD 4
00db10
+# define HIWORD 0
00db10
+#endif
00db10
+
00db10
+/* The high 16-bit word of a 64-bit dword is at this offset in memory.  */
00db10
+#if defined __LITTLE_ENDIAN__ || defined _LITTLE_ENDIAN
00db10
+# define HISHORT 6
00db10
+#else
00db10
+# define HISHORT 0
00db10
+#endif
00db10
 
00db10
 /* This seems to always be the case on PPC.  */
00db10
 #define ALIGNARG(log2) log2