Update.
authorUlrich Drepper <drepper@redhat.com>
Tue, 6 Feb 2001 00:56:59 +0000 (00:56 +0000)
committerUlrich Drepper <drepper@redhat.com>
Tue, 6 Feb 2001 00:56:59 +0000 (00:56 +0000)
* elf/ldconfig.c (search_dir): Use PRIx64 instead of Lx in printf
string.  Include <inttypes.h> instead of <stdint.h>.

ChangeLog
elf/ldconfig.c
linuxthreads/ChangeLog
linuxthreads/sysdeps/unix/sysv/linux/ia64/pt-initfini.c [new file with mode: 0644]

index 8872475..7149df3 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
 2001-02-05  Ulrich Drepper  <drepper@redhat.com>
 
+       * elf/ldconfig.c (search_dir): Use PRIx64 instead of Lx in printf
+       string.  Include <inttypes.h> instead of <stdint.h>.
+
        * configure.in: Add check for bison.
        * config.make.in: Define BISON variable.
        * intl/Makefile: Use BISON instead of YACC when generating plural.c.
index f3f51e3..2318411 100644 (file)
 #include <elf.h>
 #include <error.h>
 #include <errno.h>
+#include <inttypes.h>
 #include <libintl.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
 #include <unistd.h>
-#include <stdint.h>
 #include <sys/fcntl.h>
 #include <sys/mman.h>
 #include <sys/stat.h>
@@ -597,7 +597,7 @@ search_dir (const struct dir_entry *entry)
   if (opt_verbose)
     {
       if (hwcap != 0)
-       printf ("%s: (hwcap: 0x%Lx)\n", entry->path, hwcap);
+       printf ("%s: (hwcap: 0x%" PRIx64 ")\n", entry->path, hwcap);
       else
        printf ("%s:\n", entry->path);
     }
index 3e5e7b0..acb8480 100644 (file)
@@ -1,3 +1,7 @@
+2001-02-05  Jes Sorensen  <jes@linuxcare.com>
+
+       * sysdeps/unix/sysv/linux/ia64/pt-initfini.c: New file.
+
 2001-02-02  Ulrich Drepper  <drepper@redhat.com>
 
        * Versions: Remove __pthread_initialize_minimal.
diff --git a/linuxthreads/sysdeps/unix/sysv/linux/ia64/pt-initfini.c b/linuxthreads/sysdeps/unix/sysv/linux/ia64/pt-initfini.c
new file mode 100644 (file)
index 0000000..766d481
--- /dev/null
@@ -0,0 +1,117 @@
+/* Special .init and .fini section support for ia64. LinuxThreads version.
+   Copyright (C) 2000, 2001 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it
+   and/or modify it under the terms of the GNU Library General Public
+   License as published by the Free Software Foundation; either
+   version 2 of the License, or (at your option) any later version.
+
+   In addition to the permissions in the GNU Library General Public
+   License, the Free Software Foundation gives you unlimited
+   permission to link the compiled version of this file with other
+   programs, and to distribute those programs without any restriction
+   coming from the use of this file.  (The Library General Public
+   License restrictions do apply in other respects; for example, they
+   cover modification of the file, and distribution when not linked
+   into another program.)
+
+   The GNU C Library is distributed in the hope that it will be
+   useful, but WITHOUT ANY WARRANTY; without even the implied warranty
+   of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+/* This file is compiled into assembly code which is then munged by a sed
+   script into two files: crti.s and crtn.s.
+
+   * crti.s puts a function prologue at the beginning of the
+   .init and .fini sections and defines global symbols for
+   those addresses, so they can be called as functions.
+
+   * crtn.s puts the corresponding function epilogues
+   in the .init and .fini sections. */
+
+__asm__ ("
+
+#include \"defs.h\"
+
+/*@HEADER_ENDS*/
+
+/*@_init_PROLOG_BEGINS*/
+       .section .init
+       .align 16
+       .global _init#
+       .proc _init#
+_init:
+       alloc r34 = ar.pfs, 0, 3, 0, 0
+       mov r32 = r12
+       mov r33 = b0
+       adds r12 = -16, r12
+       addl r14 = @ltoff(@fptr(__gmon_start__#)), gp
+       ;;
+       ld8 r15 = [r14]
+/* we could use r35 to save gp, but we use the stack since that's what
+ * all the other init routines will do --davidm 00/04/05 */
+       st8 [r12] = gp, -16
+       br.call.sptk.many b0 = __pthread_initialize_minimal# ;;
+       ;;
+       cmp.eq p6, p7 = 0, r15
+       (p6) br.cond.dptk .L5
+
+       br.call.sptk.many b0 = __gmon_start__# ;;
+       adds r12 = 16, r12
+       ;;
+.L5:
+       ld8 gp = [r12]
+       ;;
+       .align 16
+       .endp _init#
+
+/*@_init_PROLOG_ENDS*/
+
+/*@_init_EPILOG_BEGINS*/
+       .section .init
+       .regstk 0,2,0,0
+       mov r12 = r32
+       mov ar.pfs = r34
+       mov b0 = r33
+       br.ret.sptk.many b0
+       .endp _init#
+/*@_init_EPILOG_ENDS*/
+
+/*@_fini_PROLOG_BEGINS*/
+       .section .fini
+       .align 16
+       .global _fini#
+       .proc _fini#
+_fini:
+       alloc r34 = ar.pfs, 0, 3, 0, 0
+       mov r32 = r12
+       mov r33 = b0
+       adds r12 = -16, r12
+       ;;
+       .align 16
+       .endp _fini#
+
+/*@_fini_PROLOG_ENDS*/
+       br.call.sptk.many b0 = i_am_not_a_leaf# ;;
+       ;;
+
+/*@_fini_EPILOG_BEGINS*/
+       .section .fini
+       mov r12 = r32
+       mov ar.pfs = r34
+       mov b0 = r33
+       br.ret.sptk.many b0
+       .endp _fini#
+
+/*@_fini_EPILOG_ENDS*/
+
+/*@TRAILER_BEGINS*/
+       .weak   __gmon_start__#
+");