00db10
commit d298c41635ce7f2dc7c3eccc842fe3aa754c0c8e
00db10
Author: Adhemerval Zanella <azanella@linux.vnet.ibm.com>
00db10
Date:   Thu May 22 14:48:38 2014 -0500
00db10
00db10
    PowerPC: Remove 64 bits instructions in PPC32 code
00db10
    
00db10
    This patch replaces the insrdi by insrwi in powerpc32 assembly.
00db10
00db10
Index: glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power4/memset.S
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/sysdeps/powerpc/powerpc32/power4/memset.S
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power4/memset.S
00db10
@@ -52,7 +52,7 @@ L(_memset):
00db10
 
00db10
 /* Align to word boundary.  */
00db10
 	cmplwi	cr5, rLEN, 31
00db10
-	insrdi	rCHR, rCHR, 8, 48     /* Replicate byte to halfword.  */
00db10
+	insrwi	rCHR, rCHR, 8, 16     /* Replicate byte to halfword.  */
00db10
 	beq+	L(aligned)
00db10
 	mtcrf	0x01, rMEMP0
00db10
 	subfic	rALIGN, rALIGN, 4
00db10
@@ -67,7 +67,7 @@ L(g0):
00db10
 /* Handle the case of size < 31.  */
00db10
 L(aligned):
00db10
 	mtcrf	0x01, rLEN
00db10
-	insrdi	rCHR, rCHR, 16, 32    /* Replicate halfword to word.  */
00db10
+	insrwi	rCHR, rCHR, 16, 0    /* Replicate halfword to word.  */
00db10
 	ble	cr5, L(medium)
00db10
 /* Align to 32-byte boundary.  */
00db10
 	andi.	rALIGN, rMEMP, 0x1C
00db10
Index: glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/memset.S
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/sysdeps/powerpc/powerpc32/power6/memset.S
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power6/memset.S
00db10
@@ -50,7 +50,7 @@ L(_memset):
00db10
 	ble-	cr1, L(small)
00db10
 /* Align to word boundary.  */
00db10
 	cmplwi	cr5, rLEN, 31
00db10
-	insrdi	rCHR, rCHR, 8, 48	/* Replicate byte to halfword.  */
00db10
+	insrwi	rCHR, rCHR, 8, 16	/* Replicate byte to halfword.  */
00db10
 	beq+	L(aligned)
00db10
 	mtcrf	0x01, rMEMP0
00db10
 	subfic	rALIGN, rALIGN, 4
00db10
@@ -66,7 +66,7 @@ L(g0):
00db10
 /* Handle the case of size < 31.  */
00db10
 L(aligned):
00db10
 	mtcrf	0x01, rLEN
00db10
-	insrdi	rCHR, rCHR, 16, 32	/* Replicate halfword to word.  */
00db10
+	insrwi	rCHR, rCHR, 16, 0	/* Replicate halfword to word.  */
00db10
 	ble	cr5, L(medium)
00db10
 /* Align to 32-byte boundary.  */
00db10
 	andi.	rALIGN, rMEMP, 0x1C
00db10
Index: glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/memset.S
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/sysdeps/powerpc/powerpc32/power7/memset.S
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/memset.S
00db10
@@ -37,8 +37,8 @@ L(_memset):
00db10
 	cfi_offset(31,-8)
00db10
 
00db10
 	/* Replicate byte to word.  */
00db10
-	insrdi	4,4,8,48
00db10
-	insrdi	4,4,16,32
00db10
+	insrwi	4,4,8,16
00db10
+	insrwi	4,4,16,0
00db10
 
00db10
 	ble	cr6,L(small)	/* If length <= 8, use short copy code.  */
00db10
 
00db10
Index: glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/rawmemchr.S
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/sysdeps/powerpc/powerpc32/power7/rawmemchr.S
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/rawmemchr.S
00db10
@@ -29,8 +29,8 @@ ENTRY (BP_SYM(__rawmemchr))
00db10
 	clrrwi	r8,r3,2	      /* Align the address to word boundary.  */
00db10
 
00db10
 	/* Replicate byte to word.  */
00db10
-	rldimi	r4,r4,8,48
00db10
-	rldimi	r4,r4,16,32
00db10
+	insrwi	r4,r4,8,16
00db10
+	insrwi	r4,r4,16,0
00db10
 
00db10
 	/* Now r4 has a word of c bytes.  */
00db10
 
00db10
Index: glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/strchr.S
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/sysdeps/powerpc/powerpc32/power7/strchr.S
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/strchr.S
00db10
@@ -37,8 +37,8 @@ ENTRY (BP_SYM(strchr))
00db10
 	beq	cr7,L(null_match)
00db10
 
00db10
 	/* Replicate byte to word.  */
00db10
-	insrdi	r4,r4,8,48
00db10
-	insrdi	r4,r4,16,32
00db10
+	insrwi	r4,r4,8,16
00db10
+	insrwi	r4,r4,16,0
00db10
 
00db10
 	/* Now r4 has a word of c bytes and r0 has
00db10
 	   a word of null bytes.  */
00db10
Index: glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/strchrnul.S
00db10
===================================================================
00db10
--- glibc-2.17-c758a686.orig/sysdeps/powerpc/powerpc32/power7/strchrnul.S
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/powerpc32/power7/strchrnul.S
00db10
@@ -29,8 +29,8 @@ ENTRY (BP_SYM(__strchrnul))
00db10
 	clrrwi	r8,r3,2	      /* Align the address to word boundary.  */
00db10
 
00db10
 	/* Replicate byte to word.  */
00db10
-	insrdi	r4,r4,8,48
00db10
-	insrdi	r4,r4,16,32
00db10
+	insrwi  r4,r4,8,16
00db10
+	insrwi  r4,r4,16,0
00db10
 
00db10
 	rlwinm	r6,r3,3,27,28 /* Calculate padding.  */
00db10
 	lwz	r12,0(r8)     /* Load word from memory.  */