Skip to content

Commit

Permalink
use atomic uint64
Browse files Browse the repository at this point in the history
  • Loading branch information
beer-1 committed Nov 9, 2024
1 parent 240904b commit 4409ec9
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 5 deletions.
8 changes: 5 additions & 3 deletions x/evm/keeper/keeper.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package keeper

import (
"context"
"sync/atomic"

"cosmossdk.io/collections"
"cosmossdk.io/core/address"
Expand Down Expand Up @@ -49,7 +50,7 @@ type Keeper struct {

// execIndex is unique index for each execution, which is used
// unique key for transient stores.
execIndex *uint64
execIndex *atomic.Uint64

// transient store
TSchema collections.Schema
Expand Down Expand Up @@ -110,7 +111,8 @@ func NewKeeper(
panic(err)
}

execIndex := uint64(0)
execIndex := &atomic.Uint64{}
execIndex.Store(0)
k := &Keeper{
ac: ac,
cdc: cdc,
Expand All @@ -131,7 +133,7 @@ func NewKeeper(
Params: collections.NewItem(sb, types.ParamsKey, "params", codec.CollValue[types.Params](cdc)),
VMStore: collections.NewMap(sb, types.VMStorePrefix, "vm_store", collections.BytesKey, collections.BytesValue),

execIndex: &execIndex,
execIndex: execIndex,

TransientVMStore: collections.NewMap(tsb, types.TransientVMStorePrefix, "transient_vm_store", collections.PairKeyCodec(collections.Uint64Key, collections.BytesKey), collections.BytesValue),
TransientCreated: collections.NewKeySet(tsb, types.TransientCreatedPrefix, "transient_created", collections.PairKeyCodec(collections.Uint64Key, collections.BytesKey)),
Expand Down
4 changes: 2 additions & 2 deletions x/evm/state/statedb.go
Original file line number Diff line number Diff line change
Expand Up @@ -73,13 +73,13 @@ func NewStateDB(
transientLogSize collections.Map[uint64, uint64],
transientAccessList collections.KeySet[collections.Pair[uint64, []byte]],
transientRefund collections.Map[uint64, uint64],
execIndex *uint64,
execIndex *atomic.Uint64,
// erc20 params
evm callableEVM,
erc20ABI *abi.ABI,
feeContractAddr common.Address,
) (*StateDB, error) {
eidx := atomic.AddUint64(execIndex, 1)
eidx := execIndex.Add(1)

err := transientLogSize.Set(ctx, eidx, 0)
if err != nil {
Expand Down

0 comments on commit 4409ec9

Please sign in to comment.