mirror of
https://github.com/status-im/op-geth.git
synced 2025-01-28 07:25:18 +00:00
Merge pull request #16491 from holiman/fix_copy_again
core/state: fix ripemd-cornercase in Copy
This commit is contained in:
commit
7e911b8e47
@ -471,8 +471,14 @@ func (self *StateDB) Copy() *StateDB {
|
|||||||
}
|
}
|
||||||
// Copy the dirty states, logs, and preimages
|
// Copy the dirty states, logs, and preimages
|
||||||
for addr := range self.journal.dirties {
|
for addr := range self.journal.dirties {
|
||||||
state.stateObjects[addr] = self.stateObjects[addr].deepCopy(state)
|
// As documented [here](https://github.com/ethereum/go-ethereum/pull/16485#issuecomment-380438527),
|
||||||
state.stateObjectsDirty[addr] = struct{}{}
|
// and in the Finalise-method, there is a case where an object is in the journal but not
|
||||||
|
// in the stateObjects: OOG after touch on ripeMD prior to Byzantium. Thus, we need to check for
|
||||||
|
// nil
|
||||||
|
if object, exist := self.stateObjects[addr]; exist {
|
||||||
|
state.stateObjects[addr] = object.deepCopy(state)
|
||||||
|
state.stateObjectsDirty[addr] = struct{}{}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// Above, we don't copy the actual journal. This means that if the copy is copied, the
|
// Above, we don't copy the actual journal. This means that if the copy is copied, the
|
||||||
// loop above will be a no-op, since the copy's journal is empty.
|
// loop above will be a no-op, since the copy's journal is empty.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user