1<?xml version='1.0' encoding='UTF-8'?>
2<?xml-stylesheet type="text/xsl"
3        href="http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl"?>
4<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.4//EN"
5        "http://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd" [
6]>
7
8<refentry>
9  <refentryinfo>
10    <title>User Manual</title>
11    <productname>jemalloc</productname>
12    <releaseinfo role="version">@jemalloc_version@</releaseinfo>
13    <authorgroup>
14      <author>
15        <firstname>Jason</firstname>
16        <surname>Evans</surname>
17        <personblurb>Author</personblurb>
18      </author>
19    </authorgroup>
20  </refentryinfo>
21  <refmeta>
22    <refentrytitle>JEMALLOC</refentrytitle>
23    <manvolnum>3</manvolnum>
24  </refmeta>
25  <refnamediv>
26    <refdescriptor>jemalloc</refdescriptor>
27    <refname>jemalloc</refname>
28    <!-- Each refname causes a man page file to be created.  Only if this were
29         the system malloc(3) implementation would these files be appropriate.
30    <refname>malloc</refname>
31    <refname>calloc</refname>
32    <refname>posix_memalign</refname>
33    <refname>aligned_alloc</refname>
34    <refname>realloc</refname>
35    <refname>free</refname>
36    <refname>mallocx</refname>
37    <refname>rallocx</refname>
38    <refname>xallocx</refname>
39    <refname>sallocx</refname>
40    <refname>dallocx</refname>
41    <refname>sdallocx</refname>
42    <refname>nallocx</refname>
43    <refname>mallctl</refname>
44    <refname>mallctlnametomib</refname>
45    <refname>mallctlbymib</refname>
46    <refname>malloc_stats_print</refname>
47    <refname>malloc_usable_size</refname>
48    -->
49    <refpurpose>general purpose memory allocation functions</refpurpose>
50  </refnamediv>
51  <refsect1 id="library">
52    <title>LIBRARY</title>
53    <para>This manual describes jemalloc @jemalloc_version@.  More information
54    can be found at the <ulink
55    url="http://jemalloc.net/">jemalloc website</ulink>.</para>
56  </refsect1>
57  <refsynopsisdiv>
58    <title>SYNOPSIS</title>
59    <funcsynopsis>
60      <funcsynopsisinfo>#include &lt;<filename class="headerfile">jemalloc/jemalloc.h</filename>&gt;</funcsynopsisinfo>
61      <refsect2>
62        <title>Standard API</title>
63        <funcprototype>
64          <funcdef>void *<function>malloc</function></funcdef>
65          <paramdef>size_t <parameter>size</parameter></paramdef>
66        </funcprototype>
67        <funcprototype>
68          <funcdef>void *<function>calloc</function></funcdef>
69          <paramdef>size_t <parameter>number</parameter></paramdef>
70          <paramdef>size_t <parameter>size</parameter></paramdef>
71        </funcprototype>
72        <funcprototype>
73          <funcdef>int <function>posix_memalign</function></funcdef>
74          <paramdef>void **<parameter>ptr</parameter></paramdef>
75          <paramdef>size_t <parameter>alignment</parameter></paramdef>
76          <paramdef>size_t <parameter>size</parameter></paramdef>
77        </funcprototype>
78        <funcprototype>
79          <funcdef>void *<function>aligned_alloc</function></funcdef>
80          <paramdef>size_t <parameter>alignment</parameter></paramdef>
81          <paramdef>size_t <parameter>size</parameter></paramdef>
82        </funcprototype>
83        <funcprototype>
84          <funcdef>void *<function>realloc</function></funcdef>
85          <paramdef>void *<parameter>ptr</parameter></paramdef>
86          <paramdef>size_t <parameter>size</parameter></paramdef>
87        </funcprototype>
88        <funcprototype>
89          <funcdef>void <function>free</function></funcdef>
90          <paramdef>void *<parameter>ptr</parameter></paramdef>
91        </funcprototype>
92      </refsect2>
93      <refsect2>
94        <title>Non-standard API</title>
95        <funcprototype>
96          <funcdef>void *<function>mallocx</function></funcdef>
97          <paramdef>size_t <parameter>size</parameter></paramdef>
98          <paramdef>int <parameter>flags</parameter></paramdef>
99        </funcprototype>
100        <funcprototype>
101          <funcdef>void *<function>rallocx</function></funcdef>
102          <paramdef>void *<parameter>ptr</parameter></paramdef>
103          <paramdef>size_t <parameter>size</parameter></paramdef>
104          <paramdef>int <parameter>flags</parameter></paramdef>
105        </funcprototype>
106        <funcprototype>
107          <funcdef>size_t <function>xallocx</function></funcdef>
108          <paramdef>void *<parameter>ptr</parameter></paramdef>
109          <paramdef>size_t <parameter>size</parameter></paramdef>
110          <paramdef>size_t <parameter>extra</parameter></paramdef>
111          <paramdef>int <parameter>flags</parameter></paramdef>
112        </funcprototype>
113        <funcprototype>
114          <funcdef>size_t <function>sallocx</function></funcdef>
115          <paramdef>void *<parameter>ptr</parameter></paramdef>
116          <paramdef>int <parameter>flags</parameter></paramdef>
117        </funcprototype>
118        <funcprototype>
119          <funcdef>void <function>dallocx</function></funcdef>
120          <paramdef>void *<parameter>ptr</parameter></paramdef>
121          <paramdef>int <parameter>flags</parameter></paramdef>
122        </funcprototype>
123        <funcprototype>
124          <funcdef>void <function>sdallocx</function></funcdef>
125          <paramdef>void *<parameter>ptr</parameter></paramdef>
126          <paramdef>size_t <parameter>size</parameter></paramdef>
127          <paramdef>int <parameter>flags</parameter></paramdef>
128        </funcprototype>
129        <funcprototype>
130          <funcdef>size_t <function>nallocx</function></funcdef>
131          <paramdef>size_t <parameter>size</parameter></paramdef>
132          <paramdef>int <parameter>flags</parameter></paramdef>
133        </funcprototype>
134        <funcprototype>
135          <funcdef>int <function>mallctl</function></funcdef>
136          <paramdef>const char *<parameter>name</parameter></paramdef>
137          <paramdef>void *<parameter>oldp</parameter></paramdef>
138          <paramdef>size_t *<parameter>oldlenp</parameter></paramdef>
139          <paramdef>void *<parameter>newp</parameter></paramdef>
140          <paramdef>size_t <parameter>newlen</parameter></paramdef>
141        </funcprototype>
142        <funcprototype>
143          <funcdef>int <function>mallctlnametomib</function></funcdef>
144          <paramdef>const char *<parameter>name</parameter></paramdef>
145          <paramdef>size_t *<parameter>mibp</parameter></paramdef>
146          <paramdef>size_t *<parameter>miblenp</parameter></paramdef>
147        </funcprototype>
148        <funcprototype>
149          <funcdef>int <function>mallctlbymib</function></funcdef>
150          <paramdef>const size_t *<parameter>mib</parameter></paramdef>
151          <paramdef>size_t <parameter>miblen</parameter></paramdef>
152          <paramdef>void *<parameter>oldp</parameter></paramdef>
153          <paramdef>size_t *<parameter>oldlenp</parameter></paramdef>
154          <paramdef>void *<parameter>newp</parameter></paramdef>
155          <paramdef>size_t <parameter>newlen</parameter></paramdef>
156        </funcprototype>
157        <funcprototype>
158          <funcdef>void <function>malloc_stats_print</function></funcdef>
159          <paramdef>void <parameter>(*write_cb)</parameter>
160            <funcparams>void *, const char *</funcparams>
161          </paramdef>
162          <paramdef>void *<parameter>cbopaque</parameter></paramdef>
163          <paramdef>const char *<parameter>opts</parameter></paramdef>
164        </funcprototype>
165        <funcprototype>
166          <funcdef>size_t <function>malloc_usable_size</function></funcdef>
167          <paramdef>const void *<parameter>ptr</parameter></paramdef>
168        </funcprototype>
169        <funcprototype>
170          <funcdef>void <function>(*malloc_message)</function></funcdef>
171          <paramdef>void *<parameter>cbopaque</parameter></paramdef>
172          <paramdef>const char *<parameter>s</parameter></paramdef>
173        </funcprototype>
174        <para><type>const char *</type><varname>malloc_conf</varname>;</para>
175      </refsect2>
176    </funcsynopsis>
177  </refsynopsisdiv>
178  <refsect1 id="description">
179    <title>DESCRIPTION</title>
180    <refsect2>
181      <title>Standard API</title>
182
183      <para>The <function>malloc()</function> function allocates
184      <parameter>size</parameter> bytes of uninitialized memory.  The allocated
185      space is suitably aligned (after possible pointer coercion) for storage
186      of any type of object.</para>
187
188      <para>The <function>calloc()</function> function allocates
189      space for <parameter>number</parameter> objects, each
190      <parameter>size</parameter> bytes in length.  The result is identical to
191      calling <function>malloc()</function> with an argument of
192      <parameter>number</parameter> * <parameter>size</parameter>, with the
193      exception that the allocated memory is explicitly initialized to zero
194      bytes.</para>
195
196      <para>The <function>posix_memalign()</function> function
197      allocates <parameter>size</parameter> bytes of memory such that the
198      allocation's base address is a multiple of
199      <parameter>alignment</parameter>, and returns the allocation in the value
200      pointed to by <parameter>ptr</parameter>.  The requested
201      <parameter>alignment</parameter> must be a power of 2 at least as large as
202      <code language="C">sizeof(<type>void *</type>)</code>.</para>
203
204      <para>The <function>aligned_alloc()</function> function
205      allocates <parameter>size</parameter> bytes of memory such that the
206      allocation's base address is a multiple of
207      <parameter>alignment</parameter>.  The requested
208      <parameter>alignment</parameter> must be a power of 2.  Behavior is
209      undefined if <parameter>size</parameter> is not an integral multiple of
210      <parameter>alignment</parameter>.</para>
211
212      <para>The <function>realloc()</function> function changes the
213      size of the previously allocated memory referenced by
214      <parameter>ptr</parameter> to <parameter>size</parameter> bytes.  The
215      contents of the memory are unchanged up to the lesser of the new and old
216      sizes.  If the new size is larger, the contents of the newly allocated
217      portion of the memory are undefined.  Upon success, the memory referenced
218      by <parameter>ptr</parameter> is freed and a pointer to the newly
219      allocated memory is returned.  Note that
220      <function>realloc()</function> may move the memory allocation,
221      resulting in a different return value than <parameter>ptr</parameter>.
222      If <parameter>ptr</parameter> is <constant>NULL</constant>, the
223      <function>realloc()</function> function behaves identically to
224      <function>malloc()</function> for the specified size.</para>
225
226      <para>The <function>free()</function> function causes the
227      allocated memory referenced by <parameter>ptr</parameter> to be made
228      available for future allocations.  If <parameter>ptr</parameter> is
229      <constant>NULL</constant>, no action occurs.</para>
230    </refsect2>
231    <refsect2>
232      <title>Non-standard API</title>
233      <para>The <function>mallocx()</function>,
234      <function>rallocx()</function>,
235      <function>xallocx()</function>,
236      <function>sallocx()</function>,
237      <function>dallocx()</function>,
238      <function>sdallocx()</function>, and
239      <function>nallocx()</function> functions all have a
240      <parameter>flags</parameter> argument that can be used to specify
241      options.  The functions only check the options that are contextually
242      relevant.  Use bitwise or (<code language="C">|</code>) operations to
243      specify one or more of the following:
244        <variablelist>
245          <varlistentry id="MALLOCX_LG_ALIGN">
246            <term><constant>MALLOCX_LG_ALIGN(<parameter>la</parameter>)
247            </constant></term>
248
249            <listitem><para>Align the memory allocation to start at an address
250            that is a multiple of <code language="C">(1 &lt;&lt;
251            <parameter>la</parameter>)</code>.  This macro does not validate
252            that <parameter>la</parameter> is within the valid
253            range.</para></listitem>
254          </varlistentry>
255          <varlistentry id="MALLOCX_ALIGN">
256            <term><constant>MALLOCX_ALIGN(<parameter>a</parameter>)
257            </constant></term>
258
259            <listitem><para>Align the memory allocation to start at an address
260            that is a multiple of <parameter>a</parameter>, where
261            <parameter>a</parameter> is a power of two.  This macro does not
262            validate that <parameter>a</parameter> is a power of 2.
263            </para></listitem>
264          </varlistentry>
265          <varlistentry id="MALLOCX_ZERO">
266            <term><constant>MALLOCX_ZERO</constant></term>
267
268            <listitem><para>Initialize newly allocated memory to contain zero
269            bytes.  In the growing reallocation case, the real size prior to
270            reallocation defines the boundary between untouched bytes and those
271            that are initialized to contain zero bytes.  If this macro is
272            absent, newly allocated memory is uninitialized.</para></listitem>
273          </varlistentry>
274          <varlistentry id="MALLOCX_TCACHE">
275            <term><constant>MALLOCX_TCACHE(<parameter>tc</parameter>)
276            </constant></term>
277
278            <listitem><para>Use the thread-specific cache (tcache) specified by
279            the identifier <parameter>tc</parameter>, which must have been
280            acquired via the <link
281            linkend="tcache.create"><mallctl>tcache.create</mallctl></link>
282            mallctl.  This macro does not validate that
283            <parameter>tc</parameter> specifies a valid
284            identifier.</para></listitem>
285          </varlistentry>
286          <varlistentry id="MALLOC_TCACHE_NONE">
287            <term><constant>MALLOCX_TCACHE_NONE</constant></term>
288
289            <listitem><para>Do not use a thread-specific cache (tcache).  Unless
290            <constant>MALLOCX_TCACHE(<parameter>tc</parameter>)</constant> or
291            <constant>MALLOCX_TCACHE_NONE</constant> is specified, an
292            automatically managed tcache will be used under many circumstances.
293            This macro cannot be used in the same <parameter>flags</parameter>
294            argument as
295            <constant>MALLOCX_TCACHE(<parameter>tc</parameter>)</constant>.</para></listitem>
296          </varlistentry>
297          <varlistentry id="MALLOCX_ARENA">
298            <term><constant>MALLOCX_ARENA(<parameter>a</parameter>)
299            </constant></term>
300
301            <listitem><para>Use the arena specified by the index
302            <parameter>a</parameter>.  This macro has no effect for regions that
303            were allocated via an arena other than the one specified.  This
304            macro does not validate that <parameter>a</parameter> specifies an
305            arena index in the valid range.</para></listitem>
306          </varlistentry>
307        </variablelist>
308      </para>
309
310      <para>The <function>mallocx()</function> function allocates at
311      least <parameter>size</parameter> bytes of memory, and returns a pointer
312      to the base address of the allocation.  Behavior is undefined if
313      <parameter>size</parameter> is <constant>0</constant>.</para>
314
315      <para>The <function>rallocx()</function> function resizes the
316      allocation at <parameter>ptr</parameter> to be at least
317      <parameter>size</parameter> bytes, and returns a pointer to the base
318      address of the resulting allocation, which may or may not have moved from
319      its original location.  Behavior is undefined if
320      <parameter>size</parameter> is <constant>0</constant>.</para>
321
322      <para>The <function>xallocx()</function> function resizes the
323      allocation at <parameter>ptr</parameter> in place to be at least
324      <parameter>size</parameter> bytes, and returns the real size of the
325      allocation.  If <parameter>extra</parameter> is non-zero, an attempt is
326      made to resize the allocation to be at least <code
327      language="C">(<parameter>size</parameter> +
328      <parameter>extra</parameter>)</code> bytes, though inability to allocate
329      the extra byte(s) will not by itself result in failure to resize.
330      Behavior is undefined if <parameter>size</parameter> is
331      <constant>0</constant>, or if <code
332      language="C">(<parameter>size</parameter> + <parameter>extra</parameter>
333      &gt; <constant>SIZE_T_MAX</constant>)</code>.</para>
334
335      <para>The <function>sallocx()</function> function returns the
336      real size of the allocation at <parameter>ptr</parameter>.</para>
337
338      <para>The <function>dallocx()</function> function causes the
339      memory referenced by <parameter>ptr</parameter> to be made available for
340      future allocations.</para>
341
342      <para>The <function>sdallocx()</function> function is an
343      extension of <function>dallocx()</function> with a
344      <parameter>size</parameter> parameter to allow the caller to pass in the
345      allocation size as an optimization.  The minimum valid input size is the
346      original requested size of the allocation, and the maximum valid input
347      size is the corresponding value returned by
348      <function>nallocx()</function> or
349      <function>sallocx()</function>.</para>
350
351      <para>The <function>nallocx()</function> function allocates no
352      memory, but it performs the same size computation as the
353      <function>mallocx()</function> function, and returns the real
354      size of the allocation that would result from the equivalent
355      <function>mallocx()</function> function call, or
356      <constant>0</constant> if the inputs exceed the maximum supported size
357      class and/or alignment.  Behavior is undefined if
358      <parameter>size</parameter> is <constant>0</constant>.</para>
359
360      <para>The <function>mallctl()</function> function provides a
361      general interface for introspecting the memory allocator, as well as
362      setting modifiable parameters and triggering actions.  The
363      period-separated <parameter>name</parameter> argument specifies a
364      location in a tree-structured namespace; see the <xref
365      linkend="mallctl_namespace" xrefstyle="template:%t"/> section for
366      documentation on the tree contents.  To read a value, pass a pointer via
367      <parameter>oldp</parameter> to adequate space to contain the value, and a
368      pointer to its length via <parameter>oldlenp</parameter>; otherwise pass
369      <constant>NULL</constant> and <constant>NULL</constant>.  Similarly, to
370      write a value, pass a pointer to the value via
371      <parameter>newp</parameter>, and its length via
372      <parameter>newlen</parameter>; otherwise pass <constant>NULL</constant>
373      and <constant>0</constant>.</para>
374
375      <para>The <function>mallctlnametomib()</function> function
376      provides a way to avoid repeated name lookups for applications that
377      repeatedly query the same portion of the namespace, by translating a name
378      to a <quote>Management Information Base</quote> (MIB) that can be passed
379      repeatedly to <function>mallctlbymib()</function>.  Upon
380      successful return from <function>mallctlnametomib()</function>,
381      <parameter>mibp</parameter> contains an array of
382      <parameter>*miblenp</parameter> integers, where
383      <parameter>*miblenp</parameter> is the lesser of the number of components
384      in <parameter>name</parameter> and the input value of
385      <parameter>*miblenp</parameter>.  Thus it is possible to pass a
386      <parameter>*miblenp</parameter> that is smaller than the number of
387      period-separated name components, which results in a partial MIB that can
388      be used as the basis for constructing a complete MIB.  For name
389      components that are integers (e.g. the 2 in
390      <link
391      linkend="arenas.bin.i.size"><mallctl>arenas.bin.2.size</mallctl></link>),
392      the corresponding MIB component will always be that integer.  Therefore,
393      it is legitimate to construct code like the following: <programlisting
394      language="C"><![CDATA[
395unsigned nbins, i;
396size_t mib[4];
397size_t len, miblen;
398
399len = sizeof(nbins);
400mallctl("arenas.nbins", &nbins, &len, NULL, 0);
401
402miblen = 4;
403mallctlnametomib("arenas.bin.0.size", mib, &miblen);
404for (i = 0; i < nbins; i++) {
405	size_t bin_size;
406
407	mib[2] = i;
408	len = sizeof(bin_size);
409	mallctlbymib(mib, miblen, (void *)&bin_size, &len, NULL, 0);
410	/* Do something with bin_size... */
411}]]></programlisting></para>
412
413      <para>The <function>malloc_stats_print()</function> function writes
414      summary statistics via the <parameter>write_cb</parameter> callback
415      function pointer and <parameter>cbopaque</parameter> data passed to
416      <parameter>write_cb</parameter>, or <function>malloc_message()</function>
417      if <parameter>write_cb</parameter> is <constant>NULL</constant>.  The
418      statistics are presented in human-readable form unless <quote>J</quote> is
419      specified as a character within the <parameter>opts</parameter> string, in
420      which case the statistics are presented in <ulink
421      url="http://www.json.org/">JSON format</ulink>.  This function can be
422      called repeatedly.  General information that never changes during
423      execution can be omitted by specifying <quote>g</quote> as a character
424      within the <parameter>opts</parameter> string.  Note that
425      <function>malloc_message()</function> uses the
426      <function>mallctl*()</function> functions internally, so inconsistent
427      statistics can be reported if multiple threads use these functions
428      simultaneously.  If <option>--enable-stats</option> is specified during
429      configuration, <quote>m</quote> and <quote>a</quote> can be specified to
430      omit merged arena and per arena statistics, respectively;
431      <quote>b</quote>, <quote>l</quote>, and <quote>h</quote> can be specified
432      to omit per size class statistics for bins, large objects, and huge
433      objects, respectively.  Unrecognized characters are silently ignored.
434      Note that thread caching may prevent some statistics from being completely
435      up to date, since extra locking would be required to merge counters that
436      track thread cache operations.</para>
437
438      <para>The <function>malloc_usable_size()</function> function
439      returns the usable size of the allocation pointed to by
440      <parameter>ptr</parameter>.  The return value may be larger than the size
441      that was requested during allocation.  The
442      <function>malloc_usable_size()</function> function is not a
443      mechanism for in-place <function>realloc()</function>; rather
444      it is provided solely as a tool for introspection purposes.  Any
445      discrepancy between the requested allocation size and the size reported
446      by <function>malloc_usable_size()</function> should not be
447      depended on, since such behavior is entirely implementation-dependent.
448      </para>
449    </refsect2>
450  </refsect1>
451  <refsect1 id="tuning">
452    <title>TUNING</title>
453    <para>Once, when the first call is made to one of the memory allocation
454    routines, the allocator initializes its internals based in part on various
455    options that can be specified at compile- or run-time.</para>
456
457    <para>The string specified via <option>--with-malloc-conf</option>, the
458    string pointed to by the global variable <varname>malloc_conf</varname>, the
459    <quote>name</quote> of the file referenced by the symbolic link named
460    <filename class="symlink">/etc/malloc.conf</filename>, and the value of the
461    environment variable <envar>MALLOC_CONF</envar>, will be interpreted, in
462    that order, from left to right as options.  Note that
463    <varname>malloc_conf</varname> may be read before
464    <function>main()</function> is entered, so the declaration of
465    <varname>malloc_conf</varname> should specify an initializer that contains
466    the final value to be read by jemalloc.  <option>--with-malloc-conf</option>
467    and <varname>malloc_conf</varname> are compile-time mechanisms, whereas
468    <filename class="symlink">/etc/malloc.conf</filename> and
469    <envar>MALLOC_CONF</envar> can be safely set any time prior to program
470    invocation.</para>
471
472    <para>An options string is a comma-separated list of option:value pairs.
473    There is one key corresponding to each <link
474    linkend="opt.abort"><mallctl>opt.*</mallctl></link> mallctl (see the <xref
475    linkend="mallctl_namespace" xrefstyle="template:%t"/> section for options
476    documentation).  For example, <literal>abort:true,narenas:1</literal> sets
477    the <link linkend="opt.abort"><mallctl>opt.abort</mallctl></link> and <link
478    linkend="opt.narenas"><mallctl>opt.narenas</mallctl></link> options.  Some
479    options have boolean values (true/false), others have integer values (base
480    8, 10, or 16, depending on prefix), and yet others have raw string
481    values.</para>
482  </refsect1>
483  <refsect1 id="implementation_notes">
484    <title>IMPLEMENTATION NOTES</title>
485    <para>Traditionally, allocators have used
486    <citerefentry><refentrytitle>sbrk</refentrytitle>
487    <manvolnum>2</manvolnum></citerefentry> to obtain memory, which is
488    suboptimal for several reasons, including race conditions, increased
489    fragmentation, and artificial limitations on maximum usable memory.  If
490    <citerefentry><refentrytitle>sbrk</refentrytitle>
491    <manvolnum>2</manvolnum></citerefentry> is supported by the operating
492    system, this allocator uses both
493    <citerefentry><refentrytitle>mmap</refentrytitle>
494    <manvolnum>2</manvolnum></citerefentry> and
495    <citerefentry><refentrytitle>sbrk</refentrytitle>
496    <manvolnum>2</manvolnum></citerefentry>, in that order of preference;
497    otherwise only <citerefentry><refentrytitle>mmap</refentrytitle>
498    <manvolnum>2</manvolnum></citerefentry> is used.</para>
499
500    <para>This allocator uses multiple arenas in order to reduce lock
501    contention for threaded programs on multi-processor systems.  This works
502    well with regard to threading scalability, but incurs some costs.  There is
503    a small fixed per-arena overhead, and additionally, arenas manage memory
504    completely independently of each other, which means a small fixed increase
505    in overall memory fragmentation.  These overheads are not generally an
506    issue, given the number of arenas normally used.  Note that using
507    substantially more arenas than the default is not likely to improve
508    performance, mainly due to reduced cache performance.  However, it may make
509    sense to reduce the number of arenas if an application does not make much
510    use of the allocation functions.</para>
511
512    <para>In addition to multiple arenas, unless
513    <option>--disable-tcache</option> is specified during configuration, this
514    allocator supports thread-specific caching for small and large objects, in
515    order to make it possible to completely avoid synchronization for most
516    allocation requests.  Such caching allows very fast allocation in the
517    common case, but it increases memory usage and fragmentation, since a
518    bounded number of objects can remain allocated in each thread cache.</para>
519
520    <para>Memory is conceptually broken into equal-sized chunks, where the chunk
521    size is a power of two that is greater than the page size.  Chunks are
522    always aligned to multiples of the chunk size.  This alignment makes it
523    possible to find metadata for user objects very quickly.  User objects are
524    broken into three categories according to size: small, large, and huge.
525    Multiple small and large objects can reside within a single chunk, whereas
526    huge objects each have one or more chunks backing them.  Each chunk that
527    contains small and/or large objects tracks its contents as runs of
528    contiguous pages (unused, backing a set of small objects, or backing one
529    large object).  The combination of chunk alignment and chunk page maps makes
530    it possible to determine all metadata regarding small and large allocations
531    in constant time.</para>
532
533    <para>Small objects are managed in groups by page runs.  Each run maintains
534    a bitmap to track which regions are in use.  Allocation requests that are no
535    more than half the quantum (8 or 16, depending on architecture) are rounded
536    up to the nearest power of two that is at least <code
537    language="C">sizeof(<type>double</type>)</code>.  All other object size
538    classes are multiples of the quantum, spaced such that there are four size
539    classes for each doubling in size, which limits internal fragmentation to
540    approximately 20% for all but the smallest size classes.  Small size classes
541    are smaller than four times the page size, large size classes are smaller
542    than the chunk size (see the <link
543    linkend="opt.lg_chunk"><mallctl>opt.lg_chunk</mallctl></link> option), and
544    huge size classes extend from the chunk size up to the largest size class
545    that does not exceed <constant>PTRDIFF_MAX</constant>.</para>
546
547    <para>Allocations are packed tightly together, which can be an issue for
548    multi-threaded applications.  If you need to assure that allocations do not
549    suffer from cacheline sharing, round your allocation requests up to the
550    nearest multiple of the cacheline size, or specify cacheline alignment when
551    allocating.</para>
552
553    <para>The <function>realloc()</function>,
554    <function>rallocx()</function>, and
555    <function>xallocx()</function> functions may resize allocations
556    without moving them under limited circumstances.  Unlike the
557    <function>*allocx()</function> API, the standard API does not
558    officially round up the usable size of an allocation to the nearest size
559    class, so technically it is necessary to call
560    <function>realloc()</function> to grow e.g. a 9-byte allocation to
561    16 bytes, or shrink a 16-byte allocation to 9 bytes.  Growth and shrinkage
562    trivially succeeds in place as long as the pre-size and post-size both round
563    up to the same size class.  No other API guarantees are made regarding
564    in-place resizing, but the current implementation also tries to resize large
565    and huge allocations in place, as long as the pre-size and post-size are
566    both large or both huge.  In such cases shrinkage always succeeds for large
567    size classes, but for huge size classes the chunk allocator must support
568    splitting (see <link
569    linkend="arena.i.chunk_hooks"><mallctl>arena.&lt;i&gt;.chunk_hooks</mallctl></link>).
570    Growth only succeeds if the trailing memory is currently available, and
571    additionally for huge size classes the chunk allocator must support
572    merging.</para>
573
574    <para>Assuming 2 MiB chunks, 4 KiB pages, and a 16-byte quantum on a
575    64-bit system, the size classes in each category are as shown in <xref
576    linkend="size_classes" xrefstyle="template:Table %n"/>.</para>
577
578    <table xml:id="size_classes" frame="all">
579      <title>Size classes</title>
580      <tgroup cols="3" colsep="1" rowsep="1">
581      <colspec colname="c1" align="left"/>
582      <colspec colname="c2" align="right"/>
583      <colspec colname="c3" align="left"/>
584      <thead>
585        <row>
586          <entry>Category</entry>
587          <entry>Spacing</entry>
588          <entry>Size</entry>
589        </row>
590      </thead>
591      <tbody>
592        <row>
593          <entry morerows="8">Small</entry>
594          <entry>lg</entry>
595          <entry>[8]</entry>
596        </row>
597        <row>
598          <entry>16</entry>
599          <entry>[16, 32, 48, 64, 80, 96, 112, 128]</entry>
600        </row>
601        <row>
602          <entry>32</entry>
603          <entry>[160, 192, 224, 256]</entry>
604        </row>
605        <row>
606          <entry>64</entry>
607          <entry>[320, 384, 448, 512]</entry>
608        </row>
609        <row>
610          <entry>128</entry>
611          <entry>[640, 768, 896, 1024]</entry>
612        </row>
613        <row>
614          <entry>256</entry>
615          <entry>[1280, 1536, 1792, 2048]</entry>
616        </row>
617        <row>
618          <entry>512</entry>
619          <entry>[2560, 3072, 3584, 4096]</entry>
620        </row>
621        <row>
622          <entry>1 KiB</entry>
623          <entry>[5 KiB, 6 KiB, 7 KiB, 8 KiB]</entry>
624        </row>
625        <row>
626          <entry>2 KiB</entry>
627          <entry>[10 KiB, 12 KiB, 14 KiB]</entry>
628        </row>
629        <row>
630          <entry morerows="7">Large</entry>
631          <entry>2 KiB</entry>
632          <entry>[16 KiB]</entry>
633        </row>
634        <row>
635          <entry>4 KiB</entry>
636          <entry>[20 KiB, 24 KiB, 28 KiB, 32 KiB]</entry>
637        </row>
638        <row>
639          <entry>8 KiB</entry>
640          <entry>[40 KiB, 48 KiB, 54 KiB, 64 KiB]</entry>
641        </row>
642        <row>
643          <entry>16 KiB</entry>
644          <entry>[80 KiB, 96 KiB, 112 KiB, 128 KiB]</entry>
645        </row>
646        <row>
647          <entry>32 KiB</entry>
648          <entry>[160 KiB, 192 KiB, 224 KiB, 256 KiB]</entry>
649        </row>
650        <row>
651          <entry>64 KiB</entry>
652          <entry>[320 KiB, 384 KiB, 448 KiB, 512 KiB]</entry>
653        </row>
654        <row>
655          <entry>128 KiB</entry>
656          <entry>[640 KiB, 768 KiB, 896 KiB, 1 MiB]</entry>
657        </row>
658        <row>
659          <entry>256 KiB</entry>
660          <entry>[1280 KiB, 1536 KiB, 1792 KiB]</entry>
661        </row>
662        <row>
663          <entry morerows="8">Huge</entry>
664          <entry>256 KiB</entry>
665          <entry>[2 MiB]</entry>
666        </row>
667        <row>
668          <entry>512 KiB</entry>
669          <entry>[2560 KiB, 3 MiB, 3584 KiB, 4 MiB]</entry>
670        </row>
671        <row>
672          <entry>1 MiB</entry>
673          <entry>[5 MiB, 6 MiB, 7 MiB, 8 MiB]</entry>
674        </row>
675        <row>
676          <entry>2 MiB</entry>
677          <entry>[10 MiB, 12 MiB, 14 MiB, 16 MiB]</entry>
678        </row>
679        <row>
680          <entry>4 MiB</entry>
681          <entry>[20 MiB, 24 MiB, 28 MiB, 32 MiB]</entry>
682        </row>
683        <row>
684          <entry>8 MiB</entry>
685          <entry>[40 MiB, 48 MiB, 56 MiB, 64 MiB]</entry>
686        </row>
687        <row>
688          <entry>...</entry>
689          <entry>...</entry>
690        </row>
691        <row>
692          <entry>512 PiB</entry>
693          <entry>[2560 PiB, 3 EiB, 3584 PiB, 4 EiB]</entry>
694        </row>
695        <row>
696          <entry>1 EiB</entry>
697          <entry>[5 EiB, 6 EiB, 7 EiB]</entry>
698        </row>
699      </tbody>
700      </tgroup>
701    </table>
702  </refsect1>
703  <refsect1 id="mallctl_namespace">
704    <title>MALLCTL NAMESPACE</title>
705    <para>The following names are defined in the namespace accessible via the
706    <function>mallctl*()</function> functions.  Value types are
707    specified in parentheses, their readable/writable statuses are encoded as
708    <literal>rw</literal>, <literal>r-</literal>, <literal>-w</literal>, or
709    <literal>--</literal>, and required build configuration flags follow, if
710    any.  A name element encoded as <literal>&lt;i&gt;</literal> or
711    <literal>&lt;j&gt;</literal> indicates an integer component, where the
712    integer varies from 0 to some upper value that must be determined via
713    introspection.  In the case of <mallctl>stats.arenas.&lt;i&gt;.*</mallctl>,
714    <literal>&lt;i&gt;</literal> equal to <link
715    linkend="arenas.narenas"><mallctl>arenas.narenas</mallctl></link> can be
716    used to access the summation of statistics from all arenas.  Take special
717    note of the <link linkend="epoch"><mallctl>epoch</mallctl></link> mallctl,
718    which controls refreshing of cached dynamic statistics.</para>
719
720    <variablelist>
721      <varlistentry id="version">
722        <term>
723          <mallctl>version</mallctl>
724          (<type>const char *</type>)
725          <literal>r-</literal>
726        </term>
727        <listitem><para>Return the jemalloc version string.</para></listitem>
728      </varlistentry>
729
730      <varlistentry id="epoch">
731        <term>
732          <mallctl>epoch</mallctl>
733          (<type>uint64_t</type>)
734          <literal>rw</literal>
735        </term>
736        <listitem><para>If a value is passed in, refresh the data from which
737        the <function>mallctl*()</function> functions report values,
738        and increment the epoch.  Return the current epoch.  This is useful for
739        detecting whether another thread caused a refresh.</para></listitem>
740      </varlistentry>
741
742      <varlistentry id="config.cache_oblivious">
743        <term>
744          <mallctl>config.cache_oblivious</mallctl>
745          (<type>bool</type>)
746          <literal>r-</literal>
747        </term>
748        <listitem><para><option>--enable-cache-oblivious</option> was specified
749        during build configuration.</para></listitem>
750      </varlistentry>
751
752      <varlistentry id="config.debug">
753        <term>
754          <mallctl>config.debug</mallctl>
755          (<type>bool</type>)
756          <literal>r-</literal>
757        </term>
758        <listitem><para><option>--enable-debug</option> was specified during
759        build configuration.</para></listitem>
760      </varlistentry>
761
762      <varlistentry id="config.fill">
763        <term>
764          <mallctl>config.fill</mallctl>
765          (<type>bool</type>)
766          <literal>r-</literal>
767        </term>
768        <listitem><para><option>--enable-fill</option> was specified during
769        build configuration.</para></listitem>
770      </varlistentry>
771
772      <varlistentry id="config.lazy_lock">
773        <term>
774          <mallctl>config.lazy_lock</mallctl>
775          (<type>bool</type>)
776          <literal>r-</literal>
777        </term>
778        <listitem><para><option>--enable-lazy-lock</option> was specified
779        during build configuration.</para></listitem>
780      </varlistentry>
781
782      <varlistentry id="config.malloc_conf">
783        <term>
784          <mallctl>config.malloc_conf</mallctl>
785          (<type>const char *</type>)
786          <literal>r-</literal>
787        </term>
788        <listitem><para>Embedded configure-time-specified run-time options
789        string, empty unless <option>--with-malloc-conf</option> was specified
790        during build configuration.</para></listitem>
791      </varlistentry>
792
793      <varlistentry id="config.munmap">
794        <term>
795          <mallctl>config.munmap</mallctl>
796          (<type>bool</type>)
797          <literal>r-</literal>
798        </term>
799        <listitem><para><option>--enable-munmap</option> was specified during
800        build configuration.</para></listitem>
801      </varlistentry>
802
803      <varlistentry id="config.prof">
804        <term>
805          <mallctl>config.prof</mallctl>
806          (<type>bool</type>)
807          <literal>r-</literal>
808        </term>
809        <listitem><para><option>--enable-prof</option> was specified during
810        build configuration.</para></listitem>
811      </varlistentry>
812
813      <varlistentry id="config.prof_libgcc">
814        <term>
815          <mallctl>config.prof_libgcc</mallctl>
816          (<type>bool</type>)
817          <literal>r-</literal>
818        </term>
819        <listitem><para><option>--disable-prof-libgcc</option> was not
820        specified during build configuration.</para></listitem>
821      </varlistentry>
822
823      <varlistentry id="config.prof_libunwind">
824        <term>
825          <mallctl>config.prof_libunwind</mallctl>
826          (<type>bool</type>)
827          <literal>r-</literal>
828        </term>
829        <listitem><para><option>--enable-prof-libunwind</option> was specified
830        during build configuration.</para></listitem>
831      </varlistentry>
832
833      <varlistentry id="config.stats">
834        <term>
835          <mallctl>config.stats</mallctl>
836          (<type>bool</type>)
837          <literal>r-</literal>
838        </term>
839        <listitem><para><option>--enable-stats</option> was specified during
840        build configuration.</para></listitem>
841      </varlistentry>
842
843      <varlistentry id="config.tcache">
844        <term>
845          <mallctl>config.tcache</mallctl>
846          (<type>bool</type>)
847          <literal>r-</literal>
848        </term>
849        <listitem><para><option>--disable-tcache</option> was not specified
850        during build configuration.</para></listitem>
851      </varlistentry>
852
853      <varlistentry id="config.tls">
854        <term>
855          <mallctl>config.tls</mallctl>
856          (<type>bool</type>)
857          <literal>r-</literal>
858        </term>
859        <listitem><para><option>--disable-tls</option> was not specified during
860        build configuration.</para></listitem>
861      </varlistentry>
862
863      <varlistentry id="config.utrace">
864        <term>
865          <mallctl>config.utrace</mallctl>
866          (<type>bool</type>)
867          <literal>r-</literal>
868        </term>
869        <listitem><para><option>--enable-utrace</option> was specified during
870        build configuration.</para></listitem>
871      </varlistentry>
872
873      <varlistentry id="config.valgrind">
874        <term>
875          <mallctl>config.valgrind</mallctl>
876          (<type>bool</type>)
877          <literal>r-</literal>
878        </term>
879        <listitem><para><option>--enable-valgrind</option> was specified during
880        build configuration.</para></listitem>
881      </varlistentry>
882
883      <varlistentry id="config.xmalloc">
884        <term>
885          <mallctl>config.xmalloc</mallctl>
886          (<type>bool</type>)
887          <literal>r-</literal>
888        </term>
889        <listitem><para><option>--enable-xmalloc</option> was specified during
890        build configuration.</para></listitem>
891      </varlistentry>
892
893      <varlistentry id="opt.abort">
894        <term>
895          <mallctl>opt.abort</mallctl>
896          (<type>bool</type>)
897          <literal>r-</literal>
898        </term>
899        <listitem><para>Abort-on-warning enabled/disabled.  If true, most
900        warnings are fatal.  The process will call
901        <citerefentry><refentrytitle>abort</refentrytitle>
902        <manvolnum>3</manvolnum></citerefentry> in these cases.  This option is
903        disabled by default unless <option>--enable-debug</option> is
904        specified during configuration, in which case it is enabled by default.
905        </para></listitem>
906      </varlistentry>
907
908      <varlistentry id="opt.dss">
909        <term>
910          <mallctl>opt.dss</mallctl>
911          (<type>const char *</type>)
912          <literal>r-</literal>
913        </term>
914        <listitem><para>dss (<citerefentry><refentrytitle>sbrk</refentrytitle>
915        <manvolnum>2</manvolnum></citerefentry>) allocation precedence as
916        related to <citerefentry><refentrytitle>mmap</refentrytitle>
917        <manvolnum>2</manvolnum></citerefentry> allocation.  The following
918        settings are supported if
919        <citerefentry><refentrytitle>sbrk</refentrytitle>
920        <manvolnum>2</manvolnum></citerefentry> is supported by the operating
921        system: <quote>disabled</quote>, <quote>primary</quote>, and
922        <quote>secondary</quote>; otherwise only <quote>disabled</quote> is
923        supported.  The default is <quote>secondary</quote> if
924        <citerefentry><refentrytitle>sbrk</refentrytitle>
925        <manvolnum>2</manvolnum></citerefentry> is supported by the operating
926        system; <quote>disabled</quote> otherwise.
927        </para></listitem>
928      </varlistentry>
929
930      <varlistentry id="opt.lg_chunk">
931        <term>
932          <mallctl>opt.lg_chunk</mallctl>
933          (<type>size_t</type>)
934          <literal>r-</literal>
935        </term>
936        <listitem><para>Virtual memory chunk size (log base 2).  If a chunk
937        size outside the supported size range is specified, the size is
938        silently clipped to the minimum/maximum supported size.  The default
939        chunk size is 2 MiB (2^21).
940        </para></listitem>
941      </varlistentry>
942
943      <varlistentry id="opt.narenas">
944        <term>
945          <mallctl>opt.narenas</mallctl>
946          (<type>unsigned</type>)
947          <literal>r-</literal>
948        </term>
949        <listitem><para>Maximum number of arenas to use for automatic
950        multiplexing of threads and arenas.  The default is four times the
951        number of CPUs, or one if there is a single CPU.</para></listitem>
952      </varlistentry>
953
954      <varlistentry id="opt.purge">
955        <term>
956          <mallctl>opt.purge</mallctl>
957          (<type>const char *</type>)
958          <literal>r-</literal>
959        </term>
960        <listitem><para>Purge mode is &ldquo;ratio&rdquo; (default) or
961        &ldquo;decay&rdquo;.  See <link
962        linkend="opt.lg_dirty_mult"><mallctl>opt.lg_dirty_mult</mallctl></link>
963        for details of the ratio mode.  See <link
964        linkend="opt.decay_time"><mallctl>opt.decay_time</mallctl></link> for
965        details of the decay mode.</para></listitem>
966      </varlistentry>
967
968      <varlistentry id="opt.lg_dirty_mult">
969        <term>
970          <mallctl>opt.lg_dirty_mult</mallctl>
971          (<type>ssize_t</type>)
972          <literal>r-</literal>
973        </term>
974        <listitem><para>Per-arena minimum ratio (log base 2) of active to dirty
975        pages.  Some dirty unused pages may be allowed to accumulate, within
976        the limit set by the ratio (or one chunk worth of dirty pages,
977        whichever is greater), before informing the kernel about some of those
978        pages via <citerefentry><refentrytitle>madvise</refentrytitle>
979        <manvolnum>2</manvolnum></citerefentry> or a similar system call.  This
980        provides the kernel with sufficient information to recycle dirty pages
981        if physical memory becomes scarce and the pages remain unused.  The
982        default minimum ratio is 8:1 (2^3:1); an option value of -1 will
983        disable dirty page purging.  See <link
984        linkend="arenas.lg_dirty_mult"><mallctl>arenas.lg_dirty_mult</mallctl></link>
985        and <link
986        linkend="arena.i.lg_dirty_mult"><mallctl>arena.&lt;i&gt;.lg_dirty_mult</mallctl></link>
987        for related dynamic control options.</para></listitem>
988      </varlistentry>
989
990      <varlistentry id="opt.decay_time">
991        <term>
992          <mallctl>opt.decay_time</mallctl>
993          (<type>ssize_t</type>)
994          <literal>r-</literal>
995        </term>
996        <listitem><para>Approximate time in seconds from the creation of a set
997        of unused dirty pages until an equivalent set of unused dirty pages is
998        purged and/or reused.  The pages are incrementally purged according to a
999        sigmoidal decay curve that starts and ends with zero purge rate.  A
1000        decay time of 0 causes all unused dirty pages to be purged immediately
1001        upon creation.  A decay time of -1 disables purging.  The default decay
1002        time is 10 seconds.  See <link
1003        linkend="arenas.decay_time"><mallctl>arenas.decay_time</mallctl></link>
1004        and <link
1005        linkend="arena.i.decay_time"><mallctl>arena.&lt;i&gt;.decay_time</mallctl></link>
1006        for related dynamic control options.
1007        </para></listitem>
1008      </varlistentry>
1009
1010      <varlistentry id="opt.stats_print">
1011        <term>
1012          <mallctl>opt.stats_print</mallctl>
1013          (<type>bool</type>)
1014          <literal>r-</literal>
1015        </term>
1016        <listitem><para>Enable/disable statistics printing at exit.  If
1017        enabled, the <function>malloc_stats_print()</function>
1018        function is called at program exit via an
1019        <citerefentry><refentrytitle>atexit</refentrytitle>
1020        <manvolnum>3</manvolnum></citerefentry> function.  If
1021        <option>--enable-stats</option> is specified during configuration, this
1022        has the potential to cause deadlock for a multi-threaded process that
1023        exits while one or more threads are executing in the memory allocation
1024        functions.  Furthermore, <function>atexit()</function> may
1025        allocate memory during application initialization and then deadlock
1026        internally when jemalloc in turn calls
1027        <function>atexit()</function>, so this option is not
1028        universally usable (though the application can register its own
1029        <function>atexit()</function> function with equivalent
1030        functionality).  Therefore, this option should only be used with care;
1031        it is primarily intended as a performance tuning aid during application
1032        development.  This option is disabled by default.</para></listitem>
1033      </varlistentry>
1034
1035      <varlistentry id="opt.junk">
1036        <term>
1037          <mallctl>opt.junk</mallctl>
1038          (<type>const char *</type>)
1039          <literal>r-</literal>
1040          [<option>--enable-fill</option>]
1041        </term>
1042        <listitem><para>Junk filling.  If set to <quote>alloc</quote>, each byte
1043        of uninitialized allocated memory will be initialized to
1044        <literal>0xa5</literal>.  If set to <quote>free</quote>, all deallocated
1045        memory will be initialized to <literal>0x5a</literal>.  If set to
1046        <quote>true</quote>, both allocated and deallocated memory will be
1047        initialized, and if set to <quote>false</quote>, junk filling be
1048        disabled entirely.  This is intended for debugging and will impact
1049        performance negatively.  This option is <quote>false</quote> by default
1050        unless <option>--enable-debug</option> is specified during
1051        configuration, in which case it is <quote>true</quote> by default unless
1052        running inside <ulink
1053        url="http://valgrind.org/">Valgrind</ulink>.</para></listitem>
1054      </varlistentry>
1055
1056      <varlistentry id="opt.quarantine">
1057        <term>
1058          <mallctl>opt.quarantine</mallctl>
1059          (<type>size_t</type>)
1060          <literal>r-</literal>
1061          [<option>--enable-fill</option>]
1062        </term>
1063        <listitem><para>Per thread quarantine size in bytes.  If non-zero, each
1064        thread maintains a FIFO object quarantine that stores up to the
1065        specified number of bytes of memory.  The quarantined memory is not
1066        freed until it is released from quarantine, though it is immediately
1067        junk-filled if the <link
1068        linkend="opt.junk"><mallctl>opt.junk</mallctl></link> option is
1069        enabled.  This feature is of particular use in combination with <ulink
1070        url="http://valgrind.org/">Valgrind</ulink>, which can detect attempts
1071        to access quarantined objects.  This is intended for debugging and will
1072        impact performance negatively.  The default quarantine size is 0 unless
1073        running inside Valgrind, in which case the default is 16
1074        MiB.</para></listitem>
1075      </varlistentry>
1076
1077      <varlistentry id="opt.redzone">
1078        <term>
1079          <mallctl>opt.redzone</mallctl>
1080          (<type>bool</type>)
1081          <literal>r-</literal>
1082          [<option>--enable-fill</option>]
1083        </term>
1084        <listitem><para>Redzones enabled/disabled.  If enabled, small
1085        allocations have redzones before and after them.  Furthermore, if the
1086        <link linkend="opt.junk"><mallctl>opt.junk</mallctl></link> option is
1087        enabled, the redzones are checked for corruption during deallocation.
1088        However, the primary intended purpose of this feature is to be used in
1089        combination with <ulink url="http://valgrind.org/">Valgrind</ulink>,
1090        which needs redzones in order to do effective buffer overflow/underflow
1091        detection.  This option is intended for debugging and will impact
1092        performance negatively.  This option is disabled by
1093        default unless running inside Valgrind.</para></listitem>
1094      </varlistentry>
1095
1096      <varlistentry id="opt.zero">
1097        <term>
1098          <mallctl>opt.zero</mallctl>
1099          (<type>bool</type>)
1100          <literal>r-</literal>
1101          [<option>--enable-fill</option>]
1102        </term>
1103        <listitem><para>Zero filling enabled/disabled.  If enabled, each byte
1104        of uninitialized allocated memory will be initialized to 0.  Note that
1105        this initialization only happens once for each byte, so
1106        <function>realloc()</function> and
1107        <function>rallocx()</function> calls do not zero memory that
1108        was previously allocated.  This is intended for debugging and will
1109        impact performance negatively.  This option is disabled by default.
1110        </para></listitem>
1111      </varlistentry>
1112
1113      <varlistentry id="opt.utrace">
1114        <term>
1115          <mallctl>opt.utrace</mallctl>
1116          (<type>bool</type>)
1117          <literal>r-</literal>
1118          [<option>--enable-utrace</option>]
1119        </term>
1120        <listitem><para>Allocation tracing based on
1121        <citerefentry><refentrytitle>utrace</refentrytitle>
1122        <manvolnum>2</manvolnum></citerefentry> enabled/disabled.  This option
1123        is disabled by default.</para></listitem>
1124      </varlistentry>
1125
1126      <varlistentry id="opt.xmalloc">
1127        <term>
1128          <mallctl>opt.xmalloc</mallctl>
1129          (<type>bool</type>)
1130          <literal>r-</literal>
1131          [<option>--enable-xmalloc</option>]
1132        </term>
1133        <listitem><para>Abort-on-out-of-memory enabled/disabled.  If enabled,
1134        rather than returning failure for any allocation function, display a
1135        diagnostic message on <constant>STDERR_FILENO</constant> and cause the
1136        program to drop core (using
1137        <citerefentry><refentrytitle>abort</refentrytitle>
1138        <manvolnum>3</manvolnum></citerefentry>).  If an application is
1139        designed to depend on this behavior, set the option at compile time by
1140        including the following in the source code:
1141        <programlisting language="C"><![CDATA[
1142malloc_conf = "xmalloc:true";]]></programlisting>
1143        This option is disabled by default.</para></listitem>
1144      </varlistentry>
1145
1146      <varlistentry id="opt.tcache">
1147        <term>
1148          <mallctl>opt.tcache</mallctl>
1149          (<type>bool</type>)
1150          <literal>r-</literal>
1151          [<option>--enable-tcache</option>]
1152        </term>
1153        <listitem><para>Thread-specific caching (tcache) enabled/disabled.  When
1154        there are multiple threads, each thread uses a tcache for objects up to
1155        a certain size.  Thread-specific caching allows many allocations to be
1156        satisfied without performing any thread synchronization, at the cost of
1157        increased memory use.  See the <link
1158        linkend="opt.lg_tcache_max"><mallctl>opt.lg_tcache_max</mallctl></link>
1159        option for related tuning information.  This option is enabled by
1160        default unless running inside <ulink
1161        url="http://valgrind.org/">Valgrind</ulink>, in which case it is
1162        forcefully disabled.</para></listitem>
1163      </varlistentry>
1164
1165      <varlistentry id="opt.lg_tcache_max">
1166        <term>
1167          <mallctl>opt.lg_tcache_max</mallctl>
1168          (<type>size_t</type>)
1169          <literal>r-</literal>
1170          [<option>--enable-tcache</option>]
1171        </term>
1172        <listitem><para>Maximum size class (log base 2) to cache in the
1173        thread-specific cache (tcache).  At a minimum, all small size classes
1174        are cached, and at a maximum all large size classes are cached.  The
1175        default maximum is 32 KiB (2^15).</para></listitem>
1176      </varlistentry>
1177
1178      <varlistentry id="opt.prof">
1179        <term>
1180          <mallctl>opt.prof</mallctl>
1181          (<type>bool</type>)
1182          <literal>r-</literal>
1183          [<option>--enable-prof</option>]
1184        </term>
1185        <listitem><para>Memory profiling enabled/disabled.  If enabled, profile
1186        memory allocation activity.  See the <link
1187        linkend="opt.prof_active"><mallctl>opt.prof_active</mallctl></link>
1188        option for on-the-fly activation/deactivation.  See the <link
1189        linkend="opt.lg_prof_sample"><mallctl>opt.lg_prof_sample</mallctl></link>
1190        option for probabilistic sampling control.  See the <link
1191        linkend="opt.prof_accum"><mallctl>opt.prof_accum</mallctl></link>
1192        option for control of cumulative sample reporting.  See the <link
1193        linkend="opt.lg_prof_interval"><mallctl>opt.lg_prof_interval</mallctl></link>
1194        option for information on interval-triggered profile dumping, the <link
1195        linkend="opt.prof_gdump"><mallctl>opt.prof_gdump</mallctl></link>
1196        option for information on high-water-triggered profile dumping, and the
1197        <link linkend="opt.prof_final"><mallctl>opt.prof_final</mallctl></link>
1198        option for final profile dumping.  Profile output is compatible with
1199        the <command>jeprof</command> command, which is based on the
1200        <command>pprof</command> that is developed as part of the <ulink
1201        url="http://code.google.com/p/gperftools/">gperftools
1202        package</ulink>.  See <link linkend="heap_profile_format">HEAP PROFILE
1203        FORMAT</link> for heap profile format documentation.</para></listitem>
1204      </varlistentry>
1205
1206      <varlistentry id="opt.prof_prefix">
1207        <term>
1208          <mallctl>opt.prof_prefix</mallctl>
1209          (<type>const char *</type>)
1210          <literal>r-</literal>
1211          [<option>--enable-prof</option>]
1212        </term>
1213        <listitem><para>Filename prefix for profile dumps.  If the prefix is
1214        set to the empty string, no automatic dumps will occur; this is
1215        primarily useful for disabling the automatic final heap dump (which
1216        also disables leak reporting, if enabled).  The default prefix is
1217        <filename>jeprof</filename>.</para></listitem>
1218      </varlistentry>
1219
1220      <varlistentry id="opt.prof_active">
1221        <term>
1222          <mallctl>opt.prof_active</mallctl>
1223          (<type>bool</type>)
1224          <literal>r-</literal>
1225          [<option>--enable-prof</option>]
1226        </term>
1227        <listitem><para>Profiling activated/deactivated.  This is a secondary
1228        control mechanism that makes it possible to start the application with
1229        profiling enabled (see the <link
1230        linkend="opt.prof"><mallctl>opt.prof</mallctl></link> option) but
1231        inactive, then toggle profiling at any time during program execution
1232        with the <link
1233        linkend="prof.active"><mallctl>prof.active</mallctl></link> mallctl.
1234        This option is enabled by default.</para></listitem>
1235      </varlistentry>
1236
1237      <varlistentry id="opt.prof_thread_active_init">
1238        <term>
1239          <mallctl>opt.prof_thread_active_init</mallctl>
1240          (<type>bool</type>)
1241          <literal>r-</literal>
1242          [<option>--enable-prof</option>]
1243        </term>
1244        <listitem><para>Initial setting for <link
1245        linkend="thread.prof.active"><mallctl>thread.prof.active</mallctl></link>
1246        in newly created threads.  The initial setting for newly created threads
1247        can also be changed during execution via the <link
1248        linkend="prof.thread_active_init"><mallctl>prof.thread_active_init</mallctl></link>
1249        mallctl.  This option is enabled by default.</para></listitem>
1250      </varlistentry>
1251
1252      <varlistentry id="opt.lg_prof_sample">
1253        <term>
1254          <mallctl>opt.lg_prof_sample</mallctl>
1255          (<type>size_t</type>)
1256          <literal>r-</literal>
1257          [<option>--enable-prof</option>]
1258        </term>
1259        <listitem><para>Average interval (log base 2) between allocation
1260        samples, as measured in bytes of allocation activity.  Increasing the
1261        sampling interval decreases profile fidelity, but also decreases the
1262        computational overhead.  The default sample interval is 512 KiB (2^19
1263        B).</para></listitem>
1264      </varlistentry>
1265
1266      <varlistentry id="opt.prof_accum">
1267        <term>
1268          <mallctl>opt.prof_accum</mallctl>
1269          (<type>bool</type>)
1270          <literal>r-</literal>
1271          [<option>--enable-prof</option>]
1272        </term>
1273        <listitem><para>Reporting of cumulative object/byte counts in profile
1274        dumps enabled/disabled.  If this option is enabled, every unique
1275        backtrace must be stored for the duration of execution.  Depending on
1276        the application, this can impose a large memory overhead, and the
1277        cumulative counts are not always of interest.  This option is disabled
1278        by default.</para></listitem>
1279      </varlistentry>
1280
1281      <varlistentry id="opt.lg_prof_interval">
1282        <term>
1283          <mallctl>opt.lg_prof_interval</mallctl>
1284          (<type>ssize_t</type>)
1285          <literal>r-</literal>
1286          [<option>--enable-prof</option>]
1287        </term>
1288        <listitem><para>Average interval (log base 2) between memory profile
1289        dumps, as measured in bytes of allocation activity.  The actual
1290        interval between dumps may be sporadic because decentralized allocation
1291        counters are used to avoid synchronization bottlenecks.  Profiles are
1292        dumped to files named according to the pattern
1293        <filename>&lt;prefix&gt;.&lt;pid&gt;.&lt;seq&gt;.i&lt;iseq&gt;.heap</filename>,
1294        where <literal>&lt;prefix&gt;</literal> is controlled by the
1295        <link
1296        linkend="opt.prof_prefix"><mallctl>opt.prof_prefix</mallctl></link>
1297        option.  By default, interval-triggered profile dumping is disabled
1298        (encoded as -1).
1299        </para></listitem>
1300      </varlistentry>
1301
1302      <varlistentry id="opt.prof_gdump">
1303        <term>
1304          <mallctl>opt.prof_gdump</mallctl>
1305          (<type>bool</type>)
1306          <literal>r-</literal>
1307          [<option>--enable-prof</option>]
1308        </term>
1309        <listitem><para>Set the initial state of <link
1310        linkend="prof.gdump"><mallctl>prof.gdump</mallctl></link>, which when
1311        enabled triggers a memory profile dump every time the total virtual
1312        memory exceeds the previous maximum.  This option is disabled by
1313        default.</para></listitem>
1314      </varlistentry>
1315
1316      <varlistentry id="opt.prof_final">
1317        <term>
1318          <mallctl>opt.prof_final</mallctl>
1319          (<type>bool</type>)
1320          <literal>r-</literal>
1321          [<option>--enable-prof</option>]
1322        </term>
1323        <listitem><para>Use an
1324        <citerefentry><refentrytitle>atexit</refentrytitle>
1325        <manvolnum>3</manvolnum></citerefentry> function to dump final memory
1326        usage to a file named according to the pattern
1327        <filename>&lt;prefix&gt;.&lt;pid&gt;.&lt;seq&gt;.f.heap</filename>,
1328        where <literal>&lt;prefix&gt;</literal> is controlled by the <link
1329        linkend="opt.prof_prefix"><mallctl>opt.prof_prefix</mallctl></link>
1330        option.  Note that <function>atexit()</function> may allocate
1331        memory during application initialization and then deadlock internally
1332        when jemalloc in turn calls <function>atexit()</function>, so
1333        this option is not universally usable (though the application can
1334        register its own <function>atexit()</function> function with
1335        equivalent functionality).  This option is disabled by
1336        default.</para></listitem>
1337      </varlistentry>
1338
1339      <varlistentry id="opt.prof_leak">
1340        <term>
1341          <mallctl>opt.prof_leak</mallctl>
1342          (<type>bool</type>)
1343          <literal>r-</literal>
1344          [<option>--enable-prof</option>]
1345        </term>
1346        <listitem><para>Leak reporting enabled/disabled.  If enabled, use an
1347        <citerefentry><refentrytitle>atexit</refentrytitle>
1348        <manvolnum>3</manvolnum></citerefentry> function to report memory leaks
1349        detected by allocation sampling.  See the
1350        <link linkend="opt.prof"><mallctl>opt.prof</mallctl></link> option for
1351        information on analyzing heap profile output.  This option is disabled
1352        by default.</para></listitem>
1353      </varlistentry>
1354
1355      <varlistentry id="thread.arena">
1356        <term>
1357          <mallctl>thread.arena</mallctl>
1358          (<type>unsigned</type>)
1359          <literal>rw</literal>
1360        </term>
1361        <listitem><para>Get or set the arena associated with the calling
1362        thread.  If the specified arena was not initialized beforehand (see the
1363        <link
1364        linkend="arenas.initialized"><mallctl>arenas.initialized</mallctl></link>
1365        mallctl), it will be automatically initialized as a side effect of
1366        calling this interface.</para></listitem>
1367      </varlistentry>
1368
1369      <varlistentry id="thread.allocated">
1370        <term>
1371          <mallctl>thread.allocated</mallctl>
1372          (<type>uint64_t</type>)
1373          <literal>r-</literal>
1374          [<option>--enable-stats</option>]
1375        </term>
1376        <listitem><para>Get the total number of bytes ever allocated by the
1377        calling thread.  This counter has the potential to wrap around; it is
1378        up to the application to appropriately interpret the counter in such
1379        cases.</para></listitem>
1380      </varlistentry>
1381
1382      <varlistentry id="thread.allocatedp">
1383        <term>
1384          <mallctl>thread.allocatedp</mallctl>
1385          (<type>uint64_t *</type>)
1386          <literal>r-</literal>
1387          [<option>--enable-stats</option>]
1388        </term>
1389        <listitem><para>Get a pointer to the the value that is returned by the
1390        <link
1391        linkend="thread.allocated"><mallctl>thread.allocated</mallctl></link>
1392        mallctl.  This is useful for avoiding the overhead of repeated
1393        <function>mallctl*()</function> calls.</para></listitem>
1394      </varlistentry>
1395
1396      <varlistentry id="thread.deallocated">
1397        <term>
1398          <mallctl>thread.deallocated</mallctl>
1399          (<type>uint64_t</type>)
1400          <literal>r-</literal>
1401          [<option>--enable-stats</option>]
1402        </term>
1403        <listitem><para>Get the total number of bytes ever deallocated by the
1404        calling thread.  This counter has the potential to wrap around; it is
1405        up to the application to appropriately interpret the counter in such
1406        cases.</para></listitem>
1407      </varlistentry>
1408
1409      <varlistentry id="thread.deallocatedp">
1410        <term>
1411          <mallctl>thread.deallocatedp</mallctl>
1412          (<type>uint64_t *</type>)
1413          <literal>r-</literal>
1414          [<option>--enable-stats</option>]
1415        </term>
1416        <listitem><para>Get a pointer to the the value that is returned by the
1417        <link
1418        linkend="thread.deallocated"><mallctl>thread.deallocated</mallctl></link>
1419        mallctl.  This is useful for avoiding the overhead of repeated
1420        <function>mallctl*()</function> calls.</para></listitem>
1421      </varlistentry>
1422
1423      <varlistentry id="thread.tcache.enabled">
1424        <term>
1425          <mallctl>thread.tcache.enabled</mallctl>
1426          (<type>bool</type>)
1427          <literal>rw</literal>
1428          [<option>--enable-tcache</option>]
1429        </term>
1430        <listitem><para>Enable/disable calling thread's tcache.  The tcache is
1431        implicitly flushed as a side effect of becoming
1432        disabled (see <link
1433        linkend="thread.tcache.flush"><mallctl>thread.tcache.flush</mallctl></link>).
1434        </para></listitem>
1435      </varlistentry>
1436
1437      <varlistentry id="thread.tcache.flush">
1438        <term>
1439          <mallctl>thread.tcache.flush</mallctl>
1440          (<type>void</type>)
1441          <literal>--</literal>
1442          [<option>--enable-tcache</option>]
1443        </term>
1444        <listitem><para>Flush calling thread's thread-specific cache (tcache).
1445        This interface releases all cached objects and internal data structures
1446        associated with the calling thread's tcache.  Ordinarily, this interface
1447        need not be called, since automatic periodic incremental garbage
1448        collection occurs, and the thread cache is automatically discarded when
1449        a thread exits.  However, garbage collection is triggered by allocation
1450        activity, so it is possible for a thread that stops
1451        allocating/deallocating to retain its cache indefinitely, in which case
1452        the developer may find manual flushing useful.</para></listitem>
1453      </varlistentry>
1454
1455      <varlistentry id="thread.prof.name">
1456        <term>
1457          <mallctl>thread.prof.name</mallctl>
1458          (<type>const char *</type>)
1459          <literal>r-</literal> or
1460          <literal>-w</literal>
1461          [<option>--enable-prof</option>]
1462        </term>
1463        <listitem><para>Get/set the descriptive name associated with the calling
1464        thread in memory profile dumps.  An internal copy of the name string is
1465        created, so the input string need not be maintained after this interface
1466        completes execution.  The output string of this interface should be
1467        copied for non-ephemeral uses, because multiple implementation details
1468        can cause asynchronous string deallocation.  Furthermore, each
1469        invocation of this interface can only read or write; simultaneous
1470        read/write is not supported due to string lifetime limitations.  The
1471        name string must be nil-terminated and comprised only of characters in
1472        the sets recognized
1473        by <citerefentry><refentrytitle>isgraph</refentrytitle>
1474        <manvolnum>3</manvolnum></citerefentry> and
1475        <citerefentry><refentrytitle>isblank</refentrytitle>
1476        <manvolnum>3</manvolnum></citerefentry>.</para></listitem>
1477      </varlistentry>
1478
1479      <varlistentry id="thread.prof.active">
1480        <term>
1481          <mallctl>thread.prof.active</mallctl>
1482          (<type>bool</type>)
1483          <literal>rw</literal>
1484          [<option>--enable-prof</option>]
1485        </term>
1486        <listitem><para>Control whether sampling is currently active for the
1487        calling thread.  This is an activation mechanism in addition to <link
1488        linkend="prof.active"><mallctl>prof.active</mallctl></link>; both must
1489        be active for the calling thread to sample.  This flag is enabled by
1490        default.</para></listitem>
1491      </varlistentry>
1492
1493      <varlistentry id="tcache.create">
1494        <term>
1495          <mallctl>tcache.create</mallctl>
1496          (<type>unsigned</type>)
1497          <literal>r-</literal>
1498          [<option>--enable-tcache</option>]
1499        </term>
1500        <listitem><para>Create an explicit thread-specific cache (tcache) and
1501        return an identifier that can be passed to the <link
1502        linkend="MALLOCX_TCACHE"><constant>MALLOCX_TCACHE(<parameter>tc</parameter>)</constant></link>
1503        macro to explicitly use the specified cache rather than the
1504        automatically managed one that is used by default.  Each explicit cache
1505        can be used by only one thread at a time; the application must assure
1506        that this constraint holds.
1507        </para></listitem>
1508      </varlistentry>
1509
1510      <varlistentry id="tcache.flush">
1511        <term>
1512          <mallctl>tcache.flush</mallctl>
1513          (<type>unsigned</type>)
1514          <literal>-w</literal>
1515          [<option>--enable-tcache</option>]
1516        </term>
1517        <listitem><para>Flush the specified thread-specific cache (tcache).  The
1518        same considerations apply to this interface as to <link
1519        linkend="thread.tcache.flush"><mallctl>thread.tcache.flush</mallctl></link>,
1520        except that the tcache will never be automatically discarded.
1521        </para></listitem>
1522      </varlistentry>
1523
1524      <varlistentry id="tcache.destroy">
1525        <term>
1526          <mallctl>tcache.destroy</mallctl>
1527          (<type>unsigned</type>)
1528          <literal>-w</literal>
1529          [<option>--enable-tcache</option>]
1530        </term>
1531        <listitem><para>Flush the specified thread-specific cache (tcache) and
1532        make the identifier available for use during a future tcache creation.
1533        </para></listitem>
1534      </varlistentry>
1535
1536      <varlistentry id="arena.i.purge">
1537        <term>
1538          <mallctl>arena.&lt;i&gt;.purge</mallctl>
1539          (<type>void</type>)
1540          <literal>--</literal>
1541        </term>
1542        <listitem><para>Purge all unused dirty pages for arena &lt;i&gt;, or for
1543        all arenas if &lt;i&gt; equals <link
1544        linkend="arenas.narenas"><mallctl>arenas.narenas</mallctl></link>.
1545        </para></listitem>
1546      </varlistentry>
1547
1548      <varlistentry id="arena.i.decay">
1549        <term>
1550          <mallctl>arena.&lt;i&gt;.decay</mallctl>
1551          (<type>void</type>)
1552          <literal>--</literal>
1553        </term>
1554        <listitem><para>Trigger decay-based purging of unused dirty pages for
1555        arena &lt;i&gt;, or for all arenas if &lt;i&gt; equals <link
1556        linkend="arenas.narenas"><mallctl>arenas.narenas</mallctl></link>.
1557        The proportion of unused dirty pages to be purged depends on the current
1558        time; see <link
1559        linkend="opt.decay_time"><mallctl>opt.decay_time</mallctl></link> for
1560        details.</para></listitem>
1561      </varlistentry>
1562
1563      <varlistentry id="arena.i.reset">
1564        <term>
1565          <mallctl>arena.&lt;i&gt;.reset</mallctl>
1566          (<type>void</type>)
1567          <literal>--</literal>
1568        </term>
1569        <listitem><para>Discard all of the arena's extant allocations.  This
1570        interface can only be used with arenas created via <link
1571        linkend="arenas.extend"><mallctl>arenas.extend</mallctl></link>.  None
1572        of the arena's discarded/cached allocations may accessed afterward.  As
1573        part of this requirement, all thread caches which were used to
1574        allocate/deallocate in conjunction with the arena must be flushed
1575        beforehand.  This interface cannot be used if running inside Valgrind,
1576        nor if the <link linkend="opt.quarantine">quarantine</link> size is
1577        non-zero.</para></listitem>
1578      </varlistentry>
1579
1580      <varlistentry id="arena.i.dss">
1581        <term>
1582          <mallctl>arena.&lt;i&gt;.dss</mallctl>
1583          (<type>const char *</type>)
1584          <literal>rw</literal>
1585        </term>
1586        <listitem><para>Set the precedence of dss allocation as related to mmap
1587        allocation for arena &lt;i&gt;, or for all arenas if &lt;i&gt; equals
1588        <link
1589        linkend="arenas.narenas"><mallctl>arenas.narenas</mallctl></link>.  See
1590        <link linkend="opt.dss"><mallctl>opt.dss</mallctl></link> for supported
1591        settings.</para></listitem>
1592      </varlistentry>
1593
1594      <varlistentry id="arena.i.lg_dirty_mult">
1595        <term>
1596          <mallctl>arena.&lt;i&gt;.lg_dirty_mult</mallctl>
1597          (<type>ssize_t</type>)
1598          <literal>rw</literal>
1599        </term>
1600        <listitem><para>Current per-arena minimum ratio (log base 2) of active
1601        to dirty pages for arena &lt;i&gt;.  Each time this interface is set and
1602        the ratio is increased, pages are synchronously purged as necessary to
1603        impose the new ratio.  See <link
1604        linkend="opt.lg_dirty_mult"><mallctl>opt.lg_dirty_mult</mallctl></link>
1605        for additional information.</para></listitem>
1606      </varlistentry>
1607
1608      <varlistentry id="arena.i.decay_time">
1609        <term>
1610          <mallctl>arena.&lt;i&gt;.decay_time</mallctl>
1611          (<type>ssize_t</type>)
1612          <literal>rw</literal>
1613        </term>
1614        <listitem><para>Current per-arena approximate time in seconds from the
1615        creation of a set of unused dirty pages until an equivalent set of
1616        unused dirty pages is purged and/or reused.  Each time this interface is
1617        set, all currently unused dirty pages are considered to have fully
1618        decayed, which causes immediate purging of all unused dirty pages unless
1619        the decay time is set to -1 (i.e. purging disabled).  See <link
1620        linkend="opt.decay_time"><mallctl>opt.decay_time</mallctl></link> for
1621        additional information.</para></listitem>
1622      </varlistentry>
1623
1624      <varlistentry id="arena.i.chunk_hooks">
1625        <term>
1626          <mallctl>arena.&lt;i&gt;.chunk_hooks</mallctl>
1627          (<type>chunk_hooks_t</type>)
1628          <literal>rw</literal>
1629        </term>
1630        <listitem><para>Get or set the chunk management hook functions for arena
1631        &lt;i&gt;.  The functions must be capable of operating on all extant
1632        chunks associated with arena &lt;i&gt;, usually by passing unknown
1633        chunks to the replaced functions.  In practice, it is feasible to
1634        control allocation for arenas created via <link
1635        linkend="arenas.extend"><mallctl>arenas.extend</mallctl></link> such
1636        that all chunks originate from an application-supplied chunk allocator
1637        (by setting custom chunk hook functions just after arena creation), but
1638        the automatically created arenas may have already created chunks prior
1639        to the application having an opportunity to take over chunk
1640        allocation.</para>
1641
1642        <programlisting language="C"><![CDATA[
1643typedef struct {
1644	chunk_alloc_t		*alloc;
1645	chunk_dalloc_t		*dalloc;
1646	chunk_commit_t		*commit;
1647	chunk_decommit_t	*decommit;
1648	chunk_purge_t		*purge;
1649	chunk_split_t		*split;
1650	chunk_merge_t		*merge;
1651} chunk_hooks_t;]]></programlisting>
1652        <para>The <type>chunk_hooks_t</type> structure comprises function
1653        pointers which are described individually below.  jemalloc uses these
1654        functions to manage chunk lifetime, which starts off with allocation of
1655        mapped committed memory, in the simplest case followed by deallocation.
1656        However, there are performance and platform reasons to retain chunks for
1657        later reuse.  Cleanup attempts cascade from deallocation to decommit to
1658        purging, which gives the chunk management functions opportunities to
1659        reject the most permanent cleanup operations in favor of less permanent
1660        (and often less costly) operations.  The chunk splitting and merging
1661        operations can also be opted out of, but this is mainly intended to
1662        support platforms on which virtual memory mappings provided by the
1663        operating system kernel do not automatically coalesce and split, e.g.
1664        Windows.</para>
1665
1666        <funcsynopsis><funcprototype>
1667          <funcdef>typedef void *<function>(chunk_alloc_t)</function></funcdef>
1668          <paramdef>void *<parameter>chunk</parameter></paramdef>
1669          <paramdef>size_t <parameter>size</parameter></paramdef>
1670          <paramdef>size_t <parameter>alignment</parameter></paramdef>
1671          <paramdef>bool *<parameter>zero</parameter></paramdef>
1672          <paramdef>bool *<parameter>commit</parameter></paramdef>
1673          <paramdef>unsigned <parameter>arena_ind</parameter></paramdef>
1674        </funcprototype></funcsynopsis>
1675        <literallayout></literallayout>
1676        <para>A chunk allocation function conforms to the
1677        <type>chunk_alloc_t</type> type and upon success returns a pointer to
1678        <parameter>size</parameter> bytes of mapped memory on behalf of arena
1679        <parameter>arena_ind</parameter> such that the chunk's base address is a
1680        multiple of <parameter>alignment</parameter>, as well as setting
1681        <parameter>*zero</parameter> to indicate whether the chunk is zeroed and
1682        <parameter>*commit</parameter> to indicate whether the chunk is
1683        committed.  Upon error the function returns <constant>NULL</constant>
1684        and leaves <parameter>*zero</parameter> and
1685        <parameter>*commit</parameter> unmodified.  The
1686        <parameter>size</parameter> parameter is always a multiple of the chunk
1687        size.  The <parameter>alignment</parameter> parameter is always a power
1688        of two at least as large as the chunk size.  Zeroing is mandatory if
1689        <parameter>*zero</parameter> is true upon function entry.  Committing is
1690        mandatory if <parameter>*commit</parameter> is true upon function entry.
1691        If <parameter>chunk</parameter> is not <constant>NULL</constant>, the
1692        returned pointer must be <parameter>chunk</parameter> on success or
1693        <constant>NULL</constant> on error.  Committed memory may be committed
1694        in absolute terms as on a system that does not overcommit, or in
1695        implicit terms as on a system that overcommits and satisfies physical
1696        memory needs on demand via soft page faults.  Note that replacing the
1697        default chunk allocation function makes the arena's <link
1698        linkend="arena.i.dss"><mallctl>arena.&lt;i&gt;.dss</mallctl></link>
1699        setting irrelevant.</para>
1700
1701        <funcsynopsis><funcprototype>
1702          <funcdef>typedef bool <function>(chunk_dalloc_t)</function></funcdef>
1703          <paramdef>void *<parameter>chunk</parameter></paramdef>
1704          <paramdef>size_t <parameter>size</parameter></paramdef>
1705          <paramdef>bool <parameter>committed</parameter></paramdef>
1706          <paramdef>unsigned <parameter>arena_ind</parameter></paramdef>
1707        </funcprototype></funcsynopsis>
1708        <literallayout></literallayout>
1709        <para>
1710        A chunk deallocation function conforms to the
1711        <type>chunk_dalloc_t</type> type and deallocates a
1712        <parameter>chunk</parameter> of given <parameter>size</parameter> with
1713        <parameter>committed</parameter>/decommited memory as indicated, on
1714        behalf of arena <parameter>arena_ind</parameter>, returning false upon
1715        success.  If the function returns true, this indicates opt-out from
1716        deallocation; the virtual memory mapping associated with the chunk
1717        remains mapped, in the same commit state, and available for future use,
1718        in which case it will be automatically retained for later reuse.</para>
1719
1720        <funcsynopsis><funcprototype>
1721          <funcdef>typedef bool <function>(chunk_commit_t)</function></funcdef>
1722          <paramdef>void *<parameter>chunk</parameter></paramdef>
1723          <paramdef>size_t <parameter>size</parameter></paramdef>
1724          <paramdef>size_t <parameter>offset</parameter></paramdef>
1725          <paramdef>size_t <parameter>length</parameter></paramdef>
1726          <paramdef>unsigned <parameter>arena_ind</parameter></paramdef>
1727        </funcprototype></funcsynopsis>
1728        <literallayout></literallayout>
1729        <para>A chunk commit function conforms to the
1730        <type>chunk_commit_t</type> type and commits zeroed physical memory to
1731        back pages within a <parameter>chunk</parameter> of given
1732        <parameter>size</parameter> at <parameter>offset</parameter> bytes,
1733        extending for <parameter>length</parameter> on behalf of arena
1734        <parameter>arena_ind</parameter>, returning false upon success.
1735        Committed memory may be committed in absolute terms as on a system that
1736        does not overcommit, or in implicit terms as on a system that
1737        overcommits and satisfies physical memory needs on demand via soft page
1738        faults. If the function returns true, this indicates insufficient
1739        physical memory to satisfy the request.</para>
1740
1741        <funcsynopsis><funcprototype>
1742          <funcdef>typedef bool <function>(chunk_decommit_t)</function></funcdef>
1743          <paramdef>void *<parameter>chunk</parameter></paramdef>
1744          <paramdef>size_t <parameter>size</parameter></paramdef>
1745          <paramdef>size_t <parameter>offset</parameter></paramdef>
1746          <paramdef>size_t <parameter>length</parameter></paramdef>
1747          <paramdef>unsigned <parameter>arena_ind</parameter></paramdef>
1748        </funcprototype></funcsynopsis>
1749        <literallayout></literallayout>
1750        <para>A chunk decommit function conforms to the
1751        <type>chunk_decommit_t</type> type and decommits any physical memory
1752        that is backing pages within a <parameter>chunk</parameter> of given
1753        <parameter>size</parameter> at <parameter>offset</parameter> bytes,
1754        extending for <parameter>length</parameter> on behalf of arena
1755        <parameter>arena_ind</parameter>, returning false upon success, in which
1756        case the pages will be committed via the chunk commit function before
1757        being reused.  If the function returns true, this indicates opt-out from
1758        decommit; the memory remains committed and available for future use, in
1759        which case it will be automatically retained for later reuse.</para>
1760
1761        <funcsynopsis><funcprototype>
1762          <funcdef>typedef bool <function>(chunk_purge_t)</function></funcdef>
1763          <paramdef>void *<parameter>chunk</parameter></paramdef>
1764          <paramdef>size_t<parameter>size</parameter></paramdef>
1765          <paramdef>size_t <parameter>offset</parameter></paramdef>
1766          <paramdef>size_t <parameter>length</parameter></paramdef>
1767          <paramdef>unsigned <parameter>arena_ind</parameter></paramdef>
1768        </funcprototype></funcsynopsis>
1769        <literallayout></literallayout>
1770        <para>A chunk purge function conforms to the <type>chunk_purge_t</type>
1771        type and optionally discards physical pages within the virtual memory
1772        mapping associated with <parameter>chunk</parameter> of given
1773        <parameter>size</parameter> at <parameter>offset</parameter> bytes,
1774        extending for <parameter>length</parameter> on behalf of arena
1775        <parameter>arena_ind</parameter>, returning false if pages within the
1776        purged virtual memory range will be zero-filled the next time they are
1777        accessed.</para>
1778
1779        <funcsynopsis><funcprototype>
1780          <funcdef>typedef bool <function>(chunk_split_t)</function></funcdef>
1781          <paramdef>void *<parameter>chunk</parameter></paramdef>
1782          <paramdef>size_t <parameter>size</parameter></paramdef>
1783          <paramdef>size_t <parameter>size_a</parameter></paramdef>
1784          <paramdef>size_t <parameter>size_b</parameter></paramdef>
1785          <paramdef>bool <parameter>committed</parameter></paramdef>
1786          <paramdef>unsigned <parameter>arena_ind</parameter></paramdef>
1787        </funcprototype></funcsynopsis>
1788        <literallayout></literallayout>
1789        <para>A chunk split function conforms to the <type>chunk_split_t</type>
1790        type and optionally splits <parameter>chunk</parameter> of given
1791        <parameter>size</parameter> into two adjacent chunks, the first of
1792        <parameter>size_a</parameter> bytes, and the second of
1793        <parameter>size_b</parameter> bytes, operating on
1794        <parameter>committed</parameter>/decommitted memory as indicated, on
1795        behalf of arena <parameter>arena_ind</parameter>, returning false upon
1796        success.  If the function returns true, this indicates that the chunk
1797        remains unsplit and therefore should continue to be operated on as a
1798        whole.</para>
1799
1800        <funcsynopsis><funcprototype>
1801          <funcdef>typedef bool <function>(chunk_merge_t)</function></funcdef>
1802          <paramdef>void *<parameter>chunk_a</parameter></paramdef>
1803          <paramdef>size_t <parameter>size_a</parameter></paramdef>
1804          <paramdef>void *<parameter>chunk_b</parameter></paramdef>
1805          <paramdef>size_t <parameter>size_b</parameter></paramdef>
1806          <paramdef>bool <parameter>committed</parameter></paramdef>
1807          <paramdef>unsigned <parameter>arena_ind</parameter></paramdef>
1808        </funcprototype></funcsynopsis>
1809        <literallayout></literallayout>
1810        <para>A chunk merge function conforms to the <type>chunk_merge_t</type>
1811        type and optionally merges adjacent chunks,
1812        <parameter>chunk_a</parameter> of given <parameter>size_a</parameter>
1813        and <parameter>chunk_b</parameter> of given
1814        <parameter>size_b</parameter> into one contiguous chunk, operating on
1815        <parameter>committed</parameter>/decommitted memory as indicated, on
1816        behalf of arena <parameter>arena_ind</parameter>, returning false upon
1817        success.  If the function returns true, this indicates that the chunks
1818        remain distinct mappings and therefore should continue to be operated on
1819        independently.</para>
1820        </listitem>
1821      </varlistentry>
1822
1823      <varlistentry id="arenas.narenas">
1824        <term>
1825          <mallctl>arenas.narenas</mallctl>
1826          (<type>unsigned</type>)
1827          <literal>r-</literal>
1828        </term>
1829        <listitem><para>Current limit on number of arenas.</para></listitem>
1830      </varlistentry>
1831
1832      <varlistentry id="arenas.initialized">
1833        <term>
1834          <mallctl>arenas.initialized</mallctl>
1835          (<type>bool *</type>)
1836          <literal>r-</literal>
1837        </term>
1838        <listitem><para>An array of <link
1839        linkend="arenas.narenas"><mallctl>arenas.narenas</mallctl></link>
1840        booleans.  Each boolean indicates whether the corresponding arena is
1841        initialized.</para></listitem>
1842      </varlistentry>
1843
1844      <varlistentry id="arenas.lg_dirty_mult">
1845        <term>
1846          <mallctl>arenas.lg_dirty_mult</mallctl>
1847          (<type>ssize_t</type>)
1848          <literal>rw</literal>
1849        </term>
1850        <listitem><para>Current default per-arena minimum ratio (log base 2) of
1851        active to dirty pages, used to initialize <link
1852        linkend="arena.i.lg_dirty_mult"><mallctl>arena.&lt;i&gt;.lg_dirty_mult</mallctl></link>
1853        during arena creation.  See <link
1854        linkend="opt.lg_dirty_mult"><mallctl>opt.lg_dirty_mult</mallctl></link>
1855        for additional information.</para></listitem>
1856      </varlistentry>
1857
1858      <varlistentry id="arenas.decay_time">
1859        <term>
1860          <mallctl>arenas.decay_time</mallctl>
1861          (<type>ssize_t</type>)
1862          <literal>rw</literal>
1863        </term>
1864        <listitem><para>Current default per-arena approximate time in seconds
1865        from the creation of a set of unused dirty pages until an equivalent set
1866        of unused dirty pages is purged and/or reused, used to initialize <link
1867        linkend="arena.i.decay_time"><mallctl>arena.&lt;i&gt;.decay_time</mallctl></link>
1868        during arena creation.  See <link
1869        linkend="opt.decay_time"><mallctl>opt.decay_time</mallctl></link> for
1870        additional information.</para></listitem>
1871      </varlistentry>
1872
1873      <varlistentry id="arenas.quantum">
1874        <term>
1875          <mallctl>arenas.quantum</mallctl>
1876          (<type>size_t</type>)
1877          <literal>r-</literal>
1878        </term>
1879        <listitem><para>Quantum size.</para></listitem>
1880      </varlistentry>
1881
1882      <varlistentry id="arenas.page">
1883        <term>
1884          <mallctl>arenas.page</mallctl>
1885          (<type>size_t</type>)
1886          <literal>r-</literal>
1887        </term>
1888        <listitem><para>Page size.</para></listitem>
1889      </varlistentry>
1890
1891      <varlistentry id="arenas.tcache_max">
1892        <term>
1893          <mallctl>arenas.tcache_max</mallctl>
1894          (<type>size_t</type>)
1895          <literal>r-</literal>
1896          [<option>--enable-tcache</option>]
1897        </term>
1898        <listitem><para>Maximum thread-cached size class.</para></listitem>
1899      </varlistentry>
1900
1901      <varlistentry id="arenas.nbins">
1902        <term>
1903          <mallctl>arenas.nbins</mallctl>
1904          (<type>unsigned</type>)
1905          <literal>r-</literal>
1906        </term>
1907        <listitem><para>Number of bin size classes.</para></listitem>
1908      </varlistentry>
1909
1910      <varlistentry id="arenas.nhbins">
1911        <term>
1912          <mallctl>arenas.nhbins</mallctl>
1913          (<type>unsigned</type>)
1914          <literal>r-</literal>
1915          [<option>--enable-tcache</option>]
1916        </term>
1917        <listitem><para>Total number of thread cache bin size
1918        classes.</para></listitem>
1919      </varlistentry>
1920
1921      <varlistentry id="arenas.bin.i.size">
1922        <term>
1923          <mallctl>arenas.bin.&lt;i&gt;.size</mallctl>
1924          (<type>size_t</type>)
1925          <literal>r-</literal>
1926        </term>
1927        <listitem><para>Maximum size supported by size class.</para></listitem>
1928      </varlistentry>
1929
1930      <varlistentry id="arenas.bin.i.nregs">
1931        <term>
1932          <mallctl>arenas.bin.&lt;i&gt;.nregs</mallctl>
1933          (<type>uint32_t</type>)
1934          <literal>r-</literal>
1935        </term>
1936        <listitem><para>Number of regions per page run.</para></listitem>
1937      </varlistentry>
1938
1939      <varlistentry id="arenas.bin.i.run_size">
1940        <term>
1941          <mallctl>arenas.bin.&lt;i&gt;.run_size</mallctl>
1942          (<type>size_t</type>)
1943          <literal>r-</literal>
1944        </term>
1945        <listitem><para>Number of bytes per page run.</para></listitem>
1946      </varlistentry>
1947
1948      <varlistentry id="arenas.nlruns">
1949        <term>
1950          <mallctl>arenas.nlruns</mallctl>
1951          (<type>unsigned</type>)
1952          <literal>r-</literal>
1953        </term>
1954        <listitem><para>Total number of large size classes.</para></listitem>
1955      </varlistentry>
1956
1957      <varlistentry id="arenas.lrun.i.size">
1958        <term>
1959          <mallctl>arenas.lrun.&lt;i&gt;.size</mallctl>
1960          (<type>size_t</type>)
1961          <literal>r-</literal>
1962        </term>
1963        <listitem><para>Maximum size supported by this large size
1964        class.</para></listitem>
1965      </varlistentry>
1966
1967      <varlistentry id="arenas.nhchunks">
1968        <term>
1969          <mallctl>arenas.nhchunks</mallctl>
1970          (<type>unsigned</type>)
1971          <literal>r-</literal>
1972        </term>
1973        <listitem><para>Total number of huge size classes.</para></listitem>
1974      </varlistentry>
1975
1976      <varlistentry id="arenas.hchunk.i.size">
1977        <term>
1978          <mallctl>arenas.hchunk.&lt;i&gt;.size</mallctl>
1979          (<type>size_t</type>)
1980          <literal>r-</literal>
1981        </term>
1982        <listitem><para>Maximum size supported by this huge size
1983        class.</para></listitem>
1984      </varlistentry>
1985
1986      <varlistentry id="arenas.extend">
1987        <term>
1988          <mallctl>arenas.extend</mallctl>
1989          (<type>unsigned</type>)
1990          <literal>r-</literal>
1991        </term>
1992        <listitem><para>Extend the array of arenas by appending a new arena,
1993        and returning the new arena index.</para></listitem>
1994      </varlistentry>
1995
1996      <varlistentry id="prof.thread_active_init">
1997        <term>
1998          <mallctl>prof.thread_active_init</mallctl>
1999          (<type>bool</type>)
2000          <literal>rw</literal>
2001          [<option>--enable-prof</option>]
2002        </term>
2003        <listitem><para>Control the initial setting for <link
2004        linkend="thread.prof.active"><mallctl>thread.prof.active</mallctl></link>
2005        in newly created threads.  See the <link
2006        linkend="opt.prof_thread_active_init"><mallctl>opt.prof_thread_active_init</mallctl></link>
2007        option for additional information.</para></listitem>
2008      </varlistentry>
2009
2010      <varlistentry id="prof.active">
2011        <term>
2012          <mallctl>prof.active</mallctl>
2013          (<type>bool</type>)
2014          <literal>rw</literal>
2015          [<option>--enable-prof</option>]
2016        </term>
2017        <listitem><para>Control whether sampling is currently active.  See the
2018        <link
2019        linkend="opt.prof_active"><mallctl>opt.prof_active</mallctl></link>
2020        option for additional information, as well as the interrelated <link
2021        linkend="thread.prof.active"><mallctl>thread.prof.active</mallctl></link>
2022        mallctl.</para></listitem>
2023      </varlistentry>
2024
2025      <varlistentry id="prof.dump">
2026        <term>
2027          <mallctl>prof.dump</mallctl>
2028          (<type>const char *</type>)
2029          <literal>-w</literal>
2030          [<option>--enable-prof</option>]
2031        </term>
2032        <listitem><para>Dump a memory profile to the specified file, or if NULL
2033        is specified, to a file according to the pattern
2034        <filename>&lt;prefix&gt;.&lt;pid&gt;.&lt;seq&gt;.m&lt;mseq&gt;.heap</filename>,
2035        where <literal>&lt;prefix&gt;</literal> is controlled by the
2036        <link
2037        linkend="opt.prof_prefix"><mallctl>opt.prof_prefix</mallctl></link>
2038        option.</para></listitem>
2039      </varlistentry>
2040
2041      <varlistentry id="prof.gdump">
2042        <term>
2043          <mallctl>prof.gdump</mallctl>
2044          (<type>bool</type>)
2045          <literal>rw</literal>
2046          [<option>--enable-prof</option>]
2047        </term>
2048        <listitem><para>When enabled, trigger a memory profile dump every time
2049        the total virtual memory exceeds the previous maximum.  Profiles are
2050        dumped to files named according to the pattern
2051        <filename>&lt;prefix&gt;.&lt;pid&gt;.&lt;seq&gt;.u&lt;useq&gt;.heap</filename>,
2052        where <literal>&lt;prefix&gt;</literal> is controlled by the <link
2053        linkend="opt.prof_prefix"><mallctl>opt.prof_prefix</mallctl></link>
2054        option.</para></listitem>
2055      </varlistentry>
2056
2057      <varlistentry id="prof.reset">
2058        <term>
2059          <mallctl>prof.reset</mallctl>
2060          (<type>size_t</type>)
2061          <literal>-w</literal>
2062          [<option>--enable-prof</option>]
2063        </term>
2064        <listitem><para>Reset all memory profile statistics, and optionally
2065        update the sample rate (see <link
2066        linkend="opt.lg_prof_sample"><mallctl>opt.lg_prof_sample</mallctl></link>
2067        and <link
2068        linkend="prof.lg_sample"><mallctl>prof.lg_sample</mallctl></link>).
2069        </para></listitem>
2070      </varlistentry>
2071
2072      <varlistentry id="prof.lg_sample">
2073        <term>
2074          <mallctl>prof.lg_sample</mallctl>
2075          (<type>size_t</type>)
2076          <literal>r-</literal>
2077          [<option>--enable-prof</option>]
2078        </term>
2079        <listitem><para>Get the current sample rate (see <link
2080        linkend="opt.lg_prof_sample"><mallctl>opt.lg_prof_sample</mallctl></link>).
2081        </para></listitem>
2082      </varlistentry>
2083
2084      <varlistentry id="prof.interval">
2085        <term>
2086          <mallctl>prof.interval</mallctl>
2087          (<type>uint64_t</type>)
2088          <literal>r-</literal>
2089          [<option>--enable-prof</option>]
2090        </term>
2091        <listitem><para>Average number of bytes allocated between
2092        interval-based profile dumps.  See the
2093        <link
2094        linkend="opt.lg_prof_interval"><mallctl>opt.lg_prof_interval</mallctl></link>
2095        option for additional information.</para></listitem>
2096      </varlistentry>
2097
2098      <varlistentry id="stats.cactive">
2099        <term>
2100          <mallctl>stats.cactive</mallctl>
2101          (<type>size_t *</type>)
2102          <literal>r-</literal>
2103          [<option>--enable-stats</option>]
2104        </term>
2105        <listitem><para>Pointer to a counter that contains an approximate count
2106        of the current number of bytes in active pages.  The estimate may be
2107        high, but never low, because each arena rounds up when computing its
2108        contribution to the counter.  Note that the <link
2109        linkend="epoch"><mallctl>epoch</mallctl></link> mallctl has no bearing
2110        on this counter.  Furthermore, counter consistency is maintained via
2111        atomic operations, so it is necessary to use an atomic operation in
2112        order to guarantee a consistent read when dereferencing the pointer.
2113        </para></listitem>
2114      </varlistentry>
2115
2116      <varlistentry id="stats.allocated">
2117        <term>
2118          <mallctl>stats.allocated</mallctl>
2119          (<type>size_t</type>)
2120          <literal>r-</literal>
2121          [<option>--enable-stats</option>]
2122        </term>
2123        <listitem><para>Total number of bytes allocated by the
2124        application.</para></listitem>
2125      </varlistentry>
2126
2127      <varlistentry id="stats.active">
2128        <term>
2129          <mallctl>stats.active</mallctl>
2130          (<type>size_t</type>)
2131          <literal>r-</literal>
2132          [<option>--enable-stats</option>]
2133        </term>
2134        <listitem><para>Total number of bytes in active pages allocated by the
2135        application.  This is a multiple of the page size, and greater than or
2136        equal to <link
2137        linkend="stats.allocated"><mallctl>stats.allocated</mallctl></link>.
2138        This does not include <link linkend="stats.arenas.i.pdirty">
2139        <mallctl>stats.arenas.&lt;i&gt;.pdirty</mallctl></link>, nor pages
2140        entirely devoted to allocator metadata.</para></listitem>
2141      </varlistentry>
2142
2143      <varlistentry id="stats.metadata">
2144        <term>
2145          <mallctl>stats.metadata</mallctl>
2146          (<type>size_t</type>)
2147          <literal>r-</literal>
2148          [<option>--enable-stats</option>]
2149        </term>
2150        <listitem><para>Total number of bytes dedicated to metadata, which
2151        comprise base allocations used for bootstrap-sensitive internal
2152        allocator data structures, arena chunk headers (see <link
2153        linkend="stats.arenas.i.metadata.mapped"><mallctl>stats.arenas.&lt;i&gt;.metadata.mapped</mallctl></link>),
2154        and internal allocations (see <link
2155        linkend="stats.arenas.i.metadata.allocated"><mallctl>stats.arenas.&lt;i&gt;.metadata.allocated</mallctl></link>).</para></listitem>
2156      </varlistentry>
2157
2158      <varlistentry id="stats.resident">
2159        <term>
2160          <mallctl>stats.resident</mallctl>
2161          (<type>size_t</type>)
2162          <literal>r-</literal>
2163          [<option>--enable-stats</option>]
2164        </term>
2165        <listitem><para>Maximum number of bytes in physically resident data
2166        pages mapped by the allocator, comprising all pages dedicated to
2167        allocator metadata, pages backing active allocations, and unused dirty
2168        pages.  This is a maximum rather than precise because pages may not
2169        actually be physically resident if they correspond to demand-zeroed
2170        virtual memory that has not yet been touched.  This is a multiple of the
2171        page size, and is larger than <link
2172        linkend="stats.active"><mallctl>stats.active</mallctl></link>.</para></listitem>
2173      </varlistentry>
2174
2175      <varlistentry id="stats.mapped">
2176        <term>
2177          <mallctl>stats.mapped</mallctl>
2178          (<type>size_t</type>)
2179          <literal>r-</literal>
2180          [<option>--enable-stats</option>]
2181        </term>
2182        <listitem><para>Total number of bytes in active chunks mapped by the
2183        allocator.  This is a multiple of the chunk size, and is larger than
2184        <link linkend="stats.active"><mallctl>stats.active</mallctl></link>.
2185        This does not include inactive chunks, even those that contain unused
2186        dirty pages, which means that there is no strict ordering between this
2187        and <link
2188        linkend="stats.resident"><mallctl>stats.resident</mallctl></link>.</para></listitem>
2189      </varlistentry>
2190
2191      <varlistentry id="stats.retained">
2192        <term>
2193          <mallctl>stats.retained</mallctl>
2194          (<type>size_t</type>)
2195          <literal>r-</literal>
2196          [<option>--enable-stats</option>]
2197        </term>
2198        <listitem><para>Total number of bytes in virtual memory mappings that
2199        were retained rather than being returned to the operating system via
2200        e.g. <citerefentry><refentrytitle>munmap</refentrytitle>
2201        <manvolnum>2</manvolnum></citerefentry>.  Retained virtual memory is
2202        typically untouched, decommitted, or purged, so it has no strongly
2203        associated physical memory (see <link
2204        linkend="arena.i.chunk_hooks">chunk hooks</link> for details).  Retained
2205        memory is excluded from mapped memory statistics, e.g. <link
2206        linkend="stats.mapped"><mallctl>stats.mapped</mallctl></link>.
2207        </para></listitem>
2208      </varlistentry>
2209
2210      <varlistentry id="stats.arenas.i.dss">
2211        <term>
2212          <mallctl>stats.arenas.&lt;i&gt;.dss</mallctl>
2213          (<type>const char *</type>)
2214          <literal>r-</literal>
2215        </term>
2216        <listitem><para>dss (<citerefentry><refentrytitle>sbrk</refentrytitle>
2217        <manvolnum>2</manvolnum></citerefentry>) allocation precedence as
2218        related to <citerefentry><refentrytitle>mmap</refentrytitle>
2219        <manvolnum>2</manvolnum></citerefentry> allocation.  See <link
2220        linkend="opt.dss"><mallctl>opt.dss</mallctl></link> for details.
2221        </para></listitem>
2222      </varlistentry>
2223
2224      <varlistentry id="stats.arenas.i.lg_dirty_mult">
2225        <term>
2226          <mallctl>stats.arenas.&lt;i&gt;.lg_dirty_mult</mallctl>
2227          (<type>ssize_t</type>)
2228          <literal>r-</literal>
2229        </term>
2230        <listitem><para>Minimum ratio (log base 2) of active to dirty pages.
2231        See <link
2232        linkend="opt.lg_dirty_mult"><mallctl>opt.lg_dirty_mult</mallctl></link>
2233        for details.</para></listitem>
2234      </varlistentry>
2235
2236      <varlistentry id="stats.arenas.i.decay_time">
2237        <term>
2238          <mallctl>stats.arenas.&lt;i&gt;.decay_time</mallctl>
2239          (<type>ssize_t</type>)
2240          <literal>r-</literal>
2241        </term>
2242        <listitem><para>Approximate time in seconds from the creation of a set
2243        of unused dirty pages until an equivalent set of unused dirty pages is
2244        purged and/or reused.  See <link
2245        linkend="opt.decay_time"><mallctl>opt.decay_time</mallctl></link>
2246        for details.</para></listitem>
2247      </varlistentry>
2248
2249      <varlistentry id="stats.arenas.i.nthreads">
2250        <term>
2251          <mallctl>stats.arenas.&lt;i&gt;.nthreads</mallctl>
2252          (<type>unsigned</type>)
2253          <literal>r-</literal>
2254        </term>
2255        <listitem><para>Number of threads currently assigned to
2256        arena.</para></listitem>
2257      </varlistentry>
2258
2259      <varlistentry id="stats.arenas.i.pactive">
2260        <term>
2261          <mallctl>stats.arenas.&lt;i&gt;.pactive</mallctl>
2262          (<type>size_t</type>)
2263          <literal>r-</literal>
2264        </term>
2265        <listitem><para>Number of pages in active runs.</para></listitem>
2266      </varlistentry>
2267
2268      <varlistentry id="stats.arenas.i.pdirty">
2269        <term>
2270          <mallctl>stats.arenas.&lt;i&gt;.pdirty</mallctl>
2271          (<type>size_t</type>)
2272          <literal>r-</literal>
2273        </term>
2274        <listitem><para>Number of pages within unused runs that are potentially
2275        dirty, and for which <function>madvise<parameter>...</parameter>
2276        <parameter><constant>MADV_DONTNEED</constant></parameter></function> or
2277        similar has not been called.</para></listitem>
2278      </varlistentry>
2279
2280      <varlistentry id="stats.arenas.i.mapped">
2281        <term>
2282          <mallctl>stats.arenas.&lt;i&gt;.mapped</mallctl>
2283          (<type>size_t</type>)
2284          <literal>r-</literal>
2285          [<option>--enable-stats</option>]
2286        </term>
2287        <listitem><para>Number of mapped bytes.</para></listitem>
2288      </varlistentry>
2289
2290      <varlistentry id="stats.arenas.i.retained">
2291        <term>
2292          <mallctl>stats.arenas.&lt;i&gt;.retained</mallctl>
2293          (<type>size_t</type>)
2294          <literal>r-</literal>
2295          [<option>--enable-stats</option>]
2296        </term>
2297        <listitem><para>Number of retained bytes.  See <link
2298        linkend="stats.retained"><mallctl>stats.retained</mallctl></link> for
2299        details.</para></listitem>
2300      </varlistentry>
2301
2302      <varlistentry id="stats.arenas.i.metadata.mapped">
2303        <term>
2304          <mallctl>stats.arenas.&lt;i&gt;.metadata.mapped</mallctl>
2305          (<type>size_t</type>)
2306          <literal>r-</literal>
2307          [<option>--enable-stats</option>]
2308        </term>
2309        <listitem><para>Number of mapped bytes in arena chunk headers, which
2310        track the states of the non-metadata pages.</para></listitem>
2311      </varlistentry>
2312
2313      <varlistentry id="stats.arenas.i.metadata.allocated">
2314        <term>
2315          <mallctl>stats.arenas.&lt;i&gt;.metadata.allocated</mallctl>
2316          (<type>size_t</type>)
2317          <literal>r-</literal>
2318          [<option>--enable-stats</option>]
2319        </term>
2320        <listitem><para>Number of bytes dedicated to internal allocations.
2321        Internal allocations differ from application-originated allocations in
2322        that they are for internal use, and that they are omitted from heap
2323        profiles.  This statistic is reported separately from <link
2324        linkend="stats.metadata"><mallctl>stats.metadata</mallctl></link> and
2325        <link
2326        linkend="stats.arenas.i.metadata.mapped"><mallctl>stats.arenas.&lt;i&gt;.metadata.mapped</mallctl></link>
2327        because it overlaps with e.g. the <link
2328        linkend="stats.allocated"><mallctl>stats.allocated</mallctl></link> and
2329        <link linkend="stats.active"><mallctl>stats.active</mallctl></link>
2330        statistics, whereas the other metadata statistics do
2331        not.</para></listitem>
2332      </varlistentry>
2333
2334      <varlistentry id="stats.arenas.i.npurge">
2335        <term>
2336          <mallctl>stats.arenas.&lt;i&gt;.npurge</mallctl>
2337          (<type>uint64_t</type>)
2338          <literal>r-</literal>
2339          [<option>--enable-stats</option>]
2340        </term>
2341        <listitem><para>Number of dirty page purge sweeps performed.
2342        </para></listitem>
2343      </varlistentry>
2344
2345      <varlistentry id="stats.arenas.i.nmadvise">
2346        <term>
2347          <mallctl>stats.arenas.&lt;i&gt;.nmadvise</mallctl>
2348          (<type>uint64_t</type>)
2349          <literal>r-</literal>
2350          [<option>--enable-stats</option>]
2351        </term>
2352        <listitem><para>Number of <function>madvise<parameter>...</parameter>
2353        <parameter><constant>MADV_DONTNEED</constant></parameter></function> or
2354        similar calls made to purge dirty pages.</para></listitem>
2355      </varlistentry>
2356
2357      <varlistentry id="stats.arenas.i.purged">
2358        <term>
2359          <mallctl>stats.arenas.&lt;i&gt;.purged</mallctl>
2360          (<type>uint64_t</type>)
2361          <literal>r-</literal>
2362          [<option>--enable-stats</option>]
2363        </term>
2364        <listitem><para>Number of pages purged.</para></listitem>
2365      </varlistentry>
2366
2367      <varlistentry id="stats.arenas.i.small.allocated">
2368        <term>
2369          <mallctl>stats.arenas.&lt;i&gt;.small.allocated</mallctl>
2370          (<type>size_t</type>)
2371          <literal>r-</literal>
2372          [<option>--enable-stats</option>]
2373        </term>
2374        <listitem><para>Number of bytes currently allocated by small objects.
2375        </para></listitem>
2376      </varlistentry>
2377
2378      <varlistentry id="stats.arenas.i.small.nmalloc">
2379        <term>
2380          <mallctl>stats.arenas.&lt;i&gt;.small.nmalloc</mallctl>
2381          (<type>uint64_t</type>)
2382          <literal>r-</literal>
2383          [<option>--enable-stats</option>]
2384        </term>
2385        <listitem><para>Cumulative number of allocation requests served by
2386        small bins.</para></listitem>
2387      </varlistentry>
2388
2389      <varlistentry id="stats.arenas.i.small.ndalloc">
2390        <term>
2391          <mallctl>stats.arenas.&lt;i&gt;.small.ndalloc</mallctl>
2392          (<type>uint64_t</type>)
2393          <literal>r-</literal>
2394          [<option>--enable-stats</option>]
2395        </term>
2396        <listitem><para>Cumulative number of small objects returned to bins.
2397        </para></listitem>
2398      </varlistentry>
2399
2400      <varlistentry id="stats.arenas.i.small.nrequests">
2401        <term>
2402          <mallctl>stats.arenas.&lt;i&gt;.small.nrequests</mallctl>
2403          (<type>uint64_t</type>)
2404          <literal>r-</literal>
2405          [<option>--enable-stats</option>]
2406        </term>
2407        <listitem><para>Cumulative number of small allocation requests.
2408        </para></listitem>
2409      </varlistentry>
2410
2411      <varlistentry id="stats.arenas.i.large.allocated">
2412        <term>
2413          <mallctl>stats.arenas.&lt;i&gt;.large.allocated</mallctl>
2414          (<type>size_t</type>)
2415          <literal>r-</literal>
2416          [<option>--enable-stats</option>]
2417        </term>
2418        <listitem><para>Number of bytes currently allocated by large objects.
2419        </para></listitem>
2420      </varlistentry>
2421
2422      <varlistentry id="stats.arenas.i.large.nmalloc">
2423        <term>
2424          <mallctl>stats.arenas.&lt;i&gt;.large.nmalloc</mallctl>
2425          (<type>uint64_t</type>)
2426          <literal>r-</literal>
2427          [<option>--enable-stats</option>]
2428        </term>
2429        <listitem><para>Cumulative number of large allocation requests served
2430        directly by the arena.</para></listitem>
2431      </varlistentry>
2432
2433      <varlistentry id="stats.arenas.i.large.ndalloc">
2434        <term>
2435          <mallctl>stats.arenas.&lt;i&gt;.large.ndalloc</mallctl>
2436          (<type>uint64_t</type>)
2437          <literal>r-</literal>
2438          [<option>--enable-stats</option>]
2439        </term>
2440        <listitem><para>Cumulative number of large deallocation requests served
2441        directly by the arena.</para></listitem>
2442      </varlistentry>
2443
2444      <varlistentry id="stats.arenas.i.large.nrequests">
2445        <term>
2446          <mallctl>stats.arenas.&lt;i&gt;.large.nrequests</mallctl>
2447          (<type>uint64_t</type>)
2448          <literal>r-</literal>
2449          [<option>--enable-stats</option>]
2450        </term>
2451        <listitem><para>Cumulative number of large allocation requests.
2452        </para></listitem>
2453      </varlistentry>
2454
2455      <varlistentry id="stats.arenas.i.huge.allocated">
2456        <term>
2457          <mallctl>stats.arenas.&lt;i&gt;.huge.allocated</mallctl>
2458          (<type>size_t</type>)
2459          <literal>r-</literal>
2460          [<option>--enable-stats</option>]
2461        </term>
2462        <listitem><para>Number of bytes currently allocated by huge objects.
2463        </para></listitem>
2464      </varlistentry>
2465
2466      <varlistentry id="stats.arenas.i.huge.nmalloc">
2467        <term>
2468          <mallctl>stats.arenas.&lt;i&gt;.huge.nmalloc</mallctl>
2469          (<type>uint64_t</type>)
2470          <literal>r-</literal>
2471          [<option>--enable-stats</option>]
2472        </term>
2473        <listitem><para>Cumulative number of huge allocation requests served
2474        directly by the arena.</para></listitem>
2475      </varlistentry>
2476
2477      <varlistentry id="stats.arenas.i.huge.ndalloc">
2478        <term>
2479          <mallctl>stats.arenas.&lt;i&gt;.huge.ndalloc</mallctl>
2480          (<type>uint64_t</type>)
2481          <literal>r-</literal>
2482          [<option>--enable-stats</option>]
2483        </term>
2484        <listitem><para>Cumulative number of huge deallocation requests served
2485        directly by the arena.</para></listitem>
2486      </varlistentry>
2487
2488      <varlistentry id="stats.arenas.i.huge.nrequests">
2489        <term>
2490          <mallctl>stats.arenas.&lt;i&gt;.huge.nrequests</mallctl>
2491          (<type>uint64_t</type>)
2492          <literal>r-</literal>
2493          [<option>--enable-stats</option>]
2494        </term>
2495        <listitem><para>Cumulative number of huge allocation requests.
2496        </para></listitem>
2497      </varlistentry>
2498
2499      <varlistentry id="stats.arenas.i.bins.j.nmalloc">
2500        <term>
2501          <mallctl>stats.arenas.&lt;i&gt;.bins.&lt;j&gt;.nmalloc</mallctl>
2502          (<type>uint64_t</type>)
2503          <literal>r-</literal>
2504          [<option>--enable-stats</option>]
2505        </term>
2506        <listitem><para>Cumulative number of allocations served by bin.
2507        </para></listitem>
2508      </varlistentry>
2509
2510      <varlistentry id="stats.arenas.i.bins.j.ndalloc">
2511        <term>
2512          <mallctl>stats.arenas.&lt;i&gt;.bins.&lt;j&gt;.ndalloc</mallctl>
2513          (<type>uint64_t</type>)
2514          <literal>r-</literal>
2515          [<option>--enable-stats</option>]
2516        </term>
2517        <listitem><para>Cumulative number of allocations returned to bin.
2518        </para></listitem>
2519      </varlistentry>
2520
2521      <varlistentry id="stats.arenas.i.bins.j.nrequests">
2522        <term>
2523          <mallctl>stats.arenas.&lt;i&gt;.bins.&lt;j&gt;.nrequests</mallctl>
2524          (<type>uint64_t</type>)
2525          <literal>r-</literal>
2526          [<option>--enable-stats</option>]
2527        </term>
2528        <listitem><para>Cumulative number of allocation
2529        requests.</para></listitem>
2530      </varlistentry>
2531
2532      <varlistentry id="stats.arenas.i.bins.j.curregs">
2533        <term>
2534          <mallctl>stats.arenas.&lt;i&gt;.bins.&lt;j&gt;.curregs</mallctl>
2535          (<type>size_t</type>)
2536          <literal>r-</literal>
2537          [<option>--enable-stats</option>]
2538        </term>
2539        <listitem><para>Current number of regions for this size
2540        class.</para></listitem>
2541      </varlistentry>
2542
2543      <varlistentry id="stats.arenas.i.bins.j.nfills">
2544        <term>
2545          <mallctl>stats.arenas.&lt;i&gt;.bins.&lt;j&gt;.nfills</mallctl>
2546          (<type>uint64_t</type>)
2547          <literal>r-</literal>
2548          [<option>--enable-stats</option> <option>--enable-tcache</option>]
2549        </term>
2550        <listitem><para>Cumulative number of tcache fills.</para></listitem>
2551      </varlistentry>
2552
2553      <varlistentry id="stats.arenas.i.bins.j.nflushes">
2554        <term>
2555          <mallctl>stats.arenas.&lt;i&gt;.bins.&lt;j&gt;.nflushes</mallctl>
2556          (<type>uint64_t</type>)
2557          <literal>r-</literal>
2558          [<option>--enable-stats</option> <option>--enable-tcache</option>]
2559        </term>
2560        <listitem><para>Cumulative number of tcache flushes.</para></listitem>
2561      </varlistentry>
2562
2563      <varlistentry id="stats.arenas.i.bins.j.nruns">
2564        <term>
2565          <mallctl>stats.arenas.&lt;i&gt;.bins.&lt;j&gt;.nruns</mallctl>
2566          (<type>uint64_t</type>)
2567          <literal>r-</literal>
2568          [<option>--enable-stats</option>]
2569        </term>
2570        <listitem><para>Cumulative number of runs created.</para></listitem>
2571      </varlistentry>
2572
2573      <varlistentry id="stats.arenas.i.bins.j.nreruns">
2574        <term>
2575          <mallctl>stats.arenas.&lt;i&gt;.bins.&lt;j&gt;.nreruns</mallctl>
2576          (<type>uint64_t</type>)
2577          <literal>r-</literal>
2578          [<option>--enable-stats</option>]
2579        </term>
2580        <listitem><para>Cumulative number of times the current run from which
2581        to allocate changed.</para></listitem>
2582      </varlistentry>
2583
2584      <varlistentry id="stats.arenas.i.bins.j.curruns">
2585        <term>
2586          <mallctl>stats.arenas.&lt;i&gt;.bins.&lt;j&gt;.curruns</mallctl>
2587          (<type>size_t</type>)
2588          <literal>r-</literal>
2589          [<option>--enable-stats</option>]
2590        </term>
2591        <listitem><para>Current number of runs.</para></listitem>
2592      </varlistentry>
2593
2594      <varlistentry id="stats.arenas.i.lruns.j.nmalloc">
2595        <term>
2596          <mallctl>stats.arenas.&lt;i&gt;.lruns.&lt;j&gt;.nmalloc</mallctl>
2597          (<type>uint64_t</type>)
2598          <literal>r-</literal>
2599          [<option>--enable-stats</option>]
2600        </term>
2601        <listitem><para>Cumulative number of allocation requests for this size
2602        class served directly by the arena.</para></listitem>
2603      </varlistentry>
2604
2605      <varlistentry id="stats.arenas.i.lruns.j.ndalloc">
2606        <term>
2607          <mallctl>stats.arenas.&lt;i&gt;.lruns.&lt;j&gt;.ndalloc</mallctl>
2608          (<type>uint64_t</type>)
2609          <literal>r-</literal>
2610          [<option>--enable-stats</option>]
2611        </term>
2612        <listitem><para>Cumulative number of deallocation requests for this
2613        size class served directly by the arena.</para></listitem>
2614      </varlistentry>
2615
2616      <varlistentry id="stats.arenas.i.lruns.j.nrequests">
2617        <term>
2618          <mallctl>stats.arenas.&lt;i&gt;.lruns.&lt;j&gt;.nrequests</mallctl>
2619          (<type>uint64_t</type>)
2620          <literal>r-</literal>
2621          [<option>--enable-stats</option>]
2622        </term>
2623        <listitem><para>Cumulative number of allocation requests for this size
2624        class.</para></listitem>
2625      </varlistentry>
2626
2627      <varlistentry id="stats.arenas.i.lruns.j.curruns">
2628        <term>
2629          <mallctl>stats.arenas.&lt;i&gt;.lruns.&lt;j&gt;.curruns</mallctl>
2630          (<type>size_t</type>)
2631          <literal>r-</literal>
2632          [<option>--enable-stats</option>]
2633        </term>
2634        <listitem><para>Current number of runs for this size class.
2635        </para></listitem>
2636      </varlistentry>
2637
2638      <varlistentry id="stats.arenas.i.hchunks.j.nmalloc">
2639        <term>
2640          <mallctl>stats.arenas.&lt;i&gt;.hchunks.&lt;j&gt;.nmalloc</mallctl>
2641          (<type>uint64_t</type>)
2642          <literal>r-</literal>
2643          [<option>--enable-stats</option>]
2644        </term>
2645        <listitem><para>Cumulative number of allocation requests for this size
2646        class served directly by the arena.</para></listitem>
2647      </varlistentry>
2648
2649      <varlistentry id="stats.arenas.i.hchunks.j.ndalloc">
2650        <term>
2651          <mallctl>stats.arenas.&lt;i&gt;.hchunks.&lt;j&gt;.ndalloc</mallctl>
2652          (<type>uint64_t</type>)
2653          <literal>r-</literal>
2654          [<option>--enable-stats</option>]
2655        </term>
2656        <listitem><para>Cumulative number of deallocation requests for this
2657        size class served directly by the arena.</para></listitem>
2658      </varlistentry>
2659
2660      <varlistentry id="stats.arenas.i.hchunks.j.nrequests">
2661        <term>
2662          <mallctl>stats.arenas.&lt;i&gt;.hchunks.&lt;j&gt;.nrequests</mallctl>
2663          (<type>uint64_t</type>)
2664          <literal>r-</literal>
2665          [<option>--enable-stats</option>]
2666        </term>
2667        <listitem><para>Cumulative number of allocation requests for this size
2668        class.</para></listitem>
2669      </varlistentry>
2670
2671      <varlistentry id="stats.arenas.i.hchunks.j.curhchunks">
2672        <term>
2673          <mallctl>stats.arenas.&lt;i&gt;.hchunks.&lt;j&gt;.curhchunks</mallctl>
2674          (<type>size_t</type>)
2675          <literal>r-</literal>
2676          [<option>--enable-stats</option>]
2677        </term>
2678        <listitem><para>Current number of huge allocations for this size class.
2679        </para></listitem>
2680      </varlistentry>
2681    </variablelist>
2682  </refsect1>
2683  <refsect1 id="heap_profile_format">
2684    <title>HEAP PROFILE FORMAT</title>
2685    <para>Although the heap profiling functionality was originally designed to
2686    be compatible with the
2687    <command>pprof</command> command that is developed as part of the <ulink
2688    url="http://code.google.com/p/gperftools/">gperftools
2689    package</ulink>, the addition of per thread heap profiling functionality
2690    required a different heap profile format.  The <command>jeprof</command>
2691    command is derived from <command>pprof</command>, with enhancements to
2692    support the heap profile format described here.</para>
2693
2694    <para>In the following hypothetical heap profile, <constant>[...]</constant>
2695    indicates elision for the sake of compactness.  <programlisting><![CDATA[
2696heap_v2/524288
2697  t*: 28106: 56637512 [0: 0]
2698  [...]
2699  t3: 352: 16777344 [0: 0]
2700  [...]
2701  t99: 17754: 29341640 [0: 0]
2702  [...]
2703@ 0x5f86da8 0x5f5a1dc [...] 0x29e4d4e 0xa200316 0xabb2988 [...]
2704  t*: 13: 6688 [0: 0]
2705  t3: 12: 6496 [0: ]
2706  t99: 1: 192 [0: 0]
2707[...]
2708
2709MAPPED_LIBRARIES:
2710[...]]]></programlisting> The following matches the above heap profile, but most
2711tokens are replaced with <constant>&lt;description&gt;</constant> to indicate
2712descriptions of the corresponding fields.  <programlisting><![CDATA[
2713<heap_profile_format_version>/<mean_sample_interval>
2714  <aggregate>: <curobjs>: <curbytes> [<cumobjs>: <cumbytes>]
2715  [...]
2716  <thread_3_aggregate>: <curobjs>: <curbytes>[<cumobjs>: <cumbytes>]
2717  [...]
2718  <thread_99_aggregate>: <curobjs>: <curbytes>[<cumobjs>: <cumbytes>]
2719  [...]
2720@ <top_frame> <frame> [...] <frame> <frame> <frame> [...]
2721  <backtrace_aggregate>: <curobjs>: <curbytes> [<cumobjs>: <cumbytes>]
2722  <backtrace_thread_3>: <curobjs>: <curbytes> [<cumobjs>: <cumbytes>]
2723  <backtrace_thread_99>: <curobjs>: <curbytes> [<cumobjs>: <cumbytes>]
2724[...]
2725
2726MAPPED_LIBRARIES:
2727</proc/<pid>/maps>]]></programlisting></para>
2728  </refsect1>
2729
2730  <refsect1 id="debugging_malloc_problems">
2731    <title>DEBUGGING MALLOC PROBLEMS</title>
2732    <para>When debugging, it is a good idea to configure/build jemalloc with
2733    the <option>--enable-debug</option> and <option>--enable-fill</option>
2734    options, and recompile the program with suitable options and symbols for
2735    debugger support.  When so configured, jemalloc incorporates a wide variety
2736    of run-time assertions that catch application errors such as double-free,
2737    write-after-free, etc.</para>
2738
2739    <para>Programs often accidentally depend on <quote>uninitialized</quote>
2740    memory actually being filled with zero bytes.  Junk filling
2741    (see the <link linkend="opt.junk"><mallctl>opt.junk</mallctl></link>
2742    option) tends to expose such bugs in the form of obviously incorrect
2743    results and/or coredumps.  Conversely, zero
2744    filling (see the <link
2745    linkend="opt.zero"><mallctl>opt.zero</mallctl></link> option) eliminates
2746    the symptoms of such bugs.  Between these two options, it is usually
2747    possible to quickly detect, diagnose, and eliminate such bugs.</para>
2748
2749    <para>This implementation does not provide much detail about the problems
2750    it detects, because the performance impact for storing such information
2751    would be prohibitive.  However, jemalloc does integrate with the most
2752    excellent <ulink url="http://valgrind.org/">Valgrind</ulink> tool if the
2753    <option>--enable-valgrind</option> configuration option is enabled.</para>
2754  </refsect1>
2755  <refsect1 id="diagnostic_messages">
2756    <title>DIAGNOSTIC MESSAGES</title>
2757    <para>If any of the memory allocation/deallocation functions detect an
2758    error or warning condition, a message will be printed to file descriptor
2759    <constant>STDERR_FILENO</constant>.  Errors will result in the process
2760    dumping core.  If the <link
2761    linkend="opt.abort"><mallctl>opt.abort</mallctl></link> option is set, most
2762    warnings are treated as errors.</para>
2763
2764    <para>The <varname>malloc_message</varname> variable allows the programmer
2765    to override the function which emits the text strings forming the errors
2766    and warnings if for some reason the <constant>STDERR_FILENO</constant> file
2767    descriptor is not suitable for this.
2768    <function>malloc_message()</function> takes the
2769    <parameter>cbopaque</parameter> pointer argument that is
2770    <constant>NULL</constant> unless overridden by the arguments in a call to
2771    <function>malloc_stats_print()</function>, followed by a string
2772    pointer.  Please note that doing anything which tries to allocate memory in
2773    this function is likely to result in a crash or deadlock.</para>
2774
2775    <para>All messages are prefixed by
2776    <quote><computeroutput>&lt;jemalloc&gt;: </computeroutput></quote>.</para>
2777  </refsect1>
2778  <refsect1 id="return_values">
2779    <title>RETURN VALUES</title>
2780    <refsect2>
2781      <title>Standard API</title>
2782      <para>The <function>malloc()</function> and
2783      <function>calloc()</function> functions return a pointer to the
2784      allocated memory if successful; otherwise a <constant>NULL</constant>
2785      pointer is returned and <varname>errno</varname> is set to
2786      <errorname>ENOMEM</errorname>.</para>
2787
2788      <para>The <function>posix_memalign()</function> function
2789      returns the value 0 if successful; otherwise it returns an error value.
2790      The <function>posix_memalign()</function> function will fail
2791      if:
2792        <variablelist>
2793          <varlistentry>
2794            <term><errorname>EINVAL</errorname></term>
2795
2796            <listitem><para>The <parameter>alignment</parameter> parameter is
2797            not a power of 2 at least as large as
2798            <code language="C">sizeof(<type>void *</type>)</code>.
2799            </para></listitem>
2800          </varlistentry>
2801          <varlistentry>
2802            <term><errorname>ENOMEM</errorname></term>
2803
2804            <listitem><para>Memory allocation error.</para></listitem>
2805          </varlistentry>
2806        </variablelist>
2807      </para>
2808
2809      <para>The <function>aligned_alloc()</function> function returns
2810      a pointer to the allocated memory if successful; otherwise a
2811      <constant>NULL</constant> pointer is returned and
2812      <varname>errno</varname> is set.  The
2813      <function>aligned_alloc()</function> function will fail if:
2814        <variablelist>
2815          <varlistentry>
2816            <term><errorname>EINVAL</errorname></term>
2817
2818            <listitem><para>The <parameter>alignment</parameter> parameter is
2819            not a power of 2.
2820            </para></listitem>
2821          </varlistentry>
2822          <varlistentry>
2823            <term><errorname>ENOMEM</errorname></term>
2824
2825            <listitem><para>Memory allocation error.</para></listitem>
2826          </varlistentry>
2827        </variablelist>
2828      </para>
2829
2830      <para>The <function>realloc()</function> function returns a
2831      pointer, possibly identical to <parameter>ptr</parameter>, to the
2832      allocated memory if successful; otherwise a <constant>NULL</constant>
2833      pointer is returned, and <varname>errno</varname> is set to
2834      <errorname>ENOMEM</errorname> if the error was the result of an
2835      allocation failure.  The <function>realloc()</function>
2836      function always leaves the original buffer intact when an error occurs.
2837      </para>
2838
2839      <para>The <function>free()</function> function returns no
2840      value.</para>
2841    </refsect2>
2842    <refsect2>
2843      <title>Non-standard API</title>
2844      <para>The <function>mallocx()</function> and
2845      <function>rallocx()</function> functions return a pointer to
2846      the allocated memory if successful; otherwise a <constant>NULL</constant>
2847      pointer is returned to indicate insufficient contiguous memory was
2848      available to service the allocation request.  </para>
2849
2850      <para>The <function>xallocx()</function> function returns the
2851      real size of the resulting resized allocation pointed to by
2852      <parameter>ptr</parameter>, which is a value less than
2853      <parameter>size</parameter> if the allocation could not be adequately
2854      grown in place.  </para>
2855
2856      <para>The <function>sallocx()</function> function returns the
2857      real size of the allocation pointed to by <parameter>ptr</parameter>.
2858      </para>
2859
2860      <para>The <function>nallocx()</function> returns the real size
2861      that would result from a successful equivalent
2862      <function>mallocx()</function> function call, or zero if
2863      insufficient memory is available to perform the size computation.  </para>
2864
2865      <para>The <function>mallctl()</function>,
2866      <function>mallctlnametomib()</function>, and
2867      <function>mallctlbymib()</function> functions return 0 on
2868      success; otherwise they return an error value.  The functions will fail
2869      if:
2870        <variablelist>
2871          <varlistentry>
2872            <term><errorname>EINVAL</errorname></term>
2873
2874            <listitem><para><parameter>newp</parameter> is not
2875            <constant>NULL</constant>, and <parameter>newlen</parameter> is too
2876            large or too small.  Alternatively, <parameter>*oldlenp</parameter>
2877            is too large or too small; in this case as much data as possible
2878            are read despite the error.</para></listitem>
2879          </varlistentry>
2880          <varlistentry>
2881            <term><errorname>ENOENT</errorname></term>
2882
2883            <listitem><para><parameter>name</parameter> or
2884            <parameter>mib</parameter> specifies an unknown/invalid
2885            value.</para></listitem>
2886          </varlistentry>
2887          <varlistentry>
2888            <term><errorname>EPERM</errorname></term>
2889
2890            <listitem><para>Attempt to read or write void value, or attempt to
2891            write read-only value.</para></listitem>
2892          </varlistentry>
2893          <varlistentry>
2894            <term><errorname>EAGAIN</errorname></term>
2895
2896            <listitem><para>A memory allocation failure
2897            occurred.</para></listitem>
2898          </varlistentry>
2899          <varlistentry>
2900            <term><errorname>EFAULT</errorname></term>
2901
2902            <listitem><para>An interface with side effects failed in some way
2903            not directly related to <function>mallctl*()</function>
2904            read/write processing.</para></listitem>
2905          </varlistentry>
2906        </variablelist>
2907      </para>
2908
2909      <para>The <function>malloc_usable_size()</function> function
2910      returns the usable size of the allocation pointed to by
2911      <parameter>ptr</parameter>.  </para>
2912    </refsect2>
2913  </refsect1>
2914  <refsect1 id="environment">
2915    <title>ENVIRONMENT</title>
2916    <para>The following environment variable affects the execution of the
2917    allocation functions:
2918      <variablelist>
2919        <varlistentry>
2920          <term><envar>MALLOC_CONF</envar></term>
2921
2922          <listitem><para>If the environment variable
2923          <envar>MALLOC_CONF</envar> is set, the characters it contains
2924          will be interpreted as options.</para></listitem>
2925        </varlistentry>
2926      </variablelist>
2927    </para>
2928  </refsect1>
2929  <refsect1 id="examples">
2930    <title>EXAMPLES</title>
2931    <para>To dump core whenever a problem occurs:
2932      <screen>ln -s 'abort:true' /etc/malloc.conf</screen>
2933    </para>
2934    <para>To specify in the source a chunk size that is 16 MiB:
2935      <programlisting language="C"><![CDATA[
2936malloc_conf = "lg_chunk:24";]]></programlisting></para>
2937  </refsect1>
2938  <refsect1 id="see_also">
2939    <title>SEE ALSO</title>
2940    <para><citerefentry><refentrytitle>madvise</refentrytitle>
2941    <manvolnum>2</manvolnum></citerefentry>,
2942    <citerefentry><refentrytitle>mmap</refentrytitle>
2943    <manvolnum>2</manvolnum></citerefentry>,
2944    <citerefentry><refentrytitle>sbrk</refentrytitle>
2945    <manvolnum>2</manvolnum></citerefentry>,
2946    <citerefentry><refentrytitle>utrace</refentrytitle>
2947    <manvolnum>2</manvolnum></citerefentry>,
2948    <citerefentry><refentrytitle>alloca</refentrytitle>
2949    <manvolnum>3</manvolnum></citerefentry>,
2950    <citerefentry><refentrytitle>atexit</refentrytitle>
2951    <manvolnum>3</manvolnum></citerefentry>,
2952    <citerefentry><refentrytitle>getpagesize</refentrytitle>
2953    <manvolnum>3</manvolnum></citerefentry></para>
2954  </refsect1>
2955  <refsect1 id="standards">
2956    <title>STANDARDS</title>
2957    <para>The <function>malloc()</function>,
2958    <function>calloc()</function>,
2959    <function>realloc()</function>, and
2960    <function>free()</function> functions conform to ISO/IEC
2961    9899:1990 (<quote>ISO C90</quote>).</para>
2962
2963    <para>The <function>posix_memalign()</function> function conforms
2964    to IEEE Std 1003.1-2001 (<quote>POSIX.1</quote>).</para>
2965  </refsect1>
2966</refentry>
2967