From 1670c7cf0d06b82b064ae37f4c47a9b9692935f2 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Mon, 18 Oct 2004 11:56:08 +0000 Subject: * malloc/arena.c (ptmalloc_init): Don't use brk if dlopened from statically linked program and avoid calling _dl_addr in that case. --- ChangeLog | 6 ++++++ malloc/arena.c | 10 ++++++++-- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/ChangeLog b/ChangeLog index a282a288db..9978171580 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2004-10-18 Jakub Jelinek + + * 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 * sysdeps/generic/strcpy_chk.c (__strcpy_chk): Speed up by checking 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 -- cgit v1.2.3