at a final spacing class of 1 slot size classes

pull/87/head
Daniel Micay 2019-04-10 16:32:24 -04:00
parent 7a89a7b8c5
commit 086eb1fee4
3 changed files with 27 additions and 17 deletions

View File

@ -407,17 +407,18 @@ The slab allocation size classes end at 16384 since that's the final size for
bytes on the target platforms. This is the minimum set of small size classes bytes on the target platforms. This is the minimum set of small size classes
required to avoid substantial waste from rounding. required to avoid substantial waste from rounding.
The `CONFIG_EXTENDED_SIZE_CLASSES` option extends the size classes up to 65536, The `CONFIG_EXTENDED_SIZE_CLASSES` option extends the size classes up to
with a final spacing class of 16384. This offers improved performance compared 131072, with a final spacing class of 16384. This offers improved performance
to the minimum set of size classes. The security story is complicated, since compared to the minimum set of size classes. The security story is complicated,
the slab allocation has both advantages like size class isolation completely since the slab allocation has both advantages like size class isolation
avoiding reuse of any of the address space for any other size classes or other completely avoiding reuse of any of the address space for any other size
data. It also has disadvantages like caching a small number of empty slabs and classes or other data. It also has disadvantages like caching a small number of
deterministic guard sizes. The cache will be configurable in the future, making empty slabs and deterministic guard sizes. The cache will be configurable in
it possible to disable slab caching for the largest slab allocation sizes, to the future, making it possible to disable slab caching for the largest slab
force unmapping them immediately and putting them in the slab quarantine, which allocation sizes, to force unmapping them immediately and putting them in the
eliminates most of the security disadvantage at the expense of also giving up slab quarantine, which eliminates most of the security disadvantage at the
most of the performance advantage, but while retaining the isolation. expense of also giving up most of the performance advantage, but while
retaining the isolation.
| size class | worst case internal fragmentation | slab slots | slab size | internal fragmentation for slabs | | size class | worst case internal fragmentation | slab slots | slab size | internal fragmentation for slabs |
| - | - | - | - | - | | - | - | - | - | - |
@ -425,10 +426,14 @@ most of the performance advantage, but while retaining the isolation.
| 24576 | 16.66259765625% | 2 | 49152 | 0.0% | | 24576 | 16.66259765625% | 2 | 49152 | 0.0% |
| 28672 | 14.2822265625% | 2 | 57344 | 0.0% | | 28672 | 14.2822265625% | 2 | 57344 | 0.0% |
| 32768 | 12.4969482421875% | 2 | 65536 | 0.0% | | 32768 | 12.4969482421875% | 2 | 65536 | 0.0% |
| 40960 | 19.99755859375% | 2 | 81920 | 0.0% | | 40960 | 19.99755859375% | 1 | 40960 | 0.0% |
| 49152 | 16.664632161458343% | 2 | 98304 | 0.0% | | 49152 | 16.664632161458343% | 1 | 49152 | 0.0% |
| 57344 | 14.283970424107139% | 2 | 114688 | 0.0% | | 57344 | 14.283970424107139% | 1 | 57344 | 0.0% |
| 65536 | 12.49847412109375% | 2 | 131072 | 0.0% | | 65536 | 12.49847412109375% | 1 | 65536 | 0.0% |
| 81920 | 19.998779296875% | 1 | 81920 | 0.0% |
| 98304 | 16.6656494140625% | 1 | 98304 | 0.0% |
| 114688 | 14.284842354910708% | 1 | 114688 | 0.0% |
| 131072 | 12.499237060546875% | 1 | 131072 | 0.0% |
The `CONFIG_LARGE_SIZE_CLASSES` option controls whether large allocations use The `CONFIG_LARGE_SIZE_CLASSES` option controls whether large allocations use
the same size class scheme providing 4 size classes for every doubling of size. the same size class scheme providing 4 size classes for every doubling of size.

View File

@ -12,7 +12,8 @@ size_classes = [
5120, 6144, 7168, 8192, 5120, 6144, 7168, 8192,
10240, 12288, 14336, 16384, 10240, 12288, 14336, 16384,
20480, 24576, 28672, 32768, 20480, 24576, 28672, 32768,
40960, 49152, 57344, 65536 40960, 49152, 57344, 65536,
81920, 98304, 114688, 131072,
] ]
size_class_slots = [ size_class_slots = [
@ -25,7 +26,8 @@ size_class_slots = [
8, 8, 8, 8, 8, 8, 8, 8,
6, 5, 4, 4, 6, 5, 4, 4,
2, 2, 2, 2, 2, 2, 2, 2,
2, 2, 2, 2 1, 1, 1, 1,
1, 1, 1, 1,
] ]
fragmentation = [100 - 1 / 16 * 100] fragmentation = [100 - 1 / 16 * 100]

View File

@ -119,6 +119,7 @@ static const u32 size_classes[] = {
#if CONFIG_EXTENDED_SIZE_CLASSES #if CONFIG_EXTENDED_SIZE_CLASSES
/* 4096 */ 20480, 24576, 28672, 32768, /* 4096 */ 20480, 24576, 28672, 32768,
/* 8192 */ 40960, 49152, 57344, 65536, /* 8192 */ 40960, 49152, 57344, 65536,
/* 16384 */ 81920, 98304, 114688, 131072,
#endif #endif
}; };
@ -135,6 +136,7 @@ static const u16 size_class_slots[] = {
#if CONFIG_EXTENDED_SIZE_CLASSES #if CONFIG_EXTENDED_SIZE_CLASSES
/* 4096 */ 2, 2, 2, 2, /* 4096 */ 2, 2, 2, 2,
/* 8192 */ 1, 1, 1, 1, /* 8192 */ 1, 1, 1, 1,
/* 16384 */ 1, 1, 1, 1,
#endif #endif
}; };
@ -152,6 +154,7 @@ static const char *const size_class_labels[] = {
#if CONFIG_EXTENDED_SIZE_CLASSES #if CONFIG_EXTENDED_SIZE_CLASSES
/* 4096 */ "malloc 20480", "malloc 24576", "malloc 28672", "malloc 32768", /* 4096 */ "malloc 20480", "malloc 24576", "malloc 28672", "malloc 32768",
/* 8192 */ "malloc 40960", "malloc 49152", "malloc 57344", "malloc 65536", /* 8192 */ "malloc 40960", "malloc 49152", "malloc 57344", "malloc 65536",
/* 16384 */ "malloc 81920", "malloc 98304", "malloc 114688", "malloc 131072",
#endif #endif
}; };