xref: /openbmc/linux/Documentation/ABI/testing/sysfs-kernel-slab (revision 4f2c0a4acffbec01079c28f839422e64ddeff004)
151e95bedSDavid RientjesWhat:		/sys/kernel/slab
251e95bedSDavid RientjesDate:		May 2007
351e95bedSDavid RientjesKernelVersion:	2.6.22
451e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
551e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
651e95bedSDavid RientjesDescription:
751e95bedSDavid Rientjes		The /sys/kernel/slab directory contains a snapshot of the
851e95bedSDavid Rientjes		internal state of the SLUB allocator for each cache.  Certain
951e95bedSDavid Rientjes		files may be modified to change the behavior of the cache (and
1051e95bedSDavid Rientjes		any cache it aliases, if any).
1151e95bedSDavid RientjesUsers:		kernel memory tuning tools
1251e95bedSDavid Rientjes
13a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/aliases
1451e95bedSDavid RientjesDate:		May 2007
1551e95bedSDavid RientjesKernelVersion:	2.6.22
1651e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
1751e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
1851e95bedSDavid RientjesDescription:
1951e95bedSDavid Rientjes		The aliases file is read-only and specifies how many caches
2051e95bedSDavid Rientjes		have merged into this cache.
2151e95bedSDavid Rientjes
22a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/align
2351e95bedSDavid RientjesDate:		May 2007
2451e95bedSDavid RientjesKernelVersion:	2.6.22
2551e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
2651e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
2751e95bedSDavid RientjesDescription:
2851e95bedSDavid Rientjes		The align file is read-only and specifies the cache's object
2951e95bedSDavid Rientjes		alignment in bytes.
3051e95bedSDavid Rientjes
31a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/alloc_calls
3251e95bedSDavid RientjesDate:		May 2007
3351e95bedSDavid RientjesKernelVersion:	2.6.22
3451e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
3551e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
3651e95bedSDavid RientjesDescription:
3751e95bedSDavid Rientjes		The alloc_calls file is read-only and lists the kernel code
3851e95bedSDavid Rientjes		locations from which allocations for this cache were performed.
3951e95bedSDavid Rientjes		The alloc_calls file only contains information if debugging is
40*ee65728eSMike Rapoport		enabled for that cache (see Documentation/mm/slub.rst).
4151e95bedSDavid Rientjes
42a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/alloc_fastpath
4351e95bedSDavid RientjesDate:		February 2008
4451e95bedSDavid RientjesKernelVersion:	2.6.25
4551e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
4651e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
4751e95bedSDavid RientjesDescription:
4878eb00ccSDavid Rientjes		The alloc_fastpath file shows how many objects have been
4978eb00ccSDavid Rientjes		allocated using the fast path.  It can be written to clear the
5078eb00ccSDavid Rientjes		current count.
5151e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
5251e95bedSDavid Rientjes
53a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/alloc_from_partial
5451e95bedSDavid RientjesDate:		February 2008
5551e95bedSDavid RientjesKernelVersion:	2.6.25
5651e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
5751e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
5851e95bedSDavid RientjesDescription:
5978eb00ccSDavid Rientjes		The alloc_from_partial file shows how many times a cpu slab has
6078eb00ccSDavid Rientjes		been full and it has been refilled by using a slab from the list
6178eb00ccSDavid Rientjes		of partially used slabs.  It can be written to clear the current
6278eb00ccSDavid Rientjes		count.
6351e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
6451e95bedSDavid Rientjes
65a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/alloc_refill
6651e95bedSDavid RientjesDate:		February 2008
6751e95bedSDavid RientjesKernelVersion:	2.6.25
6851e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
6951e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
7051e95bedSDavid RientjesDescription:
7178eb00ccSDavid Rientjes		The alloc_refill file shows how many times the per-cpu freelist
7278eb00ccSDavid Rientjes		was empty but there were objects available as the result of
7378eb00ccSDavid Rientjes		remote cpu frees.  It can be written to clear the current count.
7451e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
7551e95bedSDavid Rientjes
76a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/alloc_slab
7751e95bedSDavid RientjesDate:		February 2008
7851e95bedSDavid RientjesKernelVersion:	2.6.25
7951e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
8051e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
8151e95bedSDavid RientjesDescription:
8278eb00ccSDavid Rientjes		The alloc_slab file is shows how many times a new slab had to
8378eb00ccSDavid Rientjes		be allocated from the page allocator.  It can be written to
8478eb00ccSDavid Rientjes		clear the current count.
8551e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
8651e95bedSDavid Rientjes
87a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/alloc_slowpath
8851e95bedSDavid RientjesDate:		February 2008
8951e95bedSDavid RientjesKernelVersion:	2.6.25
9051e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
9151e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
9251e95bedSDavid RientjesDescription:
9378eb00ccSDavid Rientjes		The alloc_slowpath file shows how many objects have been
9478eb00ccSDavid Rientjes		allocated using the slow path because of a refill or
9578eb00ccSDavid Rientjes		allocation from a partial or new slab.  It can be written to
9678eb00ccSDavid Rientjes		clear the current count.
9751e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
9851e95bedSDavid Rientjes
99a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/cache_dma
10051e95bedSDavid RientjesDate:		May 2007
10151e95bedSDavid RientjesKernelVersion:	2.6.22
10251e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
10351e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
10451e95bedSDavid RientjesDescription:
10551e95bedSDavid Rientjes		The cache_dma file is read-only and specifies whether objects
10651e95bedSDavid Rientjes		are from ZONE_DMA.
10751e95bedSDavid Rientjes		Available when CONFIG_ZONE_DMA is enabled.
10851e95bedSDavid Rientjes
109a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/cpu_slabs
11051e95bedSDavid RientjesDate:		May 2007
11151e95bedSDavid RientjesKernelVersion:	2.6.22
11251e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
11351e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
11451e95bedSDavid RientjesDescription:
11551e95bedSDavid Rientjes		The cpu_slabs file is read-only and displays how many cpu slabs
11651e95bedSDavid Rientjes		are active and their NUMA locality.
11751e95bedSDavid Rientjes
118a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/cpuslab_flush
11951e95bedSDavid RientjesDate:		April 2009
12051e95bedSDavid RientjesKernelVersion:	2.6.31
12151e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
12251e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
12351e95bedSDavid RientjesDescription:
12478eb00ccSDavid Rientjes		The file cpuslab_flush shows how many times a cache's cpu slabs
12578eb00ccSDavid Rientjes		have been flushed as the result of destroying or shrinking a
12678eb00ccSDavid Rientjes		cache, a cpu going offline, or as the result of forcing an
12778eb00ccSDavid Rientjes		allocation from a certain node.  It can be written to clear the
12878eb00ccSDavid Rientjes		current count.
12951e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
13051e95bedSDavid Rientjes
131a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/ctor
13251e95bedSDavid RientjesDate:		May 2007
13351e95bedSDavid RientjesKernelVersion:	2.6.22
13451e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
13551e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
13651e95bedSDavid RientjesDescription:
13751e95bedSDavid Rientjes		The ctor file is read-only and specifies the cache's object
13851e95bedSDavid Rientjes		constructor function, which is invoked for each object when a
13951e95bedSDavid Rientjes		new slab is allocated.
14051e95bedSDavid Rientjes
141a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/deactivate_empty
14251e95bedSDavid RientjesDate:		February 2008
14351e95bedSDavid RientjesKernelVersion:	2.6.25
14451e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
14551e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
14651e95bedSDavid RientjesDescription:
14778eb00ccSDavid Rientjes		The deactivate_empty file shows how many times an empty cpu slab
14878eb00ccSDavid Rientjes		was deactivated.  It can be written to clear the current count.
14951e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
15051e95bedSDavid Rientjes
151a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/deactivate_full
15251e95bedSDavid RientjesDate:		February 2008
15351e95bedSDavid RientjesKernelVersion:	2.6.25
15451e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
15551e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
15651e95bedSDavid RientjesDescription:
15778eb00ccSDavid Rientjes		The deactivate_full file shows how many times a full cpu slab
15878eb00ccSDavid Rientjes		was deactivated.  It can be written to clear the current count.
15951e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
16051e95bedSDavid Rientjes
161a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/deactivate_remote_frees
16251e95bedSDavid RientjesDate:		February 2008
16351e95bedSDavid RientjesKernelVersion:	2.6.25
16451e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
16551e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
16651e95bedSDavid RientjesDescription:
16778eb00ccSDavid Rientjes		The deactivate_remote_frees file shows how many times a cpu slab
16878eb00ccSDavid Rientjes		has been deactivated and contained free objects that were freed
16978eb00ccSDavid Rientjes		remotely.  It can be written to clear the current count.
17051e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
17151e95bedSDavid Rientjes
172a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/deactivate_to_head
17351e95bedSDavid RientjesDate:		February 2008
17451e95bedSDavid RientjesKernelVersion:	2.6.25
17551e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
17651e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
17751e95bedSDavid RientjesDescription:
17878eb00ccSDavid Rientjes		The deactivate_to_head file shows how many times a partial cpu
17978eb00ccSDavid Rientjes		slab was deactivated and added to the head of its node's partial
18078eb00ccSDavid Rientjes		list.  It can be written to clear the current count.
18151e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
18251e95bedSDavid Rientjes
183a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/deactivate_to_tail
18451e95bedSDavid RientjesDate:		February 2008
18551e95bedSDavid RientjesKernelVersion:	2.6.25
18651e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
18751e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
18851e95bedSDavid RientjesDescription:
18978eb00ccSDavid Rientjes		The deactivate_to_tail file shows how many times a partial cpu
19078eb00ccSDavid Rientjes		slab was deactivated and added to the tail of its node's partial
19178eb00ccSDavid Rientjes		list.  It can be written to clear the current count.
19251e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
19351e95bedSDavid Rientjes
194a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/destroy_by_rcu
19551e95bedSDavid RientjesDate:		May 2007
19651e95bedSDavid RientjesKernelVersion:	2.6.22
19751e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
19851e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
19951e95bedSDavid RientjesDescription:
20051e95bedSDavid Rientjes		The destroy_by_rcu file is read-only and specifies whether
20151e95bedSDavid Rientjes		slabs (not objects) are freed by rcu.
20251e95bedSDavid Rientjes
203a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/free_add_partial
20451e95bedSDavid RientjesDate:		February 2008
20551e95bedSDavid RientjesKernelVersion:	2.6.25
20651e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
20751e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
20851e95bedSDavid RientjesDescription:
20978eb00ccSDavid Rientjes		The free_add_partial file shows how many times an object has
21078eb00ccSDavid Rientjes		been freed in a full slab so that it had to added to its node's
21178eb00ccSDavid Rientjes		partial list.  It can be written to clear the current count.
21251e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
21351e95bedSDavid Rientjes
214a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/free_calls
21551e95bedSDavid RientjesDate:		May 2007
21651e95bedSDavid RientjesKernelVersion:	2.6.22
21751e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
21851e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
21951e95bedSDavid RientjesDescription:
22051e95bedSDavid Rientjes		The free_calls file is read-only and lists the locations of
22151e95bedSDavid Rientjes		object frees if slab debugging is enabled (see
222*ee65728eSMike Rapoport		Documentation/mm/slub.rst).
22351e95bedSDavid Rientjes
224a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/free_fastpath
22551e95bedSDavid RientjesDate:		February 2008
22651e95bedSDavid RientjesKernelVersion:	2.6.25
22751e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
22851e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
22951e95bedSDavid RientjesDescription:
23078eb00ccSDavid Rientjes		The free_fastpath file shows how many objects have been freed
23178eb00ccSDavid Rientjes		using the fast path because it was an object from the cpu slab.
23278eb00ccSDavid Rientjes		It can be written to clear the current count.
23351e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
23451e95bedSDavid Rientjes
235a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/free_frozen
23651e95bedSDavid RientjesDate:		February 2008
23751e95bedSDavid RientjesKernelVersion:	2.6.25
23851e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
23951e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
24051e95bedSDavid RientjesDescription:
24178eb00ccSDavid Rientjes		The free_frozen file shows how many objects have been freed to
24278eb00ccSDavid Rientjes		a frozen slab (i.e. a remote cpu slab).  It can be written to
24378eb00ccSDavid Rientjes		clear the current count.
24451e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
24551e95bedSDavid Rientjes
246a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/free_remove_partial
24751e95bedSDavid RientjesDate:		February 2008
24851e95bedSDavid RientjesKernelVersion:	2.6.25
24951e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
25051e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
25151e95bedSDavid RientjesDescription:
25278eb00ccSDavid Rientjes		The free_remove_partial file shows how many times an object has
25378eb00ccSDavid Rientjes		been freed to a now-empty slab so that it had to be removed from
25478eb00ccSDavid Rientjes		its node's partial list.  It can be written to clear the current
25578eb00ccSDavid Rientjes		count.
25651e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
25751e95bedSDavid Rientjes
258a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/free_slab
25951e95bedSDavid RientjesDate:		February 2008
26051e95bedSDavid RientjesKernelVersion:	2.6.25
26151e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
26251e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
26351e95bedSDavid RientjesDescription:
26478eb00ccSDavid Rientjes		The free_slab file shows how many times an empty slab has been
26578eb00ccSDavid Rientjes		freed back to the page allocator.  It can be written to clear
26678eb00ccSDavid Rientjes		the current count.
26751e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
26851e95bedSDavid Rientjes
269a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/free_slowpath
27051e95bedSDavid RientjesDate:		February 2008
27151e95bedSDavid RientjesKernelVersion:	2.6.25
27251e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
27351e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
27451e95bedSDavid RientjesDescription:
27578eb00ccSDavid Rientjes		The free_slowpath file shows how many objects have been freed
27678eb00ccSDavid Rientjes		using the slow path (i.e. to a full or partial slab).  It can
27778eb00ccSDavid Rientjes		be written to clear the current count.
27851e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
27951e95bedSDavid Rientjes
280a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/hwcache_align
28151e95bedSDavid RientjesDate:		May 2007
28251e95bedSDavid RientjesKernelVersion:	2.6.22
28351e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
28451e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
28551e95bedSDavid RientjesDescription:
28651e95bedSDavid Rientjes		The hwcache_align file is read-only and specifies whether
28751e95bedSDavid Rientjes		objects are aligned on cachelines.
28851e95bedSDavid Rientjes
289a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/min_partial
29051e95bedSDavid RientjesDate:		February 2009
29151e95bedSDavid RientjesKernelVersion:	2.6.30
29251e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
29351e95bedSDavid Rientjes		David Rientjes <rientjes@google.com>
29451e95bedSDavid RientjesDescription:
29551e95bedSDavid Rientjes		The min_partial file specifies how many empty slabs shall
29651e95bedSDavid Rientjes		remain on a node's partial list to avoid the overhead of
29751e95bedSDavid Rientjes		allocating new slabs.  Such slabs may be reclaimed by utilizing
29851e95bedSDavid Rientjes		the shrink file.
29951e95bedSDavid Rientjes
300a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/object_size
30151e95bedSDavid RientjesDate:		May 2007
30251e95bedSDavid RientjesKernelVersion:	2.6.22
30351e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
30451e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
30551e95bedSDavid RientjesDescription:
30651e95bedSDavid Rientjes		The object_size file is read-only and specifies the cache's
30751e95bedSDavid Rientjes		object size.
30851e95bedSDavid Rientjes
309a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/objects
31051e95bedSDavid RientjesDate:		May 2007
31151e95bedSDavid RientjesKernelVersion:	2.6.22
31251e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
31351e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
31451e95bedSDavid RientjesDescription:
31551e95bedSDavid Rientjes		The objects file is read-only and displays how many objects are
31651e95bedSDavid Rientjes		active and from which nodes they are from.
31751e95bedSDavid Rientjes
318a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/objects_partial
31951e95bedSDavid RientjesDate:		April 2008
32051e95bedSDavid RientjesKernelVersion:	2.6.26
32151e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
32251e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
32351e95bedSDavid RientjesDescription:
32451e95bedSDavid Rientjes		The objects_partial file is read-only and displays how many
32551e95bedSDavid Rientjes		objects are on partial slabs and from which nodes they are
32651e95bedSDavid Rientjes		from.
32751e95bedSDavid Rientjes
328a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/objs_per_slab
32951e95bedSDavid RientjesDate:		May 2007
33051e95bedSDavid RientjesKernelVersion:	2.6.22
33151e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
33251e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
33351e95bedSDavid RientjesDescription:
33451e95bedSDavid Rientjes		The file objs_per_slab is read-only and specifies how many
33551e95bedSDavid Rientjes		objects may be allocated from a single slab of the order
336a19ea9e3SMauro Carvalho Chehab		specified in /sys/kernel/slab/<cache>/order.
33751e95bedSDavid Rientjes
338a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/order
33951e95bedSDavid RientjesDate:		May 2007
34051e95bedSDavid RientjesKernelVersion:	2.6.22
34151e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
34251e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
34351e95bedSDavid RientjesDescription:
34451e95bedSDavid Rientjes		The order file specifies the page order at which new slabs are
34551e95bedSDavid Rientjes		allocated.  It is writable and can be changed to increase the
34651e95bedSDavid Rientjes		number of objects per slab.  If a slab cannot be allocated
34751e95bedSDavid Rientjes		because of fragmentation, SLUB will retry with the minimum order
34851e95bedSDavid Rientjes		possible depending on its characteristics.
34954a19b4dSMauro Carvalho Chehab
350888a214dSStanislaw Gruszka		When debug_guardpage_minorder=N (N > 0) parameter is specified
3518c27ceffSMauro Carvalho Chehab		(see Documentation/admin-guide/kernel-parameters.rst), the minimum possible
352888a214dSStanislaw Gruszka		order is used and this sysfs entry can not be used to change
353888a214dSStanislaw Gruszka		the order at run time.
35451e95bedSDavid Rientjes
355a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/order_fallback
35651e95bedSDavid RientjesDate:		April 2008
35751e95bedSDavid RientjesKernelVersion:	2.6.26
35851e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
35951e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
36051e95bedSDavid RientjesDescription:
36178eb00ccSDavid Rientjes		The order_fallback file shows how many times an allocation of a
36278eb00ccSDavid Rientjes		new slab has not been possible at the cache's order and instead
36378eb00ccSDavid Rientjes		fallen back to its minimum possible order.  It can be written to
36478eb00ccSDavid Rientjes		clear the current count.
36554a19b4dSMauro Carvalho Chehab
36651e95bedSDavid Rientjes		Available when CONFIG_SLUB_STATS is enabled.
36751e95bedSDavid Rientjes
368a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/partial
36951e95bedSDavid RientjesDate:		May 2007
37051e95bedSDavid RientjesKernelVersion:	2.6.22
37151e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
37251e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
37351e95bedSDavid RientjesDescription:
37451e95bedSDavid Rientjes		The partial file is read-only and displays how long many
37551e95bedSDavid Rientjes		partial slabs there are and how long each node's list is.
37651e95bedSDavid Rientjes
377a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/poison
37851e95bedSDavid RientjesDate:		May 2007
37951e95bedSDavid RientjesKernelVersion:	2.6.22
38051e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
38151e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
38251e95bedSDavid RientjesDescription:
38351e95bedSDavid Rientjes		The poison file specifies whether objects should be poisoned
38451e95bedSDavid Rientjes		when a new slab is allocated.
38551e95bedSDavid Rientjes
386a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/reclaim_account
38751e95bedSDavid RientjesDate:		May 2007
38851e95bedSDavid RientjesKernelVersion:	2.6.22
38951e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
39051e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
39151e95bedSDavid RientjesDescription:
39251e95bedSDavid Rientjes		The reclaim_account file specifies whether the cache's objects
39351e95bedSDavid Rientjes		are reclaimable (and grouped by their mobility).
39451e95bedSDavid Rientjes
395a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/red_zone
39651e95bedSDavid RientjesDate:		May 2007
39751e95bedSDavid RientjesKernelVersion:	2.6.22
39851e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
39951e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
40051e95bedSDavid RientjesDescription:
40151e95bedSDavid Rientjes		The red_zone file specifies whether the cache's objects are red
40251e95bedSDavid Rientjes		zoned.
40351e95bedSDavid Rientjes
404a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/remote_node_defrag_ratio
40551e95bedSDavid RientjesDate:		January 2008
40651e95bedSDavid RientjesKernelVersion:	2.6.25
40751e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
40851e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
40951e95bedSDavid RientjesDescription:
41051e95bedSDavid Rientjes		The file remote_node_defrag_ratio specifies the percentage of
41151e95bedSDavid Rientjes		times SLUB will attempt to refill the cpu slab with a partial
41251e95bedSDavid Rientjes		slab from a remote node as opposed to allocating a new slab on
41351e95bedSDavid Rientjes		the local node.  This reduces the amount of wasted memory over
41451e95bedSDavid Rientjes		the entire system but can be expensive.
41554a19b4dSMauro Carvalho Chehab
41651e95bedSDavid Rientjes		Available when CONFIG_NUMA is enabled.
41751e95bedSDavid Rientjes
418a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/sanity_checks
41951e95bedSDavid RientjesDate:		May 2007
42051e95bedSDavid RientjesKernelVersion:	2.6.22
42151e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
42251e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
42351e95bedSDavid RientjesDescription:
42451e95bedSDavid Rientjes		The sanity_checks file specifies whether expensive checks
42551e95bedSDavid Rientjes		should be performed on free and, at minimum, enables double free
42651e95bedSDavid Rientjes		checks.  Caches that enable sanity_checks cannot be merged with
42751e95bedSDavid Rientjes		caches that do not.
42851e95bedSDavid Rientjes
429a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/shrink
43051e95bedSDavid RientjesDate:		May 2007
43151e95bedSDavid RientjesKernelVersion:	2.6.22
43251e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
43351e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
43451e95bedSDavid RientjesDescription:
43504f768a3SWaiman Long		The shrink file is used to reclaim unused slab cache
43604f768a3SWaiman Long		memory from a cache.  Empty per-cpu or partial slabs
43704f768a3SWaiman Long		are freed and the partial list is sorted so the slabs
43804f768a3SWaiman Long		with the fewest available objects are used first.
43904f768a3SWaiman Long		It only accepts a value of "1" on write for shrinking
44004f768a3SWaiman Long		the cache. Other input values are considered invalid.
44104f768a3SWaiman Long		Shrinking slab caches might be expensive and can
44204f768a3SWaiman Long		adversely impact other running applications.  So it
44304f768a3SWaiman Long		should be used with care.
44451e95bedSDavid Rientjes
445a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/slab_size
44651e95bedSDavid RientjesDate:		May 2007
44751e95bedSDavid RientjesKernelVersion:	2.6.22
44851e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
44951e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
45051e95bedSDavid RientjesDescription:
45151e95bedSDavid Rientjes		The slab_size file is read-only and specifies the object size
45251e95bedSDavid Rientjes		with metadata (debugging information and alignment) in bytes.
45351e95bedSDavid Rientjes
454a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/slabs
45551e95bedSDavid RientjesDate:		May 2007
45651e95bedSDavid RientjesKernelVersion:	2.6.22
45751e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
45851e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
45951e95bedSDavid RientjesDescription:
46051e95bedSDavid Rientjes		The slabs file is read-only and displays how long many slabs
46151e95bedSDavid Rientjes		there are (both cpu and partial) and from which nodes they are
46251e95bedSDavid Rientjes		from.
46351e95bedSDavid Rientjes
464a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/store_user
46551e95bedSDavid RientjesDate:		May 2007
46651e95bedSDavid RientjesKernelVersion:	2.6.22
46751e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
46851e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
46951e95bedSDavid RientjesDescription:
47051e95bedSDavid Rientjes		The store_user file specifies whether the location of
47151e95bedSDavid Rientjes		allocation or free should be tracked for a cache.
47251e95bedSDavid Rientjes
473a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/total_objects
47451e95bedSDavid RientjesDate:		April 2008
47551e95bedSDavid RientjesKernelVersion:	2.6.26
47651e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
47751e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
47851e95bedSDavid RientjesDescription:
47951e95bedSDavid Rientjes		The total_objects file is read-only and displays how many total
48051e95bedSDavid Rientjes		objects a cache has and from which nodes they are from.
48151e95bedSDavid Rientjes
482a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/trace
48351e95bedSDavid RientjesDate:		May 2007
48451e95bedSDavid RientjesKernelVersion:	2.6.22
48551e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
48651e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
48751e95bedSDavid RientjesDescription:
48851e95bedSDavid Rientjes		The trace file specifies whether object allocations and frees
48951e95bedSDavid Rientjes		should be traced.
49051e95bedSDavid Rientjes
491a19ea9e3SMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/validate
49251e95bedSDavid RientjesDate:		May 2007
49351e95bedSDavid RientjesKernelVersion:	2.6.22
49451e95bedSDavid RientjesContact:	Pekka Enberg <penberg@cs.helsinki.fi>,
49551e95bedSDavid Rientjes		Christoph Lameter <cl@linux-foundation.org>
49651e95bedSDavid RientjesDescription:
49751e95bedSDavid Rientjes		Writing to the validate file causes SLUB to traverse all of its
49851e95bedSDavid Rientjes		cache's objects and check the validity of metadata.
499773151dcSMauro Carvalho Chehab
500773151dcSMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/usersize
501773151dcSMauro Carvalho ChehabDate:		Jun 2017
502773151dcSMauro Carvalho ChehabContact:	David Windsor <dave@nullcore.net>
503773151dcSMauro Carvalho ChehabDescription:
504773151dcSMauro Carvalho Chehab		The usersize file is read-only and contains the usercopy
505773151dcSMauro Carvalho Chehab		region size.
506773151dcSMauro Carvalho Chehab
507773151dcSMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/slabs_cpu_partial
508773151dcSMauro Carvalho ChehabDate:		Aug 2011
509773151dcSMauro Carvalho ChehabContact:	Christoph Lameter <cl@linux.com>
510773151dcSMauro Carvalho ChehabDescription:
511773151dcSMauro Carvalho Chehab		This read-only file shows the number of partialli allocated
512773151dcSMauro Carvalho Chehab		frozen slabs.
513773151dcSMauro Carvalho Chehab
514773151dcSMauro Carvalho ChehabWhat:		/sys/kernel/slab/<cache>/cpu_partial
515773151dcSMauro Carvalho ChehabDate:		Aug 2011
516773151dcSMauro Carvalho ChehabContact:	Christoph Lameter <cl@linux.com>
517773151dcSMauro Carvalho ChehabDescription:
518773151dcSMauro Carvalho Chehab		This read-only file shows the number of per cpu partial
519773151dcSMauro Carvalho Chehab		pages to keep around.
520