mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2024-12-25 13:07:17 +00:00
state: take write lock in GetNonce (#3625)
We must take a write lock here because `GetNonce` calls `StateDB.GetStateObject`, which mutates the DB's live set.
This commit is contained in:
parent
4f5f90222f
commit
296450451b
@ -82,10 +82,12 @@ func (ms *ManagedState) NewNonce(addr common.Address) uint64 {
|
|||||||
return uint64(len(account.nonces)-1) + account.nstart
|
return uint64(len(account.nonces)-1) + account.nstart
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetNonce returns the canonical nonce for the managed or unmanaged account
|
// GetNonce returns the canonical nonce for the managed or unmanaged account.
|
||||||
|
//
|
||||||
|
// Because GetNonce mutates the DB, we must take a write lock.
|
||||||
func (ms *ManagedState) GetNonce(addr common.Address) uint64 {
|
func (ms *ManagedState) GetNonce(addr common.Address) uint64 {
|
||||||
ms.mu.RLock()
|
ms.mu.Lock()
|
||||||
defer ms.mu.RUnlock()
|
defer ms.mu.Unlock()
|
||||||
|
|
||||||
if ms.hasAccount(addr) {
|
if ms.hasAccount(addr) {
|
||||||
account := ms.getAccount(addr)
|
account := ms.getAccount(addr)
|
||||||
|
Loading…
Reference in New Issue
Block a user