From 36d447d465700b82b67dd4b825c7f94b4f35fc37 Mon Sep 17 00:00:00 2001 From: jeff washington Date: Thu, 6 Apr 2023 17:32:12 -0500 Subject: [PATCH] disk index: keep same random during resize --- bucket_map/src/bucket.rs | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/bucket_map/src/bucket.rs b/bucket_map/src/bucket.rs index d5ab4595789af2..e1dd9b1b565cc8 100644 --- a/bucket_map/src/bucket.rs +++ b/bucket_map/src/bucket.rs @@ -31,7 +31,7 @@ use { pub struct ReallocatedItems { // Some if the index was reallocated // u64 is random associated with the new index - pub index: Option<(u64, BucketStorage)>, + pub index: Option>, // Some for a data bucket reallocation // u64 is data bucket index pub data: Option<(u64, BucketStorage)>, @@ -460,12 +460,12 @@ impl<'b, T: Clone + Copy + 'static> Bucket { // index may have allocated something larger than we asked for, // so, in case we fail to reindex into this larger size, grow from this size next iteration. current_capacity = index.capacity(); - let random = thread_rng().gen(); let mut valid = true; for ix in 0..self.index.capacity() { if !self.index.is_free(ix) { let elem: &IndexEntry = self.index.get(ix); - let new_ix = Self::bucket_create_key(&mut index, &elem.key, random, true); + let new_ix = + Self::bucket_create_key(&mut index, &elem.key, self.random, true); if new_ix.is_err() { valid = false; break; @@ -486,7 +486,7 @@ impl<'b, T: Clone + Copy + 'static> Bucket { if valid { self.stats.index.update_max_size(index.capacity()); let mut items = self.reallocated.items.lock().unwrap(); - items.index = Some((random, index)); + items.index = Some(index); self.reallocated.add_reallocation(); break; } @@ -506,12 +506,11 @@ impl<'b, T: Clone + Copy + 'static> Bucket { } } - pub fn apply_grow_index(&mut self, random: u64, index: BucketStorage>) { + pub fn apply_grow_index(&mut self, index: BucketStorage>) { self.stats .index .resize_grow(self.index.capacity_bytes(), index.capacity_bytes()); - self.random = random; self.index = index; } @@ -601,8 +600,8 @@ impl<'b, T: Clone + Copy + 'static> Bucket { // swap out the bucket that was resized previously with a read lock let mut items = std::mem::take(&mut *self.reallocated.items.lock().unwrap()); - if let Some((random, bucket)) = items.index.take() { - self.apply_grow_index(random, bucket); + if let Some(bucket) = items.index.take() { + self.apply_grow_index(bucket); } else { // data bucket let (i, new_bucket) = items.data.take().unwrap();