Date: Fri, 12 Oct 2012 09:25:34 -0700 From: Marcel Moolenaar <marcel@xcllnt.net> To: "freebsd-arch@freebsd.org Arch" <freebsd-arch@freebsd.org> Cc: Tim LaBerge <tlaberge@juniper.net>, Alan Cox <alc@rice.edu> Subject: Behavior of madvise(MADV_FREE) Message-ID: <9FEBC10C-C453-41BE-8829-34E830585E90@xcllnt.net>
next in thread | raw e-mail | index | archive | help
All,
Juniper has been intrigued for a while about the beahviour
of madvise(MADV_FREE). Let me give a bit of context before
asking questions:
1. We have an important daemon that needs lots of memory.
It uses sbrk()/brk() to extend its address space and
uses madvise(MADV_FREE) to inform the kernel when a
chunk of memory is effectively unused (the chunk is
first zeroed).
2. Most of the time memory usage of the daemon is pretty
stable, but under certain conditions it can spike,
after which it drops back to a new stability point
(either higher or lower).
3. Obviously the daemon is not the only component in the
system, so whatever it doesn't need we very likely
need somewhere else -- badly in some cases, so we do
like immediate recycling then.
Now on to the questions:
1. madvise(MADV_FREE) marks the pages as clean and moves
them to the inactive queue. Why isn't the reference
state cleared on either the page or the TLB?
2. Why aren't the pages moved to the cache queue in the
first place?
3. What would be the impact or consequence of changing
the behaviour of madvise(MADV_FREE) to mark the page
as clean and unreferenced and have the page moved to
the cache queue (or free queue even)?
Ad 1:
When the system is under memory pressure, the pageout
daemon scans the inactive queue in order to try to move
pages to the cache or free queue. With the MADV_FREE'd
pages still having PG_REFERENCE or the underlying TLBs
still having the access flag set, these pages actually
get bumped to the active queue.
Ad 2:
MADV_DONTNEED is there to signal that the pages contain
valid data, but that the page is not needed right now.
Using this, pages get moved to the inactive queue. That
makes sense. But MADV_FREE signals that there's no valid
data anymore and that the page may be demand zeroed on
next reference. The page is not inactive. It's free. If
the paged was zeroed before calling MADV_FREE, the page
really caches contents that that can be recreated later
(the demand zero).
Thanks,
--
Marcel Moolenaar
marcel@xcllnt.net
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?9FEBC10C-C453-41BE-8829-34E830585E90>
