whisper: PoW calculations as specified in EIP-627 (#19753)
* whisper: PoW calculations as specified in EIP-627 * Fix unit tests
This commit is contained in:
parent
2ca89ea479
commit
54fd263b40
@ -91,16 +91,18 @@ func (e *Envelope) Seal(options *MessageParams) error {
|
|||||||
target = e.powToFirstBit(options.PoW)
|
target = e.powToFirstBit(options.PoW)
|
||||||
}
|
}
|
||||||
|
|
||||||
buf := make([]byte, 64)
|
rlp := e.rlpWithoutNonce()
|
||||||
h := crypto.Keccak256(e.rlpWithoutNonce())
|
buf := make([]byte, len(rlp)+8)
|
||||||
copy(buf[:32], h)
|
copy(buf, rlp)
|
||||||
|
asAnInt := new(big.Int)
|
||||||
|
|
||||||
finish := time.Now().Add(time.Duration(options.WorkTime) * time.Second).UnixNano()
|
finish := time.Now().Add(time.Duration(options.WorkTime) * time.Second).UnixNano()
|
||||||
for nonce := uint64(0); time.Now().UnixNano() < finish; {
|
for nonce := uint64(0); time.Now().UnixNano() < finish; {
|
||||||
for i := 0; i < 1024; i++ {
|
for i := 0; i < 1024; i++ {
|
||||||
binary.BigEndian.PutUint64(buf[56:], nonce)
|
binary.BigEndian.PutUint64(buf[len(rlp):], nonce)
|
||||||
d := new(big.Int).SetBytes(crypto.Keccak256(buf))
|
h := crypto.Keccak256(buf)
|
||||||
leadingZeros := 256 - d.BitLen()
|
asAnInt.SetBytes(h)
|
||||||
|
leadingZeros := 256 - asAnInt.BitLen()
|
||||||
if leadingZeros > bestLeadingZeros {
|
if leadingZeros > bestLeadingZeros {
|
||||||
e.Nonce, bestLeadingZeros = nonce, leadingZeros
|
e.Nonce, bestLeadingZeros = nonce, leadingZeros
|
||||||
if target > 0 && bestLeadingZeros >= target {
|
if target > 0 && bestLeadingZeros >= target {
|
||||||
@ -128,11 +130,10 @@ func (e *Envelope) PoW() float64 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (e *Envelope) calculatePoW(diff uint32) {
|
func (e *Envelope) calculatePoW(diff uint32) {
|
||||||
buf := make([]byte, 64)
|
|
||||||
rlp := e.rlpWithoutNonce()
|
rlp := e.rlpWithoutNonce()
|
||||||
h := crypto.Keccak256(rlp)
|
buf := make([]byte, len(rlp)+8)
|
||||||
copy(buf[:32], h)
|
copy(buf, rlp)
|
||||||
binary.BigEndian.PutUint64(buf[56:], e.Nonce)
|
binary.BigEndian.PutUint64(buf[len(rlp):], e.Nonce)
|
||||||
powHash := new(big.Int).SetBytes(crypto.Keccak256(buf))
|
powHash := new(big.Int).SetBytes(crypto.Keccak256(buf))
|
||||||
leadingZeroes := 256 - powHash.BitLen()
|
leadingZeroes := 256 - powHash.BitLen()
|
||||||
x := gmath.Pow(2, float64(leadingZeroes))
|
x := gmath.Pow(2, float64(leadingZeroes))
|
||||||
|
@ -43,12 +43,12 @@ func TestPoWCalculationsWith8LeadingZeros(t *testing.T) {
|
|||||||
e := Envelope{
|
e := Envelope{
|
||||||
TTL: 1,
|
TTL: 1,
|
||||||
Data: []byte{0xde, 0xad, 0xbe, 0xef},
|
Data: []byte{0xde, 0xad, 0xbe, 0xef},
|
||||||
Nonce: 48159,
|
Nonce: 276,
|
||||||
}
|
}
|
||||||
e.calculatePoW(0)
|
e.calculatePoW(0)
|
||||||
|
|
||||||
if e.pow != 40329.846153846156 {
|
if e.pow != 19.692307692307693 {
|
||||||
t.Fatalf("invalid PoW calculation. Expected 0.07692307692307693, got %v", e.pow)
|
t.Fatalf("invalid PoW calculation. Expected 19.692307692307693, got %v", e.pow)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user