7 The /sys/kernel/slab directory contains a snapshot of the
8 internal state of the SLUB allocator for each cache. Certain
9 files may be modified to change the behavior of the cache (and
10 any cache it aliases, if any).
11 Users: kernel memory tuning tools
13 What: /sys/kernel/slab/cache/aliases
19 The aliases file is read-only and specifies how many caches
20 have merged into this cache.
22 What: /sys/kernel/slab/cache/align
28 The align file is read-only and specifies the cache's object
31 What: /sys/kernel/slab/cache/alloc_calls
37 The alloc_calls file is read-only and lists the kernel code
38 locations from which allocations for this cache were performed.
39 The alloc_calls file only contains information if debugging is
40 enabled for that cache (see Documentation/vm/slub.txt).
42 What: /sys/kernel/slab/cache/alloc_fastpath
48 The alloc_fastpath file shows how many objects have been
49 allocated using the fast path. It can be written to clear the
51 Available when CONFIG_SLUB_STATS is enabled.
53 What: /sys/kernel/slab/cache/alloc_from_partial
59 The alloc_from_partial file shows how many times a cpu slab has
60 been full and it has been refilled by using a slab from the list
61 of partially used slabs. It can be written to clear the current
63 Available when CONFIG_SLUB_STATS is enabled.
65 What: /sys/kernel/slab/cache/alloc_refill
71 The alloc_refill file shows how many times the per-cpu freelist
72 was empty but there were objects available as the result of
73 remote cpu frees. It can be written to clear the current count.
74 Available when CONFIG_SLUB_STATS is enabled.
76 What: /sys/kernel/slab/cache/alloc_slab
82 The alloc_slab file is shows how many times a new slab had to
83 be allocated from the page allocator. It can be written to
84 clear the current count.
85 Available when CONFIG_SLUB_STATS is enabled.
87 What: /sys/kernel/slab/cache/alloc_slowpath
93 The alloc_slowpath file shows how many objects have been
94 allocated using the slow path because of a refill or
95 allocation from a partial or new slab. It can be written to
96 clear the current count.
97 Available when CONFIG_SLUB_STATS is enabled.
99 What: /sys/kernel/slab/cache/cache_dma
101 KernelVersion: 2.6.22
105 The cache_dma file is read-only and specifies whether objects
107 Available when CONFIG_ZONE_DMA is enabled.
109 What: /sys/kernel/slab/cache/cpu_slabs
111 KernelVersion: 2.6.22
115 The cpu_slabs file is read-only and displays how many cpu slabs
116 are active and their NUMA locality.
118 What: /sys/kernel/slab/cache/cpuslab_flush
120 KernelVersion: 2.6.31
124 The file cpuslab_flush shows how many times a cache's cpu slabs
125 have been flushed as the result of destroying or shrinking a
126 cache, a cpu going offline, or as the result of forcing an
127 allocation from a certain node. It can be written to clear the
129 Available when CONFIG_SLUB_STATS is enabled.
131 What: /sys/kernel/slab/cache/ctor
133 KernelVersion: 2.6.22
137 The ctor file is read-only and specifies the cache's object
138 constructor function, which is invoked for each object when a
139 new slab is allocated.
141 What: /sys/kernel/slab/cache/deactivate_empty
143 KernelVersion: 2.6.25
147 The deactivate_empty file shows how many times an empty cpu slab
148 was deactivated. It can be written to clear the current count.
149 Available when CONFIG_SLUB_STATS is enabled.
151 What: /sys/kernel/slab/cache/deactivate_full
153 KernelVersion: 2.6.25
157 The deactivate_full file shows how many times a full cpu slab
158 was deactivated. It can be written to clear the current count.
159 Available when CONFIG_SLUB_STATS is enabled.
161 What: /sys/kernel/slab/cache/deactivate_remote_frees
163 KernelVersion: 2.6.25
167 The deactivate_remote_frees file shows how many times a cpu slab
168 has been deactivated and contained free objects that were freed
169 remotely. It can be written to clear the current count.
170 Available when CONFIG_SLUB_STATS is enabled.
172 What: /sys/kernel/slab/cache/deactivate_to_head
174 KernelVersion: 2.6.25
178 The deactivate_to_head file shows how many times a partial cpu
179 slab was deactivated and added to the head of its node's partial
180 list. It can be written to clear the current count.
181 Available when CONFIG_SLUB_STATS is enabled.
183 What: /sys/kernel/slab/cache/deactivate_to_tail
185 KernelVersion: 2.6.25
189 The deactivate_to_tail file shows how many times a partial cpu
190 slab was deactivated and added to the tail of its node's partial
191 list. It can be written to clear the current count.
192 Available when CONFIG_SLUB_STATS is enabled.
194 What: /sys/kernel/slab/cache/destroy_by_rcu
196 KernelVersion: 2.6.22
200 The destroy_by_rcu file is read-only and specifies whether
201 slabs (not objects) are freed by rcu.
203 What: /sys/kernel/slab/cache/free_add_partial
205 KernelVersion: 2.6.25
209 The free_add_partial file shows how many times an object has
210 been freed in a full slab so that it had to added to its node's
211 partial list. It can be written to clear the current count.
212 Available when CONFIG_SLUB_STATS is enabled.
214 What: /sys/kernel/slab/cache/free_calls
216 KernelVersion: 2.6.22
220 The free_calls file is read-only and lists the locations of
221 object frees if slab debugging is enabled (see
222 Documentation/vm/slub.txt).
224 What: /sys/kernel/slab/cache/free_fastpath
226 KernelVersion: 2.6.25
230 The free_fastpath file shows how many objects have been freed
231 using the fast path because it was an object from the cpu slab.
232 It can be written to clear the current count.
233 Available when CONFIG_SLUB_STATS is enabled.
235 What: /sys/kernel/slab/cache/free_frozen
237 KernelVersion: 2.6.25
241 The free_frozen file shows how many objects have been freed to
242 a frozen slab (i.e. a remote cpu slab). It can be written to
243 clear the current count.
244 Available when CONFIG_SLUB_STATS is enabled.
246 What: /sys/kernel/slab/cache/free_remove_partial
248 KernelVersion: 2.6.25
252 The free_remove_partial file shows how many times an object has
253 been freed to a now-empty slab so that it had to be removed from
254 its node's partial list. It can be written to clear the current
256 Available when CONFIG_SLUB_STATS is enabled.
258 What: /sys/kernel/slab/cache/free_slab
260 KernelVersion: 2.6.25
264 The free_slab file shows how many times an empty slab has been
265 freed back to the page allocator. It can be written to clear
267 Available when CONFIG_SLUB_STATS is enabled.
269 What: /sys/kernel/slab/cache/free_slowpath
271 KernelVersion: 2.6.25
275 The free_slowpath file shows how many objects have been freed
276 using the slow path (i.e. to a full or partial slab). It can
277 be written to clear the current count.
278 Available when CONFIG_SLUB_STATS is enabled.
280 What: /sys/kernel/slab/cache/hwcache_align
282 KernelVersion: 2.6.22
286 The hwcache_align file is read-only and specifies whether
287 objects are aligned on cachelines.
289 What: /sys/kernel/slab/cache/min_partial
291 KernelVersion: 2.6.30
295 The min_partial file specifies how many empty slabs shall
296 remain on a node's partial list to avoid the overhead of
297 allocating new slabs. Such slabs may be reclaimed by utilizing
300 What: /sys/kernel/slab/cache/object_size
302 KernelVersion: 2.6.22
306 The object_size file is read-only and specifies the cache's
309 What: /sys/kernel/slab/cache/objects
311 KernelVersion: 2.6.22
315 The objects file is read-only and displays how many objects are
316 active and from which nodes they are from.
318 What: /sys/kernel/slab/cache/objects_partial
320 KernelVersion: 2.6.26
324 The objects_partial file is read-only and displays how many
325 objects are on partial slabs and from which nodes they are
328 What: /sys/kernel/slab/cache/objs_per_slab
330 KernelVersion: 2.6.22
334 The file objs_per_slab is read-only and specifies how many
335 objects may be allocated from a single slab of the order
336 specified in /sys/kernel/slab/cache/order.
338 What: /sys/kernel/slab/cache/order
340 KernelVersion: 2.6.22
344 The order file specifies the page order at which new slabs are
345 allocated. It is writable and can be changed to increase the
346 number of objects per slab. If a slab cannot be allocated
347 because of fragmentation, SLUB will retry with the minimum order
348 possible depending on its characteristics.
349 When debug_guardpage_minorder=N (N > 0) parameter is specified
350 (see Documentation/kernel-parameters.txt), the minimum possible
351 order is used and this sysfs entry can not be used to change
352 the order at run time.
354 What: /sys/kernel/slab/cache/order_fallback
356 KernelVersion: 2.6.26
360 The order_fallback file shows how many times an allocation of a
361 new slab has not been possible at the cache's order and instead
362 fallen back to its minimum possible order. It can be written to
363 clear the current count.
364 Available when CONFIG_SLUB_STATS is enabled.
366 What: /sys/kernel/slab/cache/partial
368 KernelVersion: 2.6.22
372 The partial file is read-only and displays how long many
373 partial slabs there are and how long each node's list is.
375 What: /sys/kernel/slab/cache/poison
377 KernelVersion: 2.6.22
381 The poison file specifies whether objects should be poisoned
382 when a new slab is allocated.
384 What: /sys/kernel/slab/cache/reclaim_account
386 KernelVersion: 2.6.22
390 The reclaim_account file specifies whether the cache's objects
391 are reclaimable (and grouped by their mobility).
393 What: /sys/kernel/slab/cache/red_zone
395 KernelVersion: 2.6.22
399 The red_zone file specifies whether the cache's objects are red
402 What: /sys/kernel/slab/cache/remote_node_defrag_ratio
404 KernelVersion: 2.6.25
408 The file remote_node_defrag_ratio specifies the percentage of
409 times SLUB will attempt to refill the cpu slab with a partial
410 slab from a remote node as opposed to allocating a new slab on
411 the local node. This reduces the amount of wasted memory over
412 the entire system but can be expensive.
413 Available when CONFIG_NUMA is enabled.
415 What: /sys/kernel/slab/cache/sanity_checks
417 KernelVersion: 2.6.22
421 The sanity_checks file specifies whether expensive checks
422 should be performed on free and, at minimum, enables double free
423 checks. Caches that enable sanity_checks cannot be merged with
426 What: /sys/kernel/slab/cache/shrink
428 KernelVersion: 2.6.22
432 The shrink file is written when memory should be reclaimed from
433 a cache. Empty partial slabs are freed and the partial list is
434 sorted so the slabs with the fewest available objects are used
437 What: /sys/kernel/slab/cache/slab_size
439 KernelVersion: 2.6.22
443 The slab_size file is read-only and specifies the object size
444 with metadata (debugging information and alignment) in bytes.
446 What: /sys/kernel/slab/cache/slabs
448 KernelVersion: 2.6.22
452 The slabs file is read-only and displays how long many slabs
453 there are (both cpu and partial) and from which nodes they are
456 What: /sys/kernel/slab/cache/store_user
458 KernelVersion: 2.6.22
462 The store_user file specifies whether the location of
463 allocation or free should be tracked for a cache.
465 What: /sys/kernel/slab/cache/total_objects
467 KernelVersion: 2.6.26
471 The total_objects file is read-only and displays how many total
472 objects a cache has and from which nodes they are from.
474 What: /sys/kernel/slab/cache/trace
476 KernelVersion: 2.6.22
480 The trace file specifies whether object allocations and frees
483 What: /sys/kernel/slab/cache/validate
485 KernelVersion: 2.6.22
489 Writing to the validate file causes SLUB to traverse all of its
490 cache's objects and check the validity of metadata.