diff options
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | malloc/arena.c | 10 |
2 files changed, 14 insertions, 2 deletions
@@ -1,5 +1,11 @@ 2004-10-18 Jakub Jelinek <jakub@redhat.com> + * malloc/arena.c (ptmalloc_init): Don't use brk if dlopened + from statically linked program and avoid calling _dl_addr in that + case. + +2004-10-18 Jakub Jelinek <jakub@redhat.com> + * sysdeps/generic/strcpy_chk.c (__strcpy_chk): Speed up by checking destlen only every 4 bytes. diff --git a/malloc/arena.c b/malloc/arena.c index 9018a4f0e9..02e88a391e 100644 --- a/malloc/arena.c +++ b/malloc/arena.c @@ -429,10 +429,16 @@ ptmalloc_init (void) main_arena.next = &main_arena; #if defined _LIBC && defined SHARED - /* In case this libc copy is in a non-default namespace, never use brk. */ + /* In case this libc copy is in a non-default namespace, never use brk. + Likewise if dlopened from statically linked program. */ Dl_info di; struct link_map *l; - if (_dl_addr (ptmalloc_init, &di, &l, NULL) != 0 && l->l_ns != LM_ID_BASE) + extern struct dl_open_hook *_dl_open_hook; + libc_hidden_proto (_dl_open_hook); + + if (_dl_open_hook != NULL + || (_dl_addr (ptmalloc_init, &di, &l, NULL) != 0 + && l->l_ns != LM_ID_BASE)) __morecore = __failing_morecore; #endif |