yann@1328: diff -ru eglibc-2_9_orig/sysdeps/powerpc/powerpc32/memset.S eglibc-2_9/sysdeps/powerpc/powerpc32/memset.S yann@1328: --- eglibc-2_9_orig/sysdeps/powerpc/powerpc32/memset.S 2007-04-13 08:35:45.000000000 -0700 yann@1328: +++ eglibc-2_9/sysdeps/powerpc/powerpc32/memset.S 2009-05-06 16:52:04.000000000 -0700 yann@1328: @@ -112,11 +112,13 @@ yann@1328: clrrwi. rALIGN, rLEN, 5 yann@1328: mtcrf 0x01, rLEN /* 40th instruction from .align */ yann@1328: yann@1328: +#ifndef BROKEN_PPC_8xx_CPU15 yann@1328: /* Check if we can use the special case for clearing memory using dcbz. yann@1328: This requires that we know the correct cache line size for this yann@1328: processor. Getting the __cache_line_size may require establishing GOT yann@1328: addressability, so branch out of line to set this up. */ yann@1328: beq cr1, L(checklinesize) yann@1328: +#endif yann@1328: yann@1328: /* Store blocks of 32-bytes (256-bits) starting on a 32-byte boundary. yann@1328: Can't assume that rCHR is zero or that the cache line size is either yann@1328: @@ -158,6 +160,7 @@ yann@1328: add rMEMP, rMEMP, rALIGN yann@1328: b L(medium_tail2) /* 72nd instruction from .align */ yann@1328: yann@1328: +#ifndef BROKEN_PPC_8xx_CPU15 yann@1328: .align 5 yann@1328: nop yann@1328: /* Clear cache lines of memory in 128-byte chunks. yann@1328: @@ -191,6 +194,7 @@ yann@1328: bdnz L(zloop) yann@1328: beqlr cr5 yann@1328: b L(medium_tail2) yann@1328: +#endif /* ! BROKEN_PPC_8xx_CPU15 */ yann@1328: yann@1328: .align 5 yann@1328: L(small): yann@1328: @@ -248,6 +252,7 @@ yann@1328: stw rCHR, -8(rMEMP) yann@1328: blr yann@1328: yann@1328: +#ifndef BROKEN_PPC_8xx_CPU15 yann@1328: L(checklinesize): yann@1328: #ifdef SHARED yann@1328: mflr rTMP yann@1328: @@ -329,6 +334,7 @@ yann@1328: L(handletail32): yann@1328: clrrwi. rALIGN, rLEN, 5 yann@1328: b L(nondcbz) yann@1328: +#endif /* ! BROKEN_PPC_8xx_CPU15 */ yann@1328: yann@1328: END (BP_SYM (memset)) yann@1328: libc_hidden_builtin_def (memset)