Skip to content

Commit

Permalink
add cache for genesis ID
Browse files Browse the repository at this point in the history
  • Loading branch information
uprendis committed Jun 26, 2022
1 parent 52613a1 commit 38e969f
Show file tree
Hide file tree
Showing 3 changed files with 8 additions and 0 deletions.
1 change: 1 addition & 0 deletions gossip/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -210,6 +210,7 @@ func newService(config Config, store *Store, blockProc BlockProc, engine lachesi
svc.store.GetLastEVs()
svc.store.GetLlrState()
svc.store.GetUpgradeHeights()
svc.store.GetGenesisID()
netVerStore := verwatcher.NewStore(store.table.NetworkVersion)
netVerStore.GetNetworkVersion()
netVerStore.GetMissedVersion()
Expand Down
1 change: 1 addition & 0 deletions gossip/store.go
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ type Store struct {
LlrState atomic.Value // store by value
KvdbEvmSnap atomic.Value // store by pointer
UpgradeHeights atomic.Value // store by pointer
Genesis atomic.Value // store by value
}

mutex struct {
Expand Down
6 changes: 6 additions & 0 deletions gossip/store_block.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,10 @@ import (
)

func (s *Store) GetGenesisID() *hash.Hash {
if v := s.cache.Genesis.Load(); v != nil {
val := v.(hash.Hash)
return &val
}
valBytes, err := s.table.Genesis.Get([]byte("g"))
if err != nil {
s.Log.Crit("Failed to get key-value", "err", err)
Expand All @@ -21,6 +25,7 @@ func (s *Store) GetGenesisID() *hash.Hash {
return nil
}
val := hash.BytesToHash(valBytes)
s.cache.Genesis.Store(val)
return &val
}

Expand All @@ -29,6 +34,7 @@ func (s *Store) SetGenesisID(val hash.Hash) {
if err != nil {
s.Log.Crit("Failed to put key-value", "err", err)
}
s.cache.Genesis.Store(val)
}

// SetBlock stores chain block.
Expand Down

0 comments on commit 38e969f

Please sign in to comment.