patches/glibc/2.7/290-powerpc-8xx-CPU15-errata.patch
author "Benoît Thébaudeau" <benoit.thebaudeau@advansee.com>
Fri Jan 27 13:31:16 2012 +0100 (2012-01-27)
changeset 2854 a70abdbfa342
parent 966 b6eec1274efb
permissions -rw-r--r--
complibs/cloog: fix linking with libm

In Ubuntu 11.04 and 11.10, the default options for ld have changed.
--no-copy-dt-needed-entries and --as-needed are now enabled by default, which
causes errors like:

[EXTRA] Checking CLooG/ppl
[DEBUG] ==> Executing: 'make' '-j3' '-s' 'check'
[ALL ] Making check in .
[ALL ] config.status: creating include/cloog/cloog-config.h
[ALL ] config.status: include/cloog/cloog-config.h is unchanged
[ALL ] libtool: link: i686-build_pc-linux-gnu-gcc -Wall -fomit-frame-pointer
-pipe -o cloog cloog.o -L/<snip>/build/static/lib ./.libs/libcloog.a -lm
/<snip>/build/static/lib/libppl_c.a /<snip>/build/static/lib/libpwl.a
/<snip>/build/static/lib/libppl.a /<snip>/build/static/lib/libgmpxx.a
/<snip>/build/static/lib/libgmp.a -lstdc++
[ALL ] /usr/bin/ld: /<snip>/build/static/lib/libppl.a(MIP_Problem.o):
undefined reference to symbol 'sqrt@@GLIBC_2.0'
[ALL ] /usr/bin/ld: note: 'sqrt@@GLIBC_2.0' is defined in DSO
/usr/lib/gcc/i686-linux-gnu/4.6.1/../../../i386-linux-gnu/libm.so so try adding
it to the linker command line
[ALL ] /usr/lib/gcc/i686-linux-gnu/4.6.1/../../../i386-linux-gnu/libm.so:
could not read symbols: Invalid operation
[ALL ] collect2: ld returned 1 exit status
[ERROR] make[2]: *** [cloog] Error 1
[ERROR] make[1]: *** [check-recursive] Error 1

See:
https://wiki.ubuntu.com/NattyNarwhal/ToolchainTransition

This patch fixes these errors by placing '-lm' at the right place on the command
line as libppl requires libm when linking cloog.

Signed-off-by: "Benoît Thébaudeau" <benoit.thebaudeau@advansee.com>
yann@966
     1
Fix memset on PowerPC 8xx, by Nye Liu:
yann@966
     2
http://sourceware.org/ml/crossgcc/2008-10/msg00067.html
yann@966
     3
yann@966
     4
Quote:
yann@966
     5
 I am working on a powerpc 860 toolchain, but I am having problems  
yann@966
     6
 convincing glibc to not emit code that uses the dcbz instruction (CPU15  
yann@966
     7
 dcbX bug). The source of the problem is sysdeps/powerpc/power3/memset.S
yann@966
     8
yann@966
     9
--- glibc-2.7/sysdeps/powerpc/powerpc32/memset.S	2007-03-26 13:09:07.000000000 -0700
yann@1016
    10
+++ glibc-2.7/sysdeps/powerpc/powerpc32/memset.S.new	2008-10-23 20:28:52.000000000 -0700
yann@966
    11
@@ -112,11 +112,13 @@
yann@966
    12
 	clrrwi.	rALIGN, rLEN, 5
yann@966
    13
 	mtcrf	0x01, rLEN	/* 40th instruction from .align */
yann@966
    14
 
yann@966
    15
+#ifndef BROKEN_PPC_8xx_CPU15
yann@966
    16
 /* Check if we can use the special case for clearing memory using dcbz.
yann@966
    17
    This requires that we know the correct cache line size for this
yann@966
    18
    processor.  Getting the __cache_line_size may require establishing GOT
yann@966
    19
    addressability, so branch out of line to set this up.  */
yann@966
    20
 	beq	cr1, L(checklinesize)
yann@966
    21
+#endif
yann@966
    22
 
yann@966
    23
 /* Store blocks of 32-bytes (256-bits) starting on a 32-byte boundary.
yann@966
    24
    Can't assume that rCHR is zero or that the cache line size is either
yann@1016
    25
@@ -158,6 +160,7 @@
yann@1016
    26
 	add	rMEMP, rMEMP, rALIGN
yann@1016
    27
 	b	L(medium_tail2)	/* 72nd instruction from .align */
yann@1016
    28
 
yann@1016
    29
+#ifndef BROKEN_PPC_8xx_CPU15
yann@1016
    30
 	.align	5
yann@1016
    31
 	nop
yann@1016
    32
 /* Clear cache lines of memory in 128-byte chunks.
yann@1016
    33
@@ -191,6 +194,7 @@
yann@1016
    34
 	bdnz	L(zloop)
yann@1016
    35
 	beqlr	cr5
yann@1016
    36
 	b	L(medium_tail2)
yann@1016
    37
+#endif /* ! BROKEN_PPC_8xx_CPU15 */
yann@1016
    38
 
yann@1016
    39
 	.align	5
yann@1016
    40
 L(small):
yann@1016
    41
@@ -248,6 +252,7 @@
yann@966
    42
 	stw	rCHR, -8(rMEMP)
yann@966
    43
 	blr
yann@966
    44
 
yann@966
    45
+#ifndef BROKEN_PPC_8xx_CPU15
yann@966
    46
 L(checklinesize):
yann@966
    47
 #ifdef SHARED
yann@966
    48
 	mflr	rTMP
yann@1016
    49
@@ -329,6 +334,7 @@
yann@966
    50
 L(handletail32):
yann@966
    51
 	clrrwi.	rALIGN, rLEN, 5
yann@966
    52
 	b	L(nondcbz)
yann@966
    53
+#endif /* ! BROKEN_PPC_8xx_CPU15 */
yann@966
    54
 
yann@966
    55
 END (BP_SYM (memset))
yann@966
    56
 libc_hidden_builtin_def (memset)