public inbox for libc-alpha@sourceware.org
 help / color / mirror / Atom feed
* [PATCH] Reduce number of mmap calls from __libc_memalign in ld.so
@ 2016-04-02 15:34 H.J. Lu
  2016-04-02 17:33 ` Mike Frysinger
  0 siblings, 1 reply; 7+ messages in thread
From: H.J. Lu @ 2016-04-02 15:34 UTC (permalink / raw)
  To: GNU C Library

__libc_memalign in ld.so allocates one page at a time and tries to
optimize consecutive __libc_memalign calls by hoping that the next
mmap is after the current memory allocation.

However, the kernel hands out mmap addresses in top-down order, so
this optimization in practice never happens, with the result that we
have more mmap calls and waste a bunch of space for each __libc_memalign.

This change makes __libc_memalign to mmap one page extra.  Worst case,
the kernel never puts a backing page behind it, but best case it allows
__libc_memalign to operate much much better.  For elf/tst-align --direct,
it reduces number of mmap calls from 12 to 9.

Tested on x86-64.  OK for master?

H.J.
---
	* elf/dl-minimal.c (__libc_memalign): Mmap one extra page.
---
 elf/dl-minimal.c | 1 +
 1 file changed, 1 insertion(+)

diff --git a/elf/dl-minimal.c b/elf/dl-minimal.c
index 762e65b..d6f87f1 100644
--- a/elf/dl-minimal.c
+++ b/elf/dl-minimal.c
@@ -75,6 +75,7 @@ __libc_memalign (size_t align, size_t n)
 	    return NULL;
 	  nup = GLRO(dl_pagesize);
 	}
+      nup += GLRO(dl_pagesize);
       page = __mmap (0, nup, PROT_READ|PROT_WRITE,
 		     MAP_ANON|MAP_PRIVATE, -1, 0);
       if (page == MAP_FAILED)
-- 
2.5.5

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2016-04-23 12:57 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-04-02 15:34 [PATCH] Reduce number of mmap calls from __libc_memalign in ld.so H.J. Lu
2016-04-02 17:33 ` Mike Frysinger
2016-04-02 17:43   ` H.J. Lu
2016-04-02 22:41     ` H.J. Lu
2016-04-03  6:56       ` Andreas Schwab
2016-04-03 13:42         ` H.J. Lu
2016-04-23 12:57           ` H.J. Lu

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).