forked from cerc-io/plugeth
cmd/puppeth: update chain spec of parity (#20241)
This commit is contained in:
parent
9b59c75405
commit
b7ba944e88
@ -305,19 +305,20 @@ type parityChainSpecAccount struct {
|
|||||||
|
|
||||||
// parityChainSpecBuiltin is the precompiled contract definition.
|
// parityChainSpecBuiltin is the precompiled contract definition.
|
||||||
type parityChainSpecBuiltin struct {
|
type parityChainSpecBuiltin struct {
|
||||||
Name string `json:"name"` // Each builtin should has it own name
|
Name string `json:"name"` // Each builtin should has it own name
|
||||||
Pricing *parityChainSpecPricing `json:"pricing"` // Each builtin should has it own price strategy
|
Pricing interface{} `json:"pricing"` // Each builtin should has it own price strategy
|
||||||
ActivateAt *hexutil.Big `json:"activate_at,omitempty"` // ActivateAt can't be omitted if empty, default means no fork
|
ActivateAt *hexutil.Big `json:"activate_at,omitempty"` // ActivateAt can't be omitted if empty, default means no fork
|
||||||
EIP1108Transition *hexutil.Big `json:"eip1108_transition,omitempty"` // EIP1108Transition can't be omitted if empty, default means no fork
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// parityChainSpecPricing represents the different pricing models that builtin
|
// parityChainSpecPricing represents the different pricing models that builtin
|
||||||
// contracts might advertise using.
|
// contracts might advertise using.
|
||||||
type parityChainSpecPricing struct {
|
type parityChainSpecPricing struct {
|
||||||
Linear *parityChainSpecLinearPricing `json:"linear,omitempty"`
|
Linear *parityChainSpecLinearPricing `json:"linear,omitempty"`
|
||||||
ModExp *parityChainSpecModExpPricing `json:"modexp,omitempty"`
|
ModExp *parityChainSpecModExpPricing `json:"modexp,omitempty"`
|
||||||
AltBnPairing *parityChainSpecAltBnPairingPricing `json:"alt_bn128_pairing,omitempty"`
|
|
||||||
AltBnConstOperation *parityChainSpecAltBnConstOperationPricing `json:"alt_bn128_const_operations,omitempty"`
|
// Before the https://github.com/paritytech/parity-ethereum/pull/11039,
|
||||||
|
// Parity uses this format to config bn pairing price policy.
|
||||||
|
AltBnPairing *parityChainSepcAltBnPairingPricing `json:"alt_bn128_pairing,omitempty"`
|
||||||
|
|
||||||
// Blake2F is the price per round of Blake2 compression
|
// Blake2F is the price per round of Blake2 compression
|
||||||
Blake2F *parityChainSpecBlakePricing `json:"blake2_f,omitempty"`
|
Blake2F *parityChainSpecBlakePricing `json:"blake2_f,omitempty"`
|
||||||
@ -332,22 +333,36 @@ type parityChainSpecModExpPricing struct {
|
|||||||
Divisor uint64 `json:"divisor"`
|
Divisor uint64 `json:"divisor"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// parityChainSpecAltBnConstOperationPricing defines the price
|
||||||
|
// policy for bn const operation(used after istanbul)
|
||||||
type parityChainSpecAltBnConstOperationPricing struct {
|
type parityChainSpecAltBnConstOperationPricing struct {
|
||||||
Price uint64 `json:"price"`
|
Price uint64 `json:"price"`
|
||||||
EIP1108TransitionPrice uint64 `json:"eip1108_transition_price,omitempty"` // Before Istanbul fork, this field is nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type parityChainSpecAltBnPairingPricing struct {
|
// parityChainSepcAltBnPairingPricing defines the price policy
|
||||||
Base uint64 `json:"base"`
|
// for bn pairing.
|
||||||
Pair uint64 `json:"pair"`
|
type parityChainSepcAltBnPairingPricing struct {
|
||||||
EIP1108TransitionBase uint64 `json:"eip1108_transition_base,omitempty"` // Before Istanbul fork, this field is nil
|
Base uint64 `json:"base"`
|
||||||
EIP1108TransitionPair uint64 `json:"eip1108_transition_pair,omitempty"` // Before Istanbul fork, this field is nil
|
Pair uint64 `json:"pair"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// parityChainSpecBlakePricing defines the price policy for blake2 f
|
||||||
|
// compression.
|
||||||
type parityChainSpecBlakePricing struct {
|
type parityChainSpecBlakePricing struct {
|
||||||
GasPerRound uint64 `json:"gas_per_round"`
|
GasPerRound uint64 `json:"gas_per_round"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type parityChainSpecAlternativePrice struct {
|
||||||
|
AltBnConstOperationPrice *parityChainSpecAltBnConstOperationPricing `json:"alt_bn128_const_operations,omitempty"`
|
||||||
|
AltBnPairingPrice *parityChainSepcAltBnPairingPricing `json:"alt_bn128_pairing,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// parityChainSpecVersionedPricing represents a single version price policy.
|
||||||
|
type parityChainSpecVersionedPricing struct {
|
||||||
|
Price *parityChainSpecAlternativePrice `json:"price,omitempty"`
|
||||||
|
Info string `json:"info,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
// newParityChainSpec converts a go-ethereum genesis block into a Parity specific
|
// newParityChainSpec converts a go-ethereum genesis block into a Parity specific
|
||||||
// chain specification format.
|
// chain specification format.
|
||||||
func newParityChainSpec(network string, genesis *core.Genesis, bootnodes []string) (*parityChainSpec, error) {
|
func newParityChainSpec(network string, genesis *core.Genesis, bootnodes []string) (*parityChainSpec, error) {
|
||||||
@ -445,16 +460,32 @@ func newParityChainSpec(network string, genesis *core.Genesis, bootnodes []strin
|
|||||||
})
|
})
|
||||||
if genesis.Config.ByzantiumBlock != nil {
|
if genesis.Config.ByzantiumBlock != nil {
|
||||||
spec.setPrecompile(5, &parityChainSpecBuiltin{
|
spec.setPrecompile(5, &parityChainSpecBuiltin{
|
||||||
Name: "modexp", ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock), Pricing: &parityChainSpecPricing{ModExp: &parityChainSpecModExpPricing{Divisor: 20}},
|
Name: "modexp",
|
||||||
|
ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock),
|
||||||
|
Pricing: &parityChainSpecPricing{
|
||||||
|
ModExp: &parityChainSpecModExpPricing{Divisor: 20},
|
||||||
|
},
|
||||||
})
|
})
|
||||||
spec.setPrecompile(6, &parityChainSpecBuiltin{
|
spec.setPrecompile(6, &parityChainSpecBuiltin{
|
||||||
Name: "alt_bn128_add", ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock), Pricing: &parityChainSpecPricing{AltBnConstOperation: &parityChainSpecAltBnConstOperationPricing{Price: 500}},
|
Name: "alt_bn128_add",
|
||||||
|
ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock),
|
||||||
|
Pricing: &parityChainSpecPricing{
|
||||||
|
Linear: &parityChainSpecLinearPricing{Base: 500, Word: 0},
|
||||||
|
},
|
||||||
})
|
})
|
||||||
spec.setPrecompile(7, &parityChainSpecBuiltin{
|
spec.setPrecompile(7, &parityChainSpecBuiltin{
|
||||||
Name: "alt_bn128_mul", ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock), Pricing: &parityChainSpecPricing{AltBnConstOperation: &parityChainSpecAltBnConstOperationPricing{Price: 40000}},
|
Name: "alt_bn128_mul",
|
||||||
|
ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock),
|
||||||
|
Pricing: &parityChainSpecPricing{
|
||||||
|
Linear: &parityChainSpecLinearPricing{Base: 40000, Word: 0},
|
||||||
|
},
|
||||||
})
|
})
|
||||||
spec.setPrecompile(8, &parityChainSpecBuiltin{
|
spec.setPrecompile(8, &parityChainSpecBuiltin{
|
||||||
Name: "alt_bn128_pairing", ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock), Pricing: &parityChainSpecPricing{AltBnPairing: &parityChainSpecAltBnPairingPricing{Base: 100000, Pair: 80000}},
|
Name: "alt_bn128_pairing",
|
||||||
|
ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock),
|
||||||
|
Pricing: &parityChainSpecPricing{
|
||||||
|
AltBnPairing: &parityChainSepcAltBnPairingPricing{Base: 100000, Pair: 80000},
|
||||||
|
},
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
if genesis.Config.IstanbulBlock != nil {
|
if genesis.Config.IstanbulBlock != nil {
|
||||||
@ -462,16 +493,59 @@ func newParityChainSpec(network string, genesis *core.Genesis, bootnodes []strin
|
|||||||
return nil, errors.New("invalid genesis, istanbul fork is enabled while byzantium is not")
|
return nil, errors.New("invalid genesis, istanbul fork is enabled while byzantium is not")
|
||||||
}
|
}
|
||||||
spec.setPrecompile(6, &parityChainSpecBuiltin{
|
spec.setPrecompile(6, &parityChainSpecBuiltin{
|
||||||
Name: "alt_bn128_add", ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock), EIP1108Transition: (*hexutil.Big)(genesis.Config.IstanbulBlock), Pricing: &parityChainSpecPricing{AltBnConstOperation: &parityChainSpecAltBnConstOperationPricing{Price: 500, EIP1108TransitionPrice: 150}},
|
Name: "alt_bn128_add",
|
||||||
|
ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock),
|
||||||
|
Pricing: map[*hexutil.Big]*parityChainSpecVersionedPricing{
|
||||||
|
(*hexutil.Big)(big.NewInt(0)): {
|
||||||
|
Price: &parityChainSpecAlternativePrice{
|
||||||
|
AltBnConstOperationPrice: &parityChainSpecAltBnConstOperationPricing{Price: 500},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
(*hexutil.Big)(genesis.Config.IstanbulBlock): {
|
||||||
|
Price: &parityChainSpecAlternativePrice{
|
||||||
|
AltBnConstOperationPrice: &parityChainSpecAltBnConstOperationPricing{Price: 150},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
})
|
})
|
||||||
spec.setPrecompile(7, &parityChainSpecBuiltin{
|
spec.setPrecompile(7, &parityChainSpecBuiltin{
|
||||||
Name: "alt_bn128_mul", ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock), EIP1108Transition: (*hexutil.Big)(genesis.Config.IstanbulBlock), Pricing: &parityChainSpecPricing{AltBnConstOperation: &parityChainSpecAltBnConstOperationPricing{Price: 40000, EIP1108TransitionPrice: 6000}},
|
Name: "alt_bn128_mul",
|
||||||
|
ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock),
|
||||||
|
Pricing: map[*hexutil.Big]*parityChainSpecVersionedPricing{
|
||||||
|
(*hexutil.Big)(big.NewInt(0)): {
|
||||||
|
Price: &parityChainSpecAlternativePrice{
|
||||||
|
AltBnConstOperationPrice: &parityChainSpecAltBnConstOperationPricing{Price: 40000},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
(*hexutil.Big)(genesis.Config.IstanbulBlock): {
|
||||||
|
Price: &parityChainSpecAlternativePrice{
|
||||||
|
AltBnConstOperationPrice: &parityChainSpecAltBnConstOperationPricing{Price: 6000},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
})
|
})
|
||||||
spec.setPrecompile(8, &parityChainSpecBuiltin{
|
spec.setPrecompile(8, &parityChainSpecBuiltin{
|
||||||
Name: "alt_bn128_pairing", ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock), EIP1108Transition: (*hexutil.Big)(genesis.Config.IstanbulBlock), Pricing: &parityChainSpecPricing{AltBnPairing: &parityChainSpecAltBnPairingPricing{Base: 100000, Pair: 80000, EIP1108TransitionBase: 45000, EIP1108TransitionPair: 34000}},
|
Name: "alt_bn128_pairing",
|
||||||
|
ActivateAt: (*hexutil.Big)(genesis.Config.ByzantiumBlock),
|
||||||
|
Pricing: map[*hexutil.Big]*parityChainSpecVersionedPricing{
|
||||||
|
(*hexutil.Big)(big.NewInt(0)): {
|
||||||
|
Price: &parityChainSpecAlternativePrice{
|
||||||
|
AltBnPairingPrice: &parityChainSepcAltBnPairingPricing{Base: 100000, Pair: 80000},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
(*hexutil.Big)(genesis.Config.IstanbulBlock): {
|
||||||
|
Price: &parityChainSpecAlternativePrice{
|
||||||
|
AltBnPairingPrice: &parityChainSepcAltBnPairingPricing{Base: 45000, Pair: 34000},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
})
|
})
|
||||||
spec.setPrecompile(9, &parityChainSpecBuiltin{
|
spec.setPrecompile(9, &parityChainSpecBuiltin{
|
||||||
Name: "blake2_f", ActivateAt: (*hexutil.Big)(genesis.Config.IstanbulBlock), Pricing: &parityChainSpecPricing{Blake2F: &parityChainSpecBlakePricing{GasPerRound: 1}},
|
Name: "blake2_f",
|
||||||
|
ActivateAt: (*hexutil.Big)(genesis.Config.IstanbulBlock),
|
||||||
|
Pricing: &parityChainSpecPricing{
|
||||||
|
Blake2F: &parityChainSpecBlakePricing{GasPerRound: 1},
|
||||||
|
},
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
return spec, nil
|
return spec, nil
|
||||||
@ -514,8 +588,6 @@ func (spec *parityChainSpec) setConstantinopleFix(num *big.Int) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (spec *parityChainSpec) setIstanbul(num *big.Int) {
|
func (spec *parityChainSpec) setIstanbul(num *big.Int) {
|
||||||
// spec.Params.EIP152Transition = hexutil.Uint64(num.Uint64())
|
|
||||||
// spec.Params.EIP1108Transition = hexutil.Uint64(num.Uint64())
|
|
||||||
spec.Params.EIP1344Transition = hexutil.Uint64(num.Uint64())
|
spec.Params.EIP1344Transition = hexutil.Uint64(num.Uint64())
|
||||||
spec.Params.EIP1884Transition = hexutil.Uint64(num.Uint64())
|
spec.Params.EIP1884Transition = hexutil.Uint64(num.Uint64())
|
||||||
spec.Params.EIP2028Transition = hexutil.Uint64(num.Uint64())
|
spec.Params.EIP2028Transition = hexutil.Uint64(num.Uint64())
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"reflect"
|
"reflect"
|
||||||
@ -80,29 +81,15 @@ func TestParitySturebyConverter(t *testing.T) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("failed creating chainspec: %v", err)
|
t.Fatalf("failed creating chainspec: %v", err)
|
||||||
}
|
}
|
||||||
|
enc, err := json.MarshalIndent(spec, "", " ")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("failed encoding chainspec: %v", err)
|
||||||
|
}
|
||||||
expBlob, err := ioutil.ReadFile("testdata/stureby_parity.json")
|
expBlob, err := ioutil.ReadFile("testdata/stureby_parity.json")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("could not read file: %v", err)
|
t.Fatalf("could not read file: %v", err)
|
||||||
}
|
}
|
||||||
expspec := &parityChainSpec{}
|
if !bytes.Equal(expBlob, enc) {
|
||||||
if err := json.Unmarshal(expBlob, expspec); err != nil {
|
t.Fatalf("chainspec mismatch")
|
||||||
t.Fatalf("failed parsing genesis: %v", err)
|
|
||||||
}
|
|
||||||
expspec.Nodes = []string{}
|
|
||||||
|
|
||||||
if !reflect.DeepEqual(expspec, spec) {
|
|
||||||
t.Errorf("chainspec mismatch")
|
|
||||||
c := spew.ConfigState{
|
|
||||||
DisablePointerAddresses: true,
|
|
||||||
SortKeys: true,
|
|
||||||
}
|
|
||||||
exp := strings.Split(c.Sdump(expspec), "\n")
|
|
||||||
got := strings.Split(c.Sdump(spec), "\n")
|
|
||||||
for i := 0; i < len(exp) && i < len(got); i++ {
|
|
||||||
if exp[i] != got[i] {
|
|
||||||
t.Logf("got: %v\nexp: %v\n", exp[i], got[i])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
61
cmd/puppeth/testdata/stureby_parity.json
vendored
61
cmd/puppeth/testdata/stureby_parity.json
vendored
@ -131,13 +131,22 @@
|
|||||||
"builtin": {
|
"builtin": {
|
||||||
"name": "alt_bn128_add",
|
"name": "alt_bn128_add",
|
||||||
"pricing": {
|
"pricing": {
|
||||||
"alt_bn128_const_operations": {
|
"0x0": {
|
||||||
"price": 500,
|
"price": {
|
||||||
"eip1108_transition_price": 150
|
"alt_bn128_const_operations": {
|
||||||
|
"price": 500
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"0xc350": {
|
||||||
|
"price": {
|
||||||
|
"alt_bn128_const_operations": {
|
||||||
|
"price": 150
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"activate_at": "0x7530",
|
"activate_at": "0x7530"
|
||||||
"eip1108_transition": "0xc350"
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"0000000000000000000000000000000000000007": {
|
"0000000000000000000000000000000000000007": {
|
||||||
@ -145,13 +154,22 @@
|
|||||||
"builtin": {
|
"builtin": {
|
||||||
"name": "alt_bn128_mul",
|
"name": "alt_bn128_mul",
|
||||||
"pricing": {
|
"pricing": {
|
||||||
"alt_bn128_const_operations": {
|
"0x0": {
|
||||||
"price": 40000,
|
"price": {
|
||||||
"eip1108_transition_price": 6000
|
"alt_bn128_const_operations": {
|
||||||
|
"price": 40000
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"0xc350": {
|
||||||
|
"price": {
|
||||||
|
"alt_bn128_const_operations": {
|
||||||
|
"price": 6000
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"activate_at": "0x7530",
|
"activate_at": "0x7530"
|
||||||
"eip1108_transition": "0xc350"
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"0000000000000000000000000000000000000008": {
|
"0000000000000000000000000000000000000008": {
|
||||||
@ -159,15 +177,24 @@
|
|||||||
"builtin": {
|
"builtin": {
|
||||||
"name": "alt_bn128_pairing",
|
"name": "alt_bn128_pairing",
|
||||||
"pricing": {
|
"pricing": {
|
||||||
"alt_bn128_pairing": {
|
"0x0": {
|
||||||
"base": 100000,
|
"price": {
|
||||||
"pair": 80000,
|
"alt_bn128_pairing": {
|
||||||
"eip1108_transition_base": 45000,
|
"base": 100000,
|
||||||
"eip1108_transition_pair": 34000
|
"pair": 80000
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"0xc350": {
|
||||||
|
"price": {
|
||||||
|
"alt_bn128_pairing": {
|
||||||
|
"base": 45000,
|
||||||
|
"pair": 34000
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"activate_at": "0x7530",
|
"activate_at": "0x7530"
|
||||||
"eip1108_transition": "0xc350"
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"0000000000000000000000000000000000000009": {
|
"0000000000000000000000000000000000000009": {
|
||||||
|
Loading…
Reference in New Issue
Block a user