* elf/dl-runtime.c (fixup): Trampoline passes unbounded pointer.
authorGreg McGary <greg@mcgary.org>
Tue, 18 Jul 2000 00:13:34 +0000 (00:13 +0000)
committerGreg McGary <greg@mcgary.org>
Tue, 18 Jul 2000 00:13:34 +0000 (00:13 +0000)
(profile_fixup): Don't define for __BOUNDED_POINTERS__.
* sysdeps/i386/dl-machine.h: Don't use regparm attribute for
__BOUNDED_POINTERS__.
(ELF_MACHINE_RUNTIME_TRAMPOLINE): Use non-regparm version
for __BOUNDED_POINTERS__.
* iconv/gconv_trans.c: Add #include <stdlib.h> to get malloc decl.

* elf/dl-runtime.c (fixup): Trampoline passes unbounded pointer.
(profile_fixup): Don't define for __BOUNDED_POINTERS__.
* sysdeps/i386/dl-machine.h: Don't use regparm attribute for
__BOUNDED_POINTERS__.
(ELF_MACHINE_RUNTIME_TRAMPOLINE): Use non-regparm version
for __BOUNDED_POINTERS__.

ChangeLog
elf/dl-runtime.c
iconv/gconv_trans.c
sysdeps/i386/dl-machine.h

index 4c79067..1c00cdf 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
        * sysdeps/sparc/sparc64/memchr.S: Likewise.
        * sysdeps/vax/memchr.s: Likewise.
 
+       * iconv/gconv_trans.c: Add #include <stdlib.h> to get malloc decl.
+
+       * elf/dl-runtime.c (fixup): Trampoline passes unbounded pointer.
+       (profile_fixup): Don't define for __BOUNDED_POINTERS__.
+       * sysdeps/i386/dl-machine.h: Don't use regparm attribute for
+       __BOUNDED_POINTERS__.
+       (ELF_MACHINE_RUNTIME_TRAMPOLINE): Use non-regparm version
+       for __BOUNDED_POINTERS__.
+
 2000-07-17  Bruno Haible  <haible@clisp.cons.org>
 
        * iconv/gconv_open.c (__gconv_open): Initialize the __data
index cb38dfe..bff27e7 100644 (file)
@@ -47,7 +47,9 @@ fixup (
 # ifdef ELF_MACHINE_RUNTIME_FIXUP_ARGS
         ELF_MACHINE_RUNTIME_FIXUP_ARGS,
 # endif
-       struct link_map *l, ElfW(Word) reloc_offset)
+       /* GKM FIXME: Fix trampoline to pass bounds so we can do
+          without the `__unbounded' qualifier.  */
+       struct link_map *__unbounded l, ElfW(Word) reloc_offset)
 {
   const ElfW(Sym) *const symtab
     = (const void *) D_PTR (l, l_info[DT_SYMTAB]);
@@ -119,7 +121,7 @@ fixup (
 }
 #endif
 
-#if !defined PROF && !defined ELF_MACHINE_NO_PLT
+#if !defined PROF && !defined ELF_MACHINE_NO_PLT && !__BOUNDED_POINTERS__
 
 static ElfW(Addr) __attribute__ ((unused))
 profile_fixup (
index 4fcb232..db7c567 100644 (file)
@@ -23,6 +23,7 @@
 #include <search.h>
 #include <stdint.h>
 #include <string.h>
+#include <stdlib.h>
 
 #include <bits/libc-lock.h>
 #include "gconv_int.h"
index 3044edf..1f787a5 100644 (file)
@@ -60,14 +60,16 @@ elf_machine_load_address (void)
   return addr;
 }
 
-#ifndef PROF
+#if !defined PROF && !__BOUNDED_POINTERS__
 /* We add a declaration of this function here so that in dl-runtime.c
    the ELF_MACHINE_RUNTIME_TRAMPOLINE macro really can pass the parameters
    in registers.
 
    We cannot use this scheme for profiling because the _mcount call
    destroys the passed register information.  */
-static ElfW(Addr) fixup (struct link_map *l, ElfW(Word) reloc_offset)
+/* GKM FIXME: Fix trampoline to pass bounds so we can do
+   without the `__unbounded' qualifier.  */
+static ElfW(Addr) fixup (struct link_map *__unbounded l, ElfW(Word) reloc_offset)
      __attribute__ ((regparm (2), unused));
 static ElfW(Addr) profile_fixup (struct link_map *l, ElfW(Word) reloc_offset,
                                 ElfW(Addr) retaddr)
@@ -119,7 +121,7 @@ elf_machine_runtime_setup (struct link_map *l, int lazy, int profile)
 
 /* This code is used in dl-runtime.c to call the `fixup' function
    and then redirect to the address it returns.  */
-#ifndef PROF
+#if !defined PROF && !__BOUNDED_POINTERS__
 # define ELF_MACHINE_RUNTIME_TRAMPOLINE asm ("\
        .text
        .globl _dl_runtime_resolve