Typify commitment (#454)

This commit is contained in:
Artem Vorotnikov 2022-05-20 11:01:44 +03:00 committed by GitHub
parent 6de4ac4ba9
commit 15d2a37c0b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 87 additions and 108 deletions

View File

@ -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++

View File

@ -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
} }

View File

@ -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)
} }