add slot randomization to configuration header

This commit is contained in:
Daniel Micay 2018-09-07 00:25:02 -04:00
parent bed303a76f
commit ba3a8b0058
2 changed files with 9 additions and 5 deletions

View File

@ -3,5 +3,6 @@
#define GUARD_SLABS true
#define WRITE_AFTER_FREE_CHECK true
#define SLOT_RANDOMIZE true
#endif

View File

@ -204,13 +204,16 @@ static size_t get_free_slot(struct random_state *rng, size_t slots, struct slab_
fatal_error("no zero bits");
}
// randomize start location for linear search (uniform random choice is too slow)
uint64_t random_split = ~(~0UL << get_random_u16_uniform(rng, slots));
if (SLOT_RANDOMIZE) {
// randomize start location for linear search (uniform random choice is too slow)
uint64_t random_split = ~(~0UL << get_random_u16_uniform(rng, slots));
size_t slot = ffzl(masked | random_split);
if (slot) {
return slot - 1;
size_t slot = ffzl(masked | random_split);
if (slot) {
return slot - 1;
}
}
return ffzl(masked) - 1;
}