diff options
author | Ken Smith <kensmith@FreeBSD.org> | 2007-07-13 16:18:43 +0000 |
---|---|---|
committer | Ken Smith <kensmith@FreeBSD.org> | 2007-07-13 16:18:43 +0000 |
commit | 6e5e629f070fc8218702f29cdbdf434fc02b4eaa (patch) | |
tree | 3a95825e0690cf74e548c84b3961f5f5f31b2c4b /libexec | |
parent | 99d4bb399919eeed187299a373d533f8a23aa0eb (diff) | |
download | src-6e5e629f070fc8218702f29cdbdf434fc02b4eaa.tar.gz src-6e5e629f070fc8218702f29cdbdf434fc02b4eaa.zip |
Notes
Diffstat (limited to 'libexec')
-rw-r--r-- | libexec/rtld-elf/sparc64/reloc.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/libexec/rtld-elf/sparc64/reloc.c b/libexec/rtld-elf/sparc64/reloc.c index 225322ed93e0..33eab79bc43e 100644 --- a/libexec/rtld-elf/sparc64/reloc.c +++ b/libexec/rtld-elf/sparc64/reloc.c @@ -260,8 +260,12 @@ reloc_non_plt(Obj_Entry *obj, Obj_Entry *obj_rtld) * The dynamic loader may be called from a thread, we have * limited amounts of stack available so we cannot use alloca(). */ - cache = mmap(NULL, bytes, PROT_READ|PROT_WRITE, MAP_ANON, -1, 0); - if (cache == MAP_FAILED) + if (obj != obj_rtld) { + cache = mmap(NULL, bytes, PROT_READ|PROT_WRITE, MAP_ANON, + -1, 0); + if (cache == MAP_FAILED) + cache = NULL; + } else cache = NULL; relalim = (const Elf_Rela *)((caddr_t)obj->rela + obj->relasize); |