mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-19 00:54:12 +00:00
Typify commitment (#454)
This commit is contained in:
parent
6de4ac4ba9
commit
15d2a37c0b
@ -233,7 +233,7 @@ func (hph *BinHashed) ResetFns(
|
|||||||
hph.storageFn = wrapAccountStorageFn(storageFn)
|
hph.storageFn = wrapAccountStorageFn(storageFn)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (hph *BinHashed) completeLeafHash(buf []byte, keyPrefix []byte, kp, kl, compactLen int, key []byte, compact0 byte, ni int, val rlp.RlpSerializable, singleton bool) ([]byte, error) {
|
func (hph *BinHashed) completeLeafHash(buf, keyPrefix []byte, kp, kl, compactLen int, key []byte, compact0 byte, ni int, val rlp.RlpSerializable, singleton bool) ([]byte, error) {
|
||||||
totalLen := kp + kl + val.DoubleRLPLen()
|
totalLen := kp + kl + val.DoubleRLPLen()
|
||||||
var lenPrefix [4]byte
|
var lenPrefix [4]byte
|
||||||
pt := rlp.GenerateStructLen(lenPrefix[:], totalLen)
|
pt := rlp.GenerateStructLen(lenPrefix[:], totalLen)
|
||||||
@ -281,7 +281,7 @@ func (hph *BinHashed) completeLeafHash(buf []byte, keyPrefix []byte, kp, kl, com
|
|||||||
return buf, nil
|
return buf, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (hph *BinHashed) leafHashWithKeyVal(buf []byte, key []byte, val rlp.RlpSerializableBytes, singleton bool) ([]byte, error) {
|
func (hph *BinHashed) leafHashWithKeyVal(buf, key []byte, val rlp.RlpSerializableBytes, singleton bool) ([]byte, error) {
|
||||||
// Compute the total length of binary representation
|
// Compute the total length of binary representation
|
||||||
var kp, kl int
|
var kp, kl int
|
||||||
// Write key
|
// Write key
|
||||||
@ -303,11 +303,7 @@ func (hph *BinHashed) leafHashWithKeyVal(buf []byte, key []byte, val rlp.RlpSeri
|
|||||||
} else {
|
} else {
|
||||||
kl = 1
|
kl = 1
|
||||||
}
|
}
|
||||||
buf, err := hph.completeLeafHash(buf, keyPrefix[:], kp, kl, compactLen, key, compact0, ni, val, singleton)
|
return hph.completeLeafHash(buf, keyPrefix[:], kp, kl, compactLen, key, compact0, ni, val, singleton)
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return buf, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (hph *BinHashed) accountLeafHashWithKey(buf, key []byte, val rlp.RlpSerializable) ([]byte, error) {
|
func (hph *BinHashed) accountLeafHashWithKey(buf, key []byte, val rlp.RlpSerializable) ([]byte, error) {
|
||||||
@ -340,14 +336,12 @@ func (hph *BinHashed) accountLeafHashWithKey(buf, key []byte, val rlp.RlpSeriali
|
|||||||
} else {
|
} else {
|
||||||
kl = 1
|
kl = 1
|
||||||
}
|
}
|
||||||
var err error
|
return hph.completeLeafHash(buf, keyPrefix[:], kp, kl, compactLen, key, compact0, ni, val, true)
|
||||||
if buf, err = hph.completeLeafHash(buf, keyPrefix[:], kp, kl, compactLen, key, compact0, ni, val, true); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return buf, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (hph *BinHashed) extensionHash(buf []byte, key []byte, hash []byte) ([]byte, error) {
|
func (hph *BinHashed) extensionHash(key []byte, hash []byte) ([length.Hash]byte, error) {
|
||||||
|
var hashBuf [length.Hash]byte
|
||||||
|
|
||||||
// Compute the total length of binary representation
|
// Compute the total length of binary representation
|
||||||
var kp, kl int
|
var kp, kl int
|
||||||
// Write key
|
// Write key
|
||||||
@ -382,37 +376,35 @@ func (hph *BinHashed) extensionHash(buf []byte, key []byte, hash []byte) ([]byte
|
|||||||
pt := rlp.GenerateStructLen(lenPrefix[:], totalLen)
|
pt := rlp.GenerateStructLen(lenPrefix[:], totalLen)
|
||||||
hph.keccak.Reset()
|
hph.keccak.Reset()
|
||||||
if _, err := hph.keccak.Write(lenPrefix[:pt]); err != nil {
|
if _, err := hph.keccak.Write(lenPrefix[:pt]); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
if _, err := hph.keccak.Write(keyPrefix[:kp]); err != nil {
|
if _, err := hph.keccak.Write(keyPrefix[:kp]); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
var b [1]byte
|
var b [1]byte
|
||||||
b[0] = compact0
|
b[0] = compact0
|
||||||
if _, err := hph.keccak.Write(b[:]); err != nil {
|
if _, err := hph.keccak.Write(b[:]); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
for i := 1; i < compactLen; i++ {
|
for i := 1; i < compactLen; i++ {
|
||||||
b[0] = key[ni]*16 + key[ni+1]
|
b[0] = key[ni]*16 + key[ni+1]
|
||||||
if _, err := hph.keccak.Write(b[:]); err != nil {
|
if _, err := hph.keccak.Write(b[:]); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
ni += 2
|
ni += 2
|
||||||
}
|
}
|
||||||
b[0] = 0x80 + length.Hash
|
b[0] = 0x80 + length.Hash
|
||||||
if _, err := hph.keccak.Write(b[:]); err != nil {
|
if _, err := hph.keccak.Write(b[:]); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
if _, err := hph.keccak.Write(hash); err != nil {
|
if _, err := hph.keccak.Write(hash); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
// Replace previous hash with the new one
|
// Replace previous hash with the new one
|
||||||
var hashBuf [33]byte
|
if _, err := hph.keccak.Read(hashBuf[:]); err != nil {
|
||||||
if _, err := hph.keccak.Read(hashBuf[:length.Hash]); err != nil {
|
return hashBuf, err
|
||||||
return nil, err
|
|
||||||
}
|
}
|
||||||
buf = append(buf, hashBuf[:length.Hash]...)
|
return hashBuf, nil
|
||||||
return buf, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (hph *BinHashed) computeCellHashLen(cell *BinCell, depth int) int {
|
func (hph *BinHashed) computeCellHashLen(cell *BinCell, depth int) int {
|
||||||
@ -439,7 +431,8 @@ func (hph *BinHashed) computeCellHashLen(cell *BinCell, depth int) int {
|
|||||||
|
|
||||||
func (hph *BinHashed) computeCellHash(cell *BinCell, depth int, buf []byte) ([]byte, error) {
|
func (hph *BinHashed) computeCellHash(cell *BinCell, depth int, buf []byte) ([]byte, error) {
|
||||||
var err error
|
var err error
|
||||||
var storageRootHash []byte
|
var storageRootHash [length.Hash]byte
|
||||||
|
storageRootHashIsSet := false
|
||||||
if cell.spl > 0 {
|
if cell.spl > 0 {
|
||||||
var hashedKeyOffset int
|
var hashedKeyOffset int
|
||||||
if depth >= keyHalfSize {
|
if depth >= keyHalfSize {
|
||||||
@ -454,18 +447,15 @@ func (hph *BinHashed) computeCellHash(cell *BinCell, depth int, buf []byte) ([]b
|
|||||||
if hph.trace {
|
if hph.trace {
|
||||||
fmt.Printf("leafHashWithKeyVal(singleton) for [%x]=>[%x]\n", cell.downHashedKey[:keyHalfSize-hashedKeyOffset+1], cell.Storage[:cell.StorageLen])
|
fmt.Printf("leafHashWithKeyVal(singleton) for [%x]=>[%x]\n", cell.downHashedKey[:keyHalfSize-hashedKeyOffset+1], cell.Storage[:cell.StorageLen])
|
||||||
}
|
}
|
||||||
if storageRootHash, err = hph.leafHashWithKeyVal(nil, cell.downHashedKey[:keyHalfSize-hashedKeyOffset+1], rlp.RlpSerializableBytes(cell.Storage[:cell.StorageLen]), true); err != nil {
|
if _, err = hph.leafHashWithKeyVal(storageRootHash[:0], cell.downHashedKey[:keyHalfSize-hashedKeyOffset+1], rlp.RlpSerializableBytes(cell.Storage[:cell.StorageLen]), true); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
storageRootHash = storageRootHash[1:]
|
storageRootHashIsSet = true
|
||||||
} else {
|
} else {
|
||||||
if hph.trace {
|
if hph.trace {
|
||||||
fmt.Printf("leafHashWithKeyVal for [%x]=>[%x]\n", cell.downHashedKey[:keyHalfSize-hashedKeyOffset+1], cell.Storage[:cell.StorageLen])
|
fmt.Printf("leafHashWithKeyVal for [%x]=>[%x]\n", cell.downHashedKey[:keyHalfSize-hashedKeyOffset+1], cell.Storage[:cell.StorageLen])
|
||||||
}
|
}
|
||||||
if buf, err = hph.leafHashWithKeyVal(buf, cell.downHashedKey[:keyHalfSize-hashedKeyOffset+1], rlp.RlpSerializableBytes(cell.Storage[:cell.StorageLen]), false); err != nil {
|
return hph.leafHashWithKeyVal(buf, cell.downHashedKey[:keyHalfSize-hashedKeyOffset+1], rlp.RlpSerializableBytes(cell.Storage[:cell.StorageLen]), false)
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return buf, nil
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if cell.apl > 0 {
|
if cell.apl > 0 {
|
||||||
@ -473,23 +463,23 @@ func (hph *BinHashed) computeCellHash(cell *BinCell, depth int, buf []byte) ([]b
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
cell.downHashedKey[keyHalfSize-depth] = 16 // Add terminator
|
cell.downHashedKey[keyHalfSize-depth] = 16 // Add terminator
|
||||||
if storageRootHash == nil {
|
if !storageRootHashIsSet {
|
||||||
if cell.extLen > 0 {
|
if cell.extLen > 0 {
|
||||||
// Extension
|
// Extension
|
||||||
if cell.hl > 0 {
|
if cell.hl > 0 {
|
||||||
if hph.trace {
|
if hph.trace {
|
||||||
fmt.Printf("extensionHash for [%x]=>[%x]\n", cell.extension[:cell.extLen], cell.h[:cell.hl])
|
fmt.Printf("extensionHash for [%x]=>[%x]\n", cell.extension[:cell.extLen], cell.h[:cell.hl])
|
||||||
}
|
}
|
||||||
if storageRootHash, err = hph.extensionHash(nil, cell.extension[:cell.extLen], cell.h[:cell.hl]); err != nil {
|
if storageRootHash, err = hph.extensionHash(cell.extension[:cell.extLen], cell.h[:cell.hl]); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return nil, fmt.Errorf("computeCellHash extension without hash")
|
return nil, fmt.Errorf("computeCellHash extension without hash")
|
||||||
}
|
}
|
||||||
} else if cell.hl > 0 {
|
} else if cell.hl > 0 {
|
||||||
storageRootHash = cell.h[:cell.hl]
|
storageRootHash = cell.h
|
||||||
} else {
|
} else {
|
||||||
storageRootHash = EmptyRootHash
|
storageRootHash = *(*[length.Hash]byte)(EmptyRootHash)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
var valBuf [128]byte
|
var valBuf [128]byte
|
||||||
@ -497,10 +487,7 @@ func (hph *BinHashed) computeCellHash(cell *BinCell, depth int, buf []byte) ([]b
|
|||||||
if hph.trace {
|
if hph.trace {
|
||||||
fmt.Printf("accountLeafHashWithKey for [%x]=>[%x]\n", cell.downHashedKey[:keyHalfSize+1-depth], valBuf[:valLen])
|
fmt.Printf("accountLeafHashWithKey for [%x]=>[%x]\n", cell.downHashedKey[:keyHalfSize+1-depth], valBuf[:valLen])
|
||||||
}
|
}
|
||||||
if buf, err = hph.accountLeafHashWithKey(buf, cell.downHashedKey[:keyHalfSize+1-depth], rlp.RlpEncodedBytes(valBuf[:valLen])); err != nil {
|
return hph.accountLeafHashWithKey(buf, cell.downHashedKey[:keyHalfSize+1-depth], rlp.RlpEncodedBytes(valBuf[:valLen]))
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return buf, nil
|
|
||||||
}
|
}
|
||||||
buf = append(buf, 0x80+32)
|
buf = append(buf, 0x80+32)
|
||||||
if cell.extLen > 0 {
|
if cell.extLen > 0 {
|
||||||
@ -509,9 +496,11 @@ func (hph *BinHashed) computeCellHash(cell *BinCell, depth int, buf []byte) ([]b
|
|||||||
if hph.trace {
|
if hph.trace {
|
||||||
fmt.Printf("extensionHash for [%x]=>[%x]\n", cell.extension[:cell.extLen], cell.h[:cell.hl])
|
fmt.Printf("extensionHash for [%x]=>[%x]\n", cell.extension[:cell.extLen], cell.h[:cell.hl])
|
||||||
}
|
}
|
||||||
if buf, err = hph.extensionHash(buf, cell.extension[:cell.extLen], cell.h[:cell.hl]); err != nil {
|
var hash [length.Hash]byte
|
||||||
|
if hash, err = hph.extensionHash(cell.extension[:cell.extLen], cell.h[:cell.hl]); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
buf = append(buf, hash[:]...)
|
||||||
} else {
|
} else {
|
||||||
return nil, fmt.Errorf("computeCellHash extension without hash")
|
return nil, fmt.Errorf("computeCellHash extension without hash")
|
||||||
}
|
}
|
||||||
@ -1113,11 +1102,11 @@ func (hph *BinHashed) updateStorage(plainKey, hashedKey, value []byte) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type BinCell struct {
|
type BinCell struct {
|
||||||
h [32]byte // cell hash
|
h [length.Hash]byte // cell hash
|
||||||
hl int // Length of the hash (or embedded)
|
hl int // Length of the hash (or embedded)
|
||||||
apk [20]byte // account plain key
|
apk [length.Addr]byte // account plain key
|
||||||
apl int // length of account plain key
|
apl int // length of account plain key
|
||||||
spk [52]byte // storage plain key
|
spk [length.Addr + length.Hash]byte // storage plain key
|
||||||
spl int // length of the storage plain key
|
spl int // length of the storage plain key
|
||||||
downHashedKey [maxKeySize]byte
|
downHashedKey [maxKeySize]byte
|
||||||
downHashedLen int
|
downHashedLen int
|
||||||
@ -1125,8 +1114,8 @@ type BinCell struct {
|
|||||||
extLen int
|
extLen int
|
||||||
Nonce uint64
|
Nonce uint64
|
||||||
Balance uint256.Int
|
Balance uint256.Int
|
||||||
CodeHash [32]byte // hash of the bytecode
|
CodeHash [length.Hash]byte // hash of the bytecode
|
||||||
Storage [32]byte
|
Storage [length.Hash]byte
|
||||||
StorageLen int
|
StorageLen int
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1233,7 +1222,7 @@ func (cell *BinCell) fillFromLowerCell(lowCell *BinCell, lowDepth int, preExtens
|
|||||||
|
|
||||||
func binHashKey(keccak keccakState, plainKey []byte, dest []byte, hashedKeyOffset int) error {
|
func binHashKey(keccak keccakState, plainKey []byte, dest []byte, hashedKeyOffset int) error {
|
||||||
keccak.Reset()
|
keccak.Reset()
|
||||||
var hashBufBack [32]byte
|
var hashBufBack [length.Hash]byte
|
||||||
hashBuf := hashBufBack[:]
|
hashBuf := hashBufBack[:]
|
||||||
if _, err := keccak.Write(plainKey); err != nil {
|
if _, err := keccak.Write(plainKey); err != nil {
|
||||||
return err
|
return err
|
||||||
@ -1373,7 +1362,7 @@ func (cell *BinCell) fillFromFields(data []byte, pos int, fieldBits PartFlags) (
|
|||||||
return pos, nil
|
return pos, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (cell *BinCell) accountForHashing(buffer, storageRootHash []byte) int {
|
func (cell *BinCell) accountForHashing(buffer []byte, storageRootHash [length.Hash]byte) int {
|
||||||
balanceBytes := 0
|
balanceBytes := 0
|
||||||
if !cell.Balance.LtUint64(128) {
|
if !cell.Balance.LtUint64(128) {
|
||||||
balanceBytes = cell.Balance.ByteLen()
|
balanceBytes = cell.Balance.ByteLen()
|
||||||
@ -1432,7 +1421,7 @@ func (cell *BinCell) accountForHashing(buffer, storageRootHash []byte) int {
|
|||||||
// Encoding Root and CodeHash
|
// Encoding Root and CodeHash
|
||||||
buffer[pos] = 128 + 32
|
buffer[pos] = 128 + 32
|
||||||
pos++
|
pos++
|
||||||
copy(buffer[pos:], storageRootHash[:length.Hash])
|
copy(buffer[pos:], storageRootHash[:])
|
||||||
pos += 32
|
pos += 32
|
||||||
buffer[pos] = 128 + 32
|
buffer[pos] = 128 + 32
|
||||||
pos++
|
pos++
|
||||||
|
@ -107,11 +107,11 @@ func NewHexPatriciaHashed(accountKeyLen int,
|
|||||||
}
|
}
|
||||||
|
|
||||||
type Cell struct {
|
type Cell struct {
|
||||||
h [32]byte // cell hash
|
h [length.Hash]byte // cell hash
|
||||||
hl int // Length of the hash (or embedded)
|
hl int // Length of the hash (or embedded)
|
||||||
apk [20]byte // account plain key
|
apk [length.Addr]byte // account plain key
|
||||||
apl int // length of account plain key
|
apl int // length of account plain key
|
||||||
spk [52]byte // storage plain key
|
spk [length.Addr + length.Hash]byte // storage plain key
|
||||||
spl int // length of the storage plain key
|
spl int // length of the storage plain key
|
||||||
downHashedKey [128]byte
|
downHashedKey [128]byte
|
||||||
downHashedLen int
|
downHashedLen int
|
||||||
@ -119,8 +119,8 @@ type Cell struct {
|
|||||||
extLen int
|
extLen int
|
||||||
Nonce uint64
|
Nonce uint64
|
||||||
Balance uint256.Int
|
Balance uint256.Int
|
||||||
CodeHash [32]byte // hash of the bytecode
|
CodeHash [length.Hash]byte // hash of the bytecode
|
||||||
Storage [32]byte
|
Storage [length.Hash]byte
|
||||||
StorageLen int
|
StorageLen int
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -232,7 +232,7 @@ func (cell *Cell) fillFromLowerCell(lowCell *Cell, lowDepth int, preExtension []
|
|||||||
|
|
||||||
func hashKey(keccak keccakState, plainKey []byte, dest []byte, hashedKeyOffset int) error {
|
func hashKey(keccak keccakState, plainKey []byte, dest []byte, hashedKeyOffset int) error {
|
||||||
keccak.Reset()
|
keccak.Reset()
|
||||||
var hashBufBack [32]byte
|
var hashBufBack [length.Hash]byte
|
||||||
hashBuf := hashBufBack[:]
|
hashBuf := hashBufBack[:]
|
||||||
if _, err := keccak.Write(plainKey); err != nil {
|
if _, err := keccak.Write(plainKey); err != nil {
|
||||||
return err
|
return err
|
||||||
@ -387,7 +387,7 @@ func hasTerm(s []byte) bool {
|
|||||||
return len(s) > 0 && s[len(s)-1] == 16
|
return len(s) > 0 && s[len(s)-1] == 16
|
||||||
}
|
}
|
||||||
|
|
||||||
func (hph *HexPatriciaHashed) completeLeafHash(buf []byte, keyPrefix []byte, kp, kl, compactLen int, key []byte, compact0 byte, ni int, val rlp.RlpSerializable, singleton bool) ([]byte, error) {
|
func (hph *HexPatriciaHashed) completeLeafHash(buf, keyPrefix []byte, kp, kl, compactLen int, key []byte, compact0 byte, ni int, val rlp.RlpSerializable, singleton bool) ([]byte, error) {
|
||||||
totalLen := kp + kl + val.DoubleRLPLen()
|
totalLen := kp + kl + val.DoubleRLPLen()
|
||||||
var lenPrefix [4]byte
|
var lenPrefix [4]byte
|
||||||
pt := rlp.GenerateStructLen(lenPrefix[:], totalLen)
|
pt := rlp.GenerateStructLen(lenPrefix[:], totalLen)
|
||||||
@ -435,7 +435,7 @@ func (hph *HexPatriciaHashed) completeLeafHash(buf []byte, keyPrefix []byte, kp,
|
|||||||
return buf, nil
|
return buf, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (hph *HexPatriciaHashed) leafHashWithKeyVal(buf []byte, key []byte, val rlp.RlpSerializableBytes, singleton bool) ([]byte, error) {
|
func (hph *HexPatriciaHashed) leafHashWithKeyVal(buf, key []byte, val rlp.RlpSerializableBytes, singleton bool) ([]byte, error) {
|
||||||
// Compute the total length of binary representation
|
// Compute the total length of binary representation
|
||||||
var kp, kl int
|
var kp, kl int
|
||||||
// Write key
|
// Write key
|
||||||
@ -457,14 +457,10 @@ func (hph *HexPatriciaHashed) leafHashWithKeyVal(buf []byte, key []byte, val rlp
|
|||||||
} else {
|
} else {
|
||||||
kl = 1
|
kl = 1
|
||||||
}
|
}
|
||||||
buf, err := hph.completeLeafHash(buf, keyPrefix[:], kp, kl, compactLen, key, compact0, ni, val, singleton)
|
return hph.completeLeafHash(buf, keyPrefix[:], kp, kl, compactLen, key, compact0, ni, val, singleton)
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return buf, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (cell *Cell) accountForHashing(buffer, storageRootHash []byte) int {
|
func (cell *Cell) accountForHashing(buffer []byte, storageRootHash [length.Hash]byte) int {
|
||||||
balanceBytes := 0
|
balanceBytes := 0
|
||||||
if !cell.Balance.LtUint64(128) {
|
if !cell.Balance.LtUint64(128) {
|
||||||
balanceBytes = cell.Balance.ByteLen()
|
balanceBytes = cell.Balance.ByteLen()
|
||||||
@ -523,7 +519,7 @@ func (cell *Cell) accountForHashing(buffer, storageRootHash []byte) int {
|
|||||||
// Encoding Root and CodeHash
|
// Encoding Root and CodeHash
|
||||||
buffer[pos] = 128 + 32
|
buffer[pos] = 128 + 32
|
||||||
pos++
|
pos++
|
||||||
copy(buffer[pos:], storageRootHash[:length.Hash])
|
copy(buffer[pos:], storageRootHash[:])
|
||||||
pos += 32
|
pos += 32
|
||||||
buffer[pos] = 128 + 32
|
buffer[pos] = 128 + 32
|
||||||
pos++
|
pos++
|
||||||
@ -562,14 +558,12 @@ func (hph *HexPatriciaHashed) accountLeafHashWithKey(buf, key []byte, val rlp.Rl
|
|||||||
} else {
|
} else {
|
||||||
kl = 1
|
kl = 1
|
||||||
}
|
}
|
||||||
var err error
|
return hph.completeLeafHash(buf, keyPrefix[:], kp, kl, compactLen, key, compact0, ni, val, true)
|
||||||
if buf, err = hph.completeLeafHash(buf, keyPrefix[:], kp, kl, compactLen, key, compact0, ni, val, true); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return buf, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (hph *HexPatriciaHashed) extensionHash(buf []byte, key []byte, hash []byte) ([]byte, error) {
|
func (hph *HexPatriciaHashed) extensionHash(key []byte, hash []byte) ([length.Hash]byte, error) {
|
||||||
|
var hashBuf [length.Hash]byte
|
||||||
|
|
||||||
// Compute the total length of binary representation
|
// Compute the total length of binary representation
|
||||||
var kp, kl int
|
var kp, kl int
|
||||||
// Write key
|
// Write key
|
||||||
@ -604,37 +598,35 @@ func (hph *HexPatriciaHashed) extensionHash(buf []byte, key []byte, hash []byte)
|
|||||||
pt := rlp.GenerateStructLen(lenPrefix[:], totalLen)
|
pt := rlp.GenerateStructLen(lenPrefix[:], totalLen)
|
||||||
hph.keccak.Reset()
|
hph.keccak.Reset()
|
||||||
if _, err := hph.keccak.Write(lenPrefix[:pt]); err != nil {
|
if _, err := hph.keccak.Write(lenPrefix[:pt]); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
if _, err := hph.keccak.Write(keyPrefix[:kp]); err != nil {
|
if _, err := hph.keccak.Write(keyPrefix[:kp]); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
var b [1]byte
|
var b [1]byte
|
||||||
b[0] = compact0
|
b[0] = compact0
|
||||||
if _, err := hph.keccak.Write(b[:]); err != nil {
|
if _, err := hph.keccak.Write(b[:]); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
for i := 1; i < compactLen; i++ {
|
for i := 1; i < compactLen; i++ {
|
||||||
b[0] = key[ni]*16 + key[ni+1]
|
b[0] = key[ni]*16 + key[ni+1]
|
||||||
if _, err := hph.keccak.Write(b[:]); err != nil {
|
if _, err := hph.keccak.Write(b[:]); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
ni += 2
|
ni += 2
|
||||||
}
|
}
|
||||||
b[0] = 0x80 + length.Hash
|
b[0] = 0x80 + length.Hash
|
||||||
if _, err := hph.keccak.Write(b[:]); err != nil {
|
if _, err := hph.keccak.Write(b[:]); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
if _, err := hph.keccak.Write(hash); err != nil {
|
if _, err := hph.keccak.Write(hash); err != nil {
|
||||||
return nil, err
|
return hashBuf, err
|
||||||
}
|
}
|
||||||
// Replace previous hash with the new one
|
// Replace previous hash with the new one
|
||||||
var hashBuf [33]byte
|
if _, err := hph.keccak.Read(hashBuf[:]); err != nil {
|
||||||
if _, err := hph.keccak.Read(hashBuf[:length.Hash]); err != nil {
|
return hashBuf, err
|
||||||
return nil, err
|
|
||||||
}
|
}
|
||||||
buf = append(buf, hashBuf[:length.Hash]...)
|
return hashBuf, nil
|
||||||
return buf, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (hph *HexPatriciaHashed) computeCellHashLen(cell *Cell, depth int) int {
|
func (hph *HexPatriciaHashed) computeCellHashLen(cell *Cell, depth int) int {
|
||||||
@ -661,7 +653,8 @@ func (hph *HexPatriciaHashed) computeCellHashLen(cell *Cell, depth int) int {
|
|||||||
|
|
||||||
func (hph *HexPatriciaHashed) computeCellHash(cell *Cell, depth int, buf []byte) ([]byte, error) {
|
func (hph *HexPatriciaHashed) computeCellHash(cell *Cell, depth int, buf []byte) ([]byte, error) {
|
||||||
var err error
|
var err error
|
||||||
var storageRootHash []byte
|
var storageRootHash [length.Hash]byte
|
||||||
|
storageRootHashIsSet := false
|
||||||
if cell.spl > 0 {
|
if cell.spl > 0 {
|
||||||
var hashedKeyOffset int
|
var hashedKeyOffset int
|
||||||
if depth >= 64 {
|
if depth >= 64 {
|
||||||
@ -677,18 +670,15 @@ func (hph *HexPatriciaHashed) computeCellHash(cell *Cell, depth int, buf []byte)
|
|||||||
if hph.trace {
|
if hph.trace {
|
||||||
fmt.Printf("leafHashWithKeyVal(singleton) for [%x]=>[%x]\n", cell.downHashedKey[:64-hashedKeyOffset+1], cell.Storage[:cell.StorageLen])
|
fmt.Printf("leafHashWithKeyVal(singleton) for [%x]=>[%x]\n", cell.downHashedKey[:64-hashedKeyOffset+1], cell.Storage[:cell.StorageLen])
|
||||||
}
|
}
|
||||||
if storageRootHash, err = hph.leafHashWithKeyVal(nil, cell.downHashedKey[:64-hashedKeyOffset+1], rlp.RlpSerializableBytes(cell.Storage[:cell.StorageLen]), true); err != nil {
|
if _, err = hph.leafHashWithKeyVal(storageRootHash[:0], cell.downHashedKey[:64-hashedKeyOffset+1], rlp.RlpSerializableBytes(cell.Storage[:cell.StorageLen]), true); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
storageRootHash = storageRootHash[1:]
|
storageRootHashIsSet = true
|
||||||
} else {
|
} else {
|
||||||
if hph.trace {
|
if hph.trace {
|
||||||
fmt.Printf("leafHashWithKeyVal for [%x]=>[%x]\n", cell.downHashedKey[:64-hashedKeyOffset+1], cell.Storage[:cell.StorageLen])
|
fmt.Printf("leafHashWithKeyVal for [%x]=>[%x]\n", cell.downHashedKey[:64-hashedKeyOffset+1], cell.Storage[:cell.StorageLen])
|
||||||
}
|
}
|
||||||
if buf, err = hph.leafHashWithKeyVal(buf, cell.downHashedKey[:64-hashedKeyOffset+1], rlp.RlpSerializableBytes(cell.Storage[:cell.StorageLen]), false); err != nil {
|
return hph.leafHashWithKeyVal(buf, cell.downHashedKey[:64-hashedKeyOffset+1], rlp.RlpSerializableBytes(cell.Storage[:cell.StorageLen]), false)
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return buf, nil
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if cell.apl > 0 {
|
if cell.apl > 0 {
|
||||||
@ -696,23 +686,23 @@ func (hph *HexPatriciaHashed) computeCellHash(cell *Cell, depth int, buf []byte)
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
cell.downHashedKey[64-depth] = 16 // Add terminator
|
cell.downHashedKey[64-depth] = 16 // Add terminator
|
||||||
if storageRootHash == nil {
|
if !storageRootHashIsSet {
|
||||||
if cell.extLen > 0 {
|
if cell.extLen > 0 {
|
||||||
// Extension
|
// Extension
|
||||||
if cell.hl > 0 {
|
if cell.hl > 0 {
|
||||||
if hph.trace {
|
if hph.trace {
|
||||||
fmt.Printf("extensionHash for [%x]=>[%x]\n", cell.extension[:cell.extLen], cell.h[:cell.hl])
|
fmt.Printf("extensionHash for [%x]=>[%x]\n", cell.extension[:cell.extLen], cell.h[:cell.hl])
|
||||||
}
|
}
|
||||||
if storageRootHash, err = hph.extensionHash(nil, cell.extension[:cell.extLen], cell.h[:cell.hl]); err != nil {
|
if storageRootHash, err = hph.extensionHash(cell.extension[:cell.extLen], cell.h[:cell.hl]); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return nil, fmt.Errorf("computeCellHash extension without hash")
|
return nil, fmt.Errorf("computeCellHash extension without hash")
|
||||||
}
|
}
|
||||||
} else if cell.hl > 0 {
|
} else if cell.hl > 0 {
|
||||||
storageRootHash = cell.h[:cell.hl]
|
storageRootHash = cell.h
|
||||||
} else {
|
} else {
|
||||||
storageRootHash = EmptyRootHash
|
storageRootHash = *(*[length.Hash]byte)(EmptyRootHash)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
var valBuf [128]byte
|
var valBuf [128]byte
|
||||||
@ -720,10 +710,7 @@ func (hph *HexPatriciaHashed) computeCellHash(cell *Cell, depth int, buf []byte)
|
|||||||
if hph.trace {
|
if hph.trace {
|
||||||
fmt.Printf("accountLeafHashWithKey for [%x]=>[%x]\n", cell.downHashedKey[:65-depth], valBuf[:valLen])
|
fmt.Printf("accountLeafHashWithKey for [%x]=>[%x]\n", cell.downHashedKey[:65-depth], valBuf[:valLen])
|
||||||
}
|
}
|
||||||
if buf, err = hph.accountLeafHashWithKey(buf, cell.downHashedKey[:65-depth], rlp.RlpEncodedBytes(valBuf[:valLen])); err != nil {
|
return hph.accountLeafHashWithKey(buf, cell.downHashedKey[:65-depth], rlp.RlpEncodedBytes(valBuf[:valLen]))
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return buf, nil
|
|
||||||
}
|
}
|
||||||
buf = append(buf, 0x80+32)
|
buf = append(buf, 0x80+32)
|
||||||
if cell.extLen > 0 {
|
if cell.extLen > 0 {
|
||||||
@ -732,9 +719,11 @@ func (hph *HexPatriciaHashed) computeCellHash(cell *Cell, depth int, buf []byte)
|
|||||||
if hph.trace {
|
if hph.trace {
|
||||||
fmt.Printf("extensionHash for [%x]=>[%x]\n", cell.extension[:cell.extLen], cell.h[:cell.hl])
|
fmt.Printf("extensionHash for [%x]=>[%x]\n", cell.extension[:cell.extLen], cell.h[:cell.hl])
|
||||||
}
|
}
|
||||||
if buf, err = hph.extensionHash(buf, cell.extension[:cell.extLen], cell.h[:cell.hl]); err != nil {
|
var hash [length.Hash]byte
|
||||||
|
if hash, err = hph.extensionHash(cell.extension[:cell.extLen], cell.h[:cell.hl]); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
buf = append(buf, hash[:]...)
|
||||||
} else {
|
} else {
|
||||||
return nil, fmt.Errorf("computeCellHash extension without hash")
|
return nil, fmt.Errorf("computeCellHash extension without hash")
|
||||||
}
|
}
|
||||||
@ -1444,7 +1433,7 @@ type Update struct {
|
|||||||
Flags UpdateFlags
|
Flags UpdateFlags
|
||||||
Balance uint256.Int
|
Balance uint256.Int
|
||||||
Nonce uint64
|
Nonce uint64
|
||||||
CodeHashOrStorage [32]byte
|
CodeHashOrStorage [length.Hash]byte
|
||||||
ValLength int
|
ValLength int
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,6 +28,7 @@ import (
|
|||||||
"golang.org/x/exp/slices"
|
"golang.org/x/exp/slices"
|
||||||
|
|
||||||
"github.com/ledgerwatch/erigon-lib/common"
|
"github.com/ledgerwatch/erigon-lib/common"
|
||||||
|
"github.com/ledgerwatch/erigon-lib/common/length"
|
||||||
)
|
)
|
||||||
|
|
||||||
// In memory commitment and state to use with the tests
|
// In memory commitment and state to use with the tests
|
||||||
@ -130,7 +131,7 @@ func (ms MockState) storageFn(plainKey []byte, cell *Cell) error {
|
|||||||
if ex.Flags&STORAGE_UPDATE != 0 {
|
if ex.Flags&STORAGE_UPDATE != 0 {
|
||||||
copy(cell.Storage[:], ex.CodeHashOrStorage[:])
|
copy(cell.Storage[:], ex.CodeHashOrStorage[:])
|
||||||
} else {
|
} else {
|
||||||
cell.Storage = [32]byte{}
|
cell.Storage = [length.Hash]byte{}
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -203,7 +204,7 @@ func decodeHex(in string) []byte {
|
|||||||
type UpdateBuilder struct {
|
type UpdateBuilder struct {
|
||||||
balances map[string]*uint256.Int
|
balances map[string]*uint256.Int
|
||||||
nonces map[string]uint64
|
nonces map[string]uint64
|
||||||
codeHashes map[string][32]byte
|
codeHashes map[string][length.Hash]byte
|
||||||
storages map[string]map[string][]byte
|
storages map[string]map[string][]byte
|
||||||
deletes map[string]struct{}
|
deletes map[string]struct{}
|
||||||
deletes2 map[string]map[string]struct{}
|
deletes2 map[string]map[string]struct{}
|
||||||
@ -215,7 +216,7 @@ func NewUpdateBuilder() *UpdateBuilder {
|
|||||||
return &UpdateBuilder{
|
return &UpdateBuilder{
|
||||||
balances: make(map[string]*uint256.Int),
|
balances: make(map[string]*uint256.Int),
|
||||||
nonces: make(map[string]uint64),
|
nonces: make(map[string]uint64),
|
||||||
codeHashes: make(map[string][32]byte),
|
codeHashes: make(map[string][length.Hash]byte),
|
||||||
storages: make(map[string]map[string][]byte),
|
storages: make(map[string]map[string][]byte),
|
||||||
deletes: make(map[string]struct{}),
|
deletes: make(map[string]struct{}),
|
||||||
deletes2: make(map[string]map[string]struct{}),
|
deletes2: make(map[string]map[string]struct{}),
|
||||||
@ -240,7 +241,7 @@ func (ub *UpdateBuilder) Nonce(addr string, nonce uint64) *UpdateBuilder {
|
|||||||
return ub
|
return ub
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ub *UpdateBuilder) CodeHash(addr string, hash [32]byte) *UpdateBuilder {
|
func (ub *UpdateBuilder) CodeHash(addr string, hash [length.Hash]byte) *UpdateBuilder {
|
||||||
sk := string(decodeHex(addr))
|
sk := string(decodeHex(addr))
|
||||||
delete(ub.deletes, sk)
|
delete(ub.deletes, sk)
|
||||||
ub.codeHashes[sk] = hash
|
ub.codeHashes[sk] = hash
|
||||||
@ -395,7 +396,7 @@ func (ub *UpdateBuilder) Build() (plainKeys, hashedKeys [][]byte, updates []Upda
|
|||||||
if sm, ok1 := ub.storages[string(key)]; ok1 {
|
if sm, ok1 := ub.storages[string(key)]; ok1 {
|
||||||
if storage, ok2 := sm[string(key2)]; ok2 {
|
if storage, ok2 := sm[string(key2)]; ok2 {
|
||||||
u.Flags |= STORAGE_UPDATE
|
u.Flags |= STORAGE_UPDATE
|
||||||
u.CodeHashOrStorage = [32]byte{}
|
u.CodeHashOrStorage = [length.Hash]byte{}
|
||||||
u.ValLength = len(storage)
|
u.ValLength = len(storage)
|
||||||
copy(u.CodeHashOrStorage[:], storage)
|
copy(u.CodeHashOrStorage[:], storage)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user