From edc7c2dd25098c76d720964651244649d662bfea Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Wojciech=20Ma=C5=82ota-W=C3=B3jcik?= <59281144+outofforest@users.noreply.github.com> Date: Thu, 21 Nov 2024 22:42:09 +0100 Subject: [PATCH] Optimize update detection (#222) --- pipeline/pipeline.go | 3 ++- space/space.go | 35 ++++++++++++++++++----------------- 2 files changed, 20 insertions(+), 18 deletions(-) diff --git a/pipeline/pipeline.go b/pipeline/pipeline.go index 3b40baa..b3b15e5 100644 --- a/pipeline/pipeline.go +++ b/pipeline/pipeline.go @@ -28,6 +28,7 @@ const ( // StoreCapacity is the maximum capacity of store array in store request. StoreCapacity = 10 + sleepDuration = 10 * time.Microsecond atomicDivider = 100 ) @@ -143,7 +144,7 @@ func (qr *Reader) Read(ctx context.Context) (*TransactionRequest, error) { break } - time.Sleep(10 * time.Microsecond) + time.Sleep(sleepDuration) if ctx.Err() != nil { return nil, errors.WithStack(ctx.Err()) diff --git a/space/space.go b/space/space.go index 573d0ad..194587e 100644 --- a/space/space.go +++ b/space/space.go @@ -7,6 +7,7 @@ import ( "unsafe" "github.com/cespare/xxhash" + "github.com/samber/lo" "github.com/outofforest/mass" "github.com/outofforest/photon" @@ -33,7 +34,8 @@ func New[K, V comparable](config Config[K, V]) *Space[K, V] { } defaultInit := Entry[K, V]{ - space: s, + space: s, + nextDataNodeState: lo.ToPtr(types.StateFree), storeRequest: pipeline.StoreRequest{ NoSnapshots: s.config.NoSnapshots, PointersToStore: 1, @@ -584,7 +586,7 @@ func (s *Space[K, V]) walkPointers(v *Entry[K, V], hashBuff []byte) { v.storeRequest.PointersToStore++ v.parentIndex = index if nextIndex == index { - v.nextDataNodeState = nil + v.nextDataNodeState = lo.ToPtr(types.StateFree) } else { v.nextDataNodeState = &pointerNode.Pointers[nextIndex].State } @@ -629,19 +631,19 @@ func (s *Space[K, V]) walkDataItems(v *Entry[K, V], hashMatches []uint64) bool { // Entry represents entry in the space. type Entry[K, V comparable] struct { - space *Space[K, V] - storeRequest pipeline.StoreRequest - - itemP *types.DataItem[K, V] - keyHashP *types.KeyHash - keyHash types.KeyHash - key K - value V + space *Space[K, V] nextDataNodeState *types.State - parentIndex uint64 - dataItemIndex uint64 - exists bool - level uint8 + storeRequest pipeline.StoreRequest + + itemP *types.DataItem[K, V] + keyHashP *types.KeyHash + keyHash types.KeyHash + key K + value V + parentIndex uint64 + dataItemIndex uint64 + exists bool + level uint8 } // Value returns the value from entry. @@ -710,15 +712,14 @@ func dataItemIndex(keyHash types.KeyHash, numOfDataItems uint64) uint64 { } func detectUpdate[K, V comparable](v *Entry[K, V]) { - pointer := v.storeRequest.Store[v.storeRequest.PointersToStore-1].Pointer switch { - case v.nextDataNodeState != nil && *v.nextDataNodeState != types.StateFree: + case *v.nextDataNodeState != types.StateFree: v.storeRequest.PointersToStore-- v.level-- v.keyHashP = nil v.itemP = nil - case v.keyHashP != nil && (pointer.State != types.StateData || + case v.keyHashP != nil && (v.storeRequest.Store[v.storeRequest.PointersToStore-1].Pointer.State != types.StateData || (*v.keyHashP != 0 && (*v.keyHashP != v.keyHash || v.itemP.Key != v.key))): v.keyHashP = nil v.itemP = nil