patches/glibc/2.6.1/150-alpha-asm_page.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Thu Jul 31 09:08:33 2008 +0000 (2008-07-31)
changeset 752 b037a5643e04
parent 565 ef7dd7893e54
permissions -rw-r--r--
Have the glibc build use the cross-objdump, rather than the host one.
On some distros (eg. Fedora), the native objdump can not interpret objects not for the native system, and thus fail.
This commit adds a new patch against glibc-2.7 that introduces OBJDUMP_FOR_HOST, wich, if set, overides the detected objdump.

Note: bizarely enough, glibc already has code to detect the cross-objdump, but that does not work for an unknown reason... :-(

/trunk/patches/glibc/2.7/220-objdump_for_host.patch | 13 13 0 0 +++++++++
/trunk/scripts/build/libc_glibc.sh | 37 21 16 0 +++++++++++++++------------
2 files changed, 34 insertions(+), 16 deletions(-)
yann@565
     1
2008-06-07  Mike Frysinger  <vapier@gentoo.org>
yann@565
     2
yann@565
     3
	* sysdeps/unix/sysv/linux/alpha/sys/user.h: Copy page.h definitions
yann@565
     4
	from the kernel header to sys/user.h and remove the #include of
yann@565
     5
	sys/user.h.
yann@565
     6
yann@565
     7
--- a/sysdeps/unix/sysv/linux/alpha/sys/user.h
yann@565
     8
+++ b/sysdeps/unix/sysv/linux/alpha/sys/user.h
yann@565
     9
@@ -23,7 +23,6 @@
yann@565
    10
    only. Don't read too much into it. Don't use it for anything other
yann@565
    11
    than gdb/strace unless you know what you are doing. */
yann@565
    12
 
yann@565
    13
-#include <asm/page.h>
yann@565
    14
 #include <asm/reg.h>
yann@565
    15
 
yann@565
    16
 struct user
yann@565
    17
@@ -41,6 +40,9 @@ struct user
yann@565
    18
   char u_comm[32];				/* user command name */
yann@565
    19
 };
yann@565
    20
 
yann@565
    21
+#define PAGE_SHIFT		13
yann@565
    22
+#define PAGE_SIZE		(1 << PAGE_SHIFT)
yann@565
    23
+#define PAGE_MASK		(~(PAGE_SIZE-1))
yann@565
    24
 #define NBPG			PAGE_SIZE
yann@565
    25
 #define UPAGES			1
yann@565
    26
 #define HOST_TEXT_START_ADDR	(u.start_code)