This is the mail archive of the crossgcc@sourceware.org mailing list for the crossgcc project.
See the CrossGCC FAQ for lots more information.
Index Nav: | [Date Index] [Subject Index] [Author Index] [Thread Index] | |
---|---|---|
Message Nav: | [Date Prev] [Date Next] | [Thread Prev] [Thread Next] |
Other format: | [Raw text] |
On Fri, Mar 27, 2009 at 06:32:23PM -0700, Nye Liu wrote: > looks like same patch from > http://sourceware.org/ml/crossgcc/2008-10/msg00067.html > (glibc/2.7/290-powerpc-8xx-CPU15-errata.patch) > > applies to 2.9 and eglibc as well... -- Nye Liu nliu@mrv.com (818) 772-6235x248 (818) 772-0576 fax "Who would be stupid enough to quote a fictitious character?" -- Don Quixote
Index: scripts/build/libc/eglibc.sh =================================================================== --- scripts/build/libc/eglibc.sh (.../vendor/crosstool-ng/current) (revision 12574) +++ scripts/build/libc/eglibc.sh (.../trunk/tools/crosstool-ng) (revision 12574) @@ -266,8 +266,16 @@ CT_DoLog EXTRA "Building C library" - CT_DoExecLog ALL make + # eglibc build hacks + # http://sourceware.org/ml/crossgcc/2008-10/msg00068.html + case "${CT_ARCH},${CT_ARCH_CPU}" in + powerpc,8??) + CT_DoLog DEBUG "Activating support for memset on broken ppc-8xx (CPU15 erratum)" + EGLIBC_BUILD_ASFLAGS="-DBROKEN_PPC_8xx_CPU15";; + esac + CT_DoExecLog ALL make ASFLAGS="${EGLIBC_BUILD_ASFLAGS}" + CT_DoLog EXTRA "Installing C library" CT_DoExecLog ALL make install install_root="${CT_SYSROOT_DIR}" Property changes on: scripts/config.guess ___________________________________________________________________ Added: svn:executable + * Property changes on: scripts/config.sub ___________________________________________________________________ Added: svn:executable + * Index: patches/eglibc/2_9/100-powerpc-8xx-CPU15-errata.patch =================================================================== --- patches/eglibc/2_9/100-powerpc-8xx-CPU15-errata.patch (.../vendor/crosstool-ng/current) (revision 0) +++ patches/eglibc/2_9/100-powerpc-8xx-CPU15-errata.patch (.../trunk/tools/crosstool-ng) (revision 12574) @@ -0,0 +1,49 @@ +diff -ru eglibc-2_9_orig/sysdeps/powerpc/powerpc32/memset.S eglibc-2_9/sysdeps/powerpc/powerpc32/memset.S +--- eglibc-2_9_orig/sysdeps/powerpc/powerpc32/memset.S 2007-04-13 08:35:45.000000000 -0700 ++++ eglibc-2_9/sysdeps/powerpc/powerpc32/memset.S 2009-05-06 16:52:04.000000000 -0700 +@@ -112,11 +112,13 @@ + clrrwi. rALIGN, rLEN, 5 + mtcrf 0x01, rLEN /* 40th instruction from .align */ + ++#ifndef BROKEN_PPC_8xx_CPU15 + /* Check if we can use the special case for clearing memory using dcbz. + This requires that we know the correct cache line size for this + processor. Getting the __cache_line_size may require establishing GOT + addressability, so branch out of line to set this up. */ + beq cr1, L(checklinesize) ++#endif + + /* Store blocks of 32-bytes (256-bits) starting on a 32-byte boundary. + Can't assume that rCHR is zero or that the cache line size is either +@@ -158,6 +160,7 @@ + add rMEMP, rMEMP, rALIGN + b L(medium_tail2) /* 72nd instruction from .align */ + ++#ifndef BROKEN_PPC_8xx_CPU15 + .align 5 + nop + /* Clear cache lines of memory in 128-byte chunks. +@@ -191,6 +194,7 @@ + bdnz L(zloop) + beqlr cr5 + b L(medium_tail2) ++#endif /* ! BROKEN_PPC_8xx_CPU15 */ + + .align 5 + L(small): +@@ -248,6 +252,7 @@ + stw rCHR, -8(rMEMP) + blr + ++#ifndef BROKEN_PPC_8xx_CPU15 + L(checklinesize): + #ifdef SHARED + mflr rTMP +@@ -329,6 +334,7 @@ + L(handletail32): + clrrwi. rALIGN, rLEN, 5 + b L(nondcbz) ++#endif /* ! BROKEN_PPC_8xx_CPU15 */ + + END (BP_SYM (memset)) + libc_hidden_builtin_def (memset)
-- For unsubscribe information see http://sourceware.org/lists.html#faq
Index Nav: | [Date Index] [Subject Index] [Author Index] [Thread Index] | |
---|---|---|
Message Nav: | [Date Prev] [Date Next] | [Thread Prev] [Thread Next] |