avoid duplicated init code calculating slab size
parent
eec85b0c8c
commit
67b9608ccf
6
malloc.c
6
malloc.c
|
@ -637,9 +637,9 @@ COLD static void init_slow_path(void) {
|
||||||
size = 16;
|
size = 16;
|
||||||
}
|
}
|
||||||
c->size_divisor = libdivide_u32_gen(size);
|
c->size_divisor = libdivide_u32_gen(size);
|
||||||
c->slab_size_divisor = libdivide_u64_gen(get_slab_size(size_class_slots[i], size));
|
size_t slab_size = get_slab_size(size_class_slots[i], size);
|
||||||
size_t slots = size_class_slots[i];
|
c->slab_size_divisor = libdivide_u64_gen(slab_size);
|
||||||
size_t metadata_max = get_metadata_max(get_slab_size(slots, size));
|
size_t metadata_max = get_metadata_max(slab_size);
|
||||||
c->slab_info = allocate_pages(metadata_max * sizeof(struct slab_metadata), PAGE_SIZE, false);
|
c->slab_info = allocate_pages(metadata_max * sizeof(struct slab_metadata), PAGE_SIZE, false);
|
||||||
if (c->slab_info == NULL) {
|
if (c->slab_info == NULL) {
|
||||||
fatal_error("failed to allocate slab metadata");
|
fatal_error("failed to allocate slab metadata");
|
||||||
|
|
Loading…
Reference in New Issue