Blame SOURCES/gdb-runtest-pie-override.patch

7a6771
make check//unix/-fPIE/-pie RUNTESTFLAGS=solib-display.exp
7a6771
7a6771
gcc -fpic -c  -fPIE -pie -o x.o x.c
7a6771
/usr/lib/gcc/x86_64-redhat-linux/4.6.1/../../../../lib64/Scrt1.o: In function `_start':
7a6771
(.text+0x20): undefined reference to `main'
7a6771
7a6771
=> Change the order for overrides.
7a6771
7a6771
One has to also use -fPIC rather than -fPIE, -fPIC is stronger.
7a6771
7a6771
The correct way would be:
7a6771
make check//unix RUNTESTFLAGS='CC_FOR_TARGET=gcc\ -fPIC\ -pie CXX_FOR_TARGET=g++\ -fPIC\ -pie solib-display.exp'
7a6771
7a6771
But there is a problem with testsuite.unix non-unique subdir name and also
7a6771
a problem with make -j parallelization of the testsuite.
7a6771
7a6771
--- gdb-7.3.50.20110722/gdb/testsuite/lib/future.exp	2011-10-11 16:44:05.000000000 +0200
7a6771
+++ gdb-7.3.50.20110722/gdb/testsuite/lib/future.exp	2011-10-11 16:44:10.000000000 +0200
7a6771
@@ -77,6 +77,10 @@ proc gdb_default_target_compile {source
7a6771
     set ldflags ""
7a6771
     set dest [target_info name]
7a6771
 
7a6771
+    if {[board_info $dest exists multilib_flags]} {
7a6771
+	append add_flags " [board_info $dest multilib_flags]"
7a6771
+    }
7a6771
+
7a6771
     if {[info exists CFLAGS_FOR_TARGET]} {
7a6771
 	append add_flags " $CFLAGS_FOR_TARGET"
7a6771
     }
7a6771
@@ -333,10 +337,6 @@ proc gdb_default_target_compile {source
7a6771
 	}
7a6771
     }
7a6771
 
7a6771
-    if {[board_info $dest exists multilib_flags]} {
7a6771
-	append add_flags " [board_info $dest multilib_flags]"
7a6771
-    }
7a6771
-
7a6771
     verbose "doing compile"
7a6771
 
7a6771
     set sources ""