Merge pull request #4039 from filecoin-project/feat/v0.8-actors
Ignition upgrades, for release v0.8.0
This commit is contained in:
commit
b453b8da99
@ -12,6 +12,8 @@ const UpgradeBreezeHeight = -1
|
|||||||
const BreezeGasTampingDuration = 0
|
const BreezeGasTampingDuration = 0
|
||||||
|
|
||||||
const UpgradeSmokeHeight = -1
|
const UpgradeSmokeHeight = -1
|
||||||
|
const UpgradeIgnitionHeight = -2
|
||||||
|
const UpgradeLiftoffHeight = -3
|
||||||
|
|
||||||
var DrandSchedule = map[abi.ChainEpoch]DrandEnum{
|
var DrandSchedule = map[abi.ChainEpoch]DrandEnum{
|
||||||
0: DrandMainnet,
|
0: DrandMainnet,
|
||||||
|
@ -22,8 +22,8 @@ const UnixfsLinksPerLevel = 1024
|
|||||||
// Consensus / Network
|
// Consensus / Network
|
||||||
|
|
||||||
const AllowableClockDriftSecs = uint64(1)
|
const AllowableClockDriftSecs = uint64(1)
|
||||||
const NewestNetworkVersion = network.Version2
|
const NewestNetworkVersion = network.Version3
|
||||||
const ActorUpgradeNetworkVersion = network.Version3
|
const ActorUpgradeNetworkVersion = network.Version4
|
||||||
|
|
||||||
// Epochs
|
// Epochs
|
||||||
const ForkLengthThreshold = Finality
|
const ForkLengthThreshold = Finality
|
||||||
@ -63,6 +63,8 @@ const WinningPoStSectorSetLookback = abi.ChainEpoch(10)
|
|||||||
// /////
|
// /////
|
||||||
// Devnet settings
|
// Devnet settings
|
||||||
|
|
||||||
|
var Devnet = true
|
||||||
|
|
||||||
const FilBase = uint64(2_000_000_000)
|
const FilBase = uint64(2_000_000_000)
|
||||||
const FilAllocStorageMining = uint64(1_100_000_000)
|
const FilAllocStorageMining = uint64(1_100_000_000)
|
||||||
|
|
||||||
|
@ -74,7 +74,9 @@ var (
|
|||||||
UpgradeBreezeHeight abi.ChainEpoch = -1
|
UpgradeBreezeHeight abi.ChainEpoch = -1
|
||||||
BreezeGasTampingDuration abi.ChainEpoch = 0
|
BreezeGasTampingDuration abi.ChainEpoch = 0
|
||||||
|
|
||||||
UpgradeSmokeHeight abi.ChainEpoch = -1
|
UpgradeSmokeHeight abi.ChainEpoch = -1
|
||||||
|
UpgradeIgnitionHeight abi.ChainEpoch = -2
|
||||||
|
UpgradeLiftoffHeight abi.ChainEpoch = -3
|
||||||
|
|
||||||
DrandSchedule = map[abi.ChainEpoch]DrandEnum{
|
DrandSchedule = map[abi.ChainEpoch]DrandEnum{
|
||||||
0: DrandMainnet,
|
0: DrandMainnet,
|
||||||
@ -82,4 +84,6 @@ var (
|
|||||||
|
|
||||||
NewestNetworkVersion = network.Version2
|
NewestNetworkVersion = network.Version2
|
||||||
ActorUpgradeNetworkVersion = network.Version3
|
ActorUpgradeNetworkVersion = network.Version3
|
||||||
|
|
||||||
|
Devnet = true
|
||||||
)
|
)
|
||||||
|
@ -21,12 +21,20 @@ const BreezeGasTampingDuration = 120
|
|||||||
|
|
||||||
const UpgradeSmokeHeight = 51000
|
const UpgradeSmokeHeight = 51000
|
||||||
|
|
||||||
|
const UpgradeIgnitionHeight = 94000
|
||||||
|
|
||||||
|
// This signals our tentative epoch for mainnet launch. Can make it later, but not earlier.
|
||||||
|
// Miners, clients, developers, custodians all need time to prepare.
|
||||||
|
// We still have upgrades and state changes to do, but can happen after signaling timing here.
|
||||||
|
const UpgradeLiftoffHeight = 148888
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
policy.SetConsensusMinerMinPower(abi.NewStoragePower(10 << 40))
|
policy.SetConsensusMinerMinPower(abi.NewStoragePower(10 << 40))
|
||||||
policy.SetSupportedProofTypes(
|
policy.SetSupportedProofTypes(
|
||||||
abi.RegisteredSealProof_StackedDrg32GiBV1,
|
abi.RegisteredSealProof_StackedDrg32GiBV1,
|
||||||
abi.RegisteredSealProof_StackedDrg64GiBV1,
|
abi.RegisteredSealProof_StackedDrg64GiBV1,
|
||||||
)
|
)
|
||||||
|
Devnet = false
|
||||||
}
|
}
|
||||||
|
|
||||||
const BlockDelaySecs = uint64(builtin0.EpochDurationSeconds)
|
const BlockDelaySecs = uint64(builtin0.EpochDurationSeconds)
|
||||||
|
@ -21,7 +21,7 @@ const (
|
|||||||
// Converts a network version into a specs-actors version.
|
// Converts a network version into a specs-actors version.
|
||||||
func VersionForNetwork(version network.Version) Version {
|
func VersionForNetwork(version network.Version) Version {
|
||||||
switch version {
|
switch version {
|
||||||
case network.Version0, network.Version1, network.Version2:
|
case network.Version0, network.Version1, network.Version2, network.Version3:
|
||||||
return Version0
|
return Version0
|
||||||
default:
|
default:
|
||||||
panic(fmt.Sprintf("unsupported network version %d", version))
|
panic(fmt.Sprintf("unsupported network version %d", version))
|
||||||
|
@ -1,44 +1,59 @@
|
|||||||
package stmgr
|
package stmgr
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
"context"
|
"context"
|
||||||
|
"encoding/binary"
|
||||||
|
"math"
|
||||||
|
|
||||||
|
multisig0 "github.com/filecoin-project/specs-actors/actors/builtin/multisig"
|
||||||
|
|
||||||
|
"github.com/filecoin-project/lotus/chain/actors/builtin/multisig"
|
||||||
|
|
||||||
|
"github.com/filecoin-project/lotus/chain/state"
|
||||||
|
|
||||||
|
"github.com/filecoin-project/specs-actors/actors/migration/nv3"
|
||||||
|
|
||||||
|
"github.com/ipfs/go-cid"
|
||||||
|
|
||||||
"github.com/filecoin-project/go-address"
|
"github.com/filecoin-project/go-address"
|
||||||
"github.com/filecoin-project/go-state-types/abi"
|
"github.com/filecoin-project/go-state-types/abi"
|
||||||
"github.com/filecoin-project/go-state-types/big"
|
"github.com/filecoin-project/go-state-types/big"
|
||||||
|
|
||||||
builtin0 "github.com/filecoin-project/specs-actors/actors/builtin"
|
builtin0 "github.com/filecoin-project/specs-actors/actors/builtin"
|
||||||
|
init0 "github.com/filecoin-project/specs-actors/actors/builtin/init"
|
||||||
miner0 "github.com/filecoin-project/specs-actors/actors/builtin/miner"
|
miner0 "github.com/filecoin-project/specs-actors/actors/builtin/miner"
|
||||||
power0 "github.com/filecoin-project/specs-actors/actors/builtin/power"
|
power0 "github.com/filecoin-project/specs-actors/actors/builtin/power"
|
||||||
adt0 "github.com/filecoin-project/specs-actors/actors/util/adt"
|
adt0 "github.com/filecoin-project/specs-actors/actors/util/adt"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/build"
|
"github.com/filecoin-project/lotus/build"
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
|
"github.com/filecoin-project/lotus/chain/vm"
|
||||||
cbor "github.com/ipfs/go-ipld-cbor"
|
cbor "github.com/ipfs/go-ipld-cbor"
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
)
|
)
|
||||||
|
|
||||||
var ForksAtHeight = map[abi.ChainEpoch]func(context.Context, *StateManager, types.StateTree, *types.TipSet) error{
|
var ForksAtHeight = map[abi.ChainEpoch]func(context.Context, *StateManager, ExecCallback, cid.Cid, *types.TipSet) (cid.Cid, error){
|
||||||
build.UpgradeBreezeHeight: UpgradeFaucetBurnRecovery,
|
build.UpgradeBreezeHeight: UpgradeFaucetBurnRecovery,
|
||||||
|
build.UpgradeIgnitionHeight: UpgradeIgnition,
|
||||||
|
build.UpgradeLiftoffHeight: UpgradeLiftoff,
|
||||||
}
|
}
|
||||||
|
|
||||||
func (sm *StateManager) handleStateForks(ctx context.Context, st types.StateTree, height abi.ChainEpoch, ts *types.TipSet) (err error) {
|
func (sm *StateManager) handleStateForks(ctx context.Context, root cid.Cid, height abi.ChainEpoch, cb ExecCallback, ts *types.TipSet) (cid.Cid, error) {
|
||||||
|
retCid := root
|
||||||
|
var err error
|
||||||
f, ok := ForksAtHeight[height]
|
f, ok := ForksAtHeight[height]
|
||||||
if ok {
|
if ok {
|
||||||
err := f(ctx, sm, st, ts)
|
retCid, err = f(ctx, sm, cb, root, ts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return cid.Undef, err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return retCid, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
type forEachTree interface {
|
func doTransfer(cb ExecCallback, tree types.StateTree, from, to address.Address, amt abi.TokenAmount) error {
|
||||||
ForEach(func(address.Address, *types.Actor) error) error
|
|
||||||
}
|
|
||||||
|
|
||||||
func doTransfer(tree types.StateTree, from, to address.Address, amt abi.TokenAmount) error {
|
|
||||||
fromAct, err := tree.GetActor(from)
|
fromAct, err := tree.GetActor(from)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("failed to get 'from' actor for transfer: %w", err)
|
return xerrors.Errorf("failed to get 'from' actor for transfer: %w", err)
|
||||||
@ -64,10 +79,43 @@ func doTransfer(tree types.StateTree, from, to address.Address, amt abi.TokenAmo
|
|||||||
return xerrors.Errorf("failed to persist to actor: %w", err)
|
return xerrors.Errorf("failed to persist to actor: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if cb != nil {
|
||||||
|
// record the transfer in execution traces
|
||||||
|
|
||||||
|
fakeMsg := &types.Message{
|
||||||
|
From: from,
|
||||||
|
To: to,
|
||||||
|
Value: amt,
|
||||||
|
Nonce: math.MaxUint64,
|
||||||
|
}
|
||||||
|
fakeRct := &types.MessageReceipt{
|
||||||
|
ExitCode: 0,
|
||||||
|
Return: nil,
|
||||||
|
GasUsed: 0,
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := cb(fakeMsg.Cid(), fakeMsg, &vm.ApplyRet{
|
||||||
|
MessageReceipt: *fakeRct,
|
||||||
|
ActorErr: nil,
|
||||||
|
ExecutionTrace: types.ExecutionTrace{
|
||||||
|
Msg: fakeMsg,
|
||||||
|
MsgRct: fakeRct,
|
||||||
|
Error: "",
|
||||||
|
Duration: 0,
|
||||||
|
GasCharges: nil,
|
||||||
|
Subcalls: nil,
|
||||||
|
},
|
||||||
|
Duration: 0,
|
||||||
|
GasCosts: vm.ZeroGasOutputs(),
|
||||||
|
}); err != nil {
|
||||||
|
return xerrors.Errorf("recording transfer: %w", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func UpgradeFaucetBurnRecovery(ctx context.Context, sm *StateManager, tree types.StateTree, ts *types.TipSet) error {
|
func UpgradeFaucetBurnRecovery(ctx context.Context, sm *StateManager, cb ExecCallback, root cid.Cid, ts *types.TipSet) (cid.Cid, error) {
|
||||||
// Some initial parameters
|
// Some initial parameters
|
||||||
FundsForMiners := types.FromFil(1_000_000)
|
FundsForMiners := types.FromFil(1_000_000)
|
||||||
LookbackEpoch := abi.ChainEpoch(32000)
|
LookbackEpoch := abi.ChainEpoch(32000)
|
||||||
@ -94,22 +142,22 @@ func UpgradeFaucetBurnRecovery(ctx context.Context, sm *StateManager, tree types
|
|||||||
// Grab lookback state for account checks
|
// Grab lookback state for account checks
|
||||||
lbts, err := sm.ChainStore().GetTipsetByHeight(ctx, LookbackEpoch, ts, false)
|
lbts, err := sm.ChainStore().GetTipsetByHeight(ctx, LookbackEpoch, ts, false)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("failed to get tipset at lookback height: %w", err)
|
return cid.Undef, xerrors.Errorf("failed to get tipset at lookback height: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
lbtree, err := sm.ParentState(lbts)
|
lbtree, err := sm.ParentState(lbts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("loading state tree failed: %w", err)
|
return cid.Undef, xerrors.Errorf("loading state tree failed: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
ReserveAddress, err := address.NewFromString("t090")
|
ReserveAddress, err := address.NewFromString("t090")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("failed to parse reserve address: %w", err)
|
return cid.Undef, xerrors.Errorf("failed to parse reserve address: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
fetree, ok := tree.(forEachTree)
|
tree, err := sm.StateTree(root)
|
||||||
if !ok {
|
if err != nil {
|
||||||
return xerrors.Errorf("fork transition state tree doesnt support ForEach (%T)", tree)
|
return cid.Undef, xerrors.Errorf("getting state tree: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
type transfer struct {
|
type transfer struct {
|
||||||
@ -121,7 +169,7 @@ func UpgradeFaucetBurnRecovery(ctx context.Context, sm *StateManager, tree types
|
|||||||
var transfers []transfer
|
var transfers []transfer
|
||||||
|
|
||||||
// Take all excess funds away, put them into the reserve account
|
// Take all excess funds away, put them into the reserve account
|
||||||
err = fetree.ForEach(func(addr address.Address, act *types.Actor) error {
|
err = tree.ForEach(func(addr address.Address, act *types.Actor) error {
|
||||||
switch act.Code {
|
switch act.Code {
|
||||||
case builtin0.AccountActorCodeID, builtin0.MultisigActorCodeID, builtin0.PaymentChannelActorCodeID:
|
case builtin0.AccountActorCodeID, builtin0.MultisigActorCodeID, builtin0.PaymentChannelActorCodeID:
|
||||||
sysAcc, err := isSystemAccount(addr)
|
sysAcc, err := isSystemAccount(addr)
|
||||||
@ -163,13 +211,13 @@ func UpgradeFaucetBurnRecovery(ctx context.Context, sm *StateManager, tree types
|
|||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("foreach over state tree failed: %w", err)
|
return cid.Undef, xerrors.Errorf("foreach over state tree failed: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Execute transfers from previous step
|
// Execute transfers from previous step
|
||||||
for _, t := range transfers {
|
for _, t := range transfers {
|
||||||
if err := doTransfer(tree, t.From, t.To, t.Amt); err != nil {
|
if err := doTransfer(cb, tree, t.From, t.To, t.Amt); err != nil {
|
||||||
return xerrors.Errorf("transfer %s %s->%s failed: %w", t.Amt, t.From, t.To, err)
|
return cid.Undef, xerrors.Errorf("transfer %s %s->%s failed: %w", t.Amt, t.From, t.To, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -177,19 +225,19 @@ func UpgradeFaucetBurnRecovery(ctx context.Context, sm *StateManager, tree types
|
|||||||
var ps power0.State
|
var ps power0.State
|
||||||
powAct, err := tree.GetActor(builtin0.StoragePowerActorAddr)
|
powAct, err := tree.GetActor(builtin0.StoragePowerActorAddr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("failed to load power actor: %w", err)
|
return cid.Undef, xerrors.Errorf("failed to load power actor: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
cst := cbor.NewCborStore(sm.ChainStore().Blockstore())
|
cst := cbor.NewCborStore(sm.ChainStore().Blockstore())
|
||||||
if err := cst.Get(ctx, powAct.Head, &ps); err != nil {
|
if err := cst.Get(ctx, powAct.Head, &ps); err != nil {
|
||||||
return xerrors.Errorf("failed to get power actor state: %w", err)
|
return cid.Undef, xerrors.Errorf("failed to get power actor state: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
totalPower := ps.TotalBytesCommitted
|
totalPower := ps.TotalBytesCommitted
|
||||||
|
|
||||||
var transfersBack []transfer
|
var transfersBack []transfer
|
||||||
// Now, we return some funds to places where they are needed
|
// Now, we return some funds to places where they are needed
|
||||||
err = fetree.ForEach(func(addr address.Address, act *types.Actor) error {
|
err = tree.ForEach(func(addr address.Address, act *types.Actor) error {
|
||||||
lbact, err := lbtree.GetActor(addr)
|
lbact, err := lbtree.GetActor(addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if !xerrors.Is(err, types.ErrActorNotFound) {
|
if !xerrors.Is(err, types.ErrActorNotFound) {
|
||||||
@ -267,53 +315,310 @@ func UpgradeFaucetBurnRecovery(ctx context.Context, sm *StateManager, tree types
|
|||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("foreach over state tree failed: %w", err)
|
return cid.Undef, xerrors.Errorf("foreach over state tree failed: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, t := range transfersBack {
|
for _, t := range transfersBack {
|
||||||
if err := doTransfer(tree, t.From, t.To, t.Amt); err != nil {
|
if err := doTransfer(cb, tree, t.From, t.To, t.Amt); err != nil {
|
||||||
return xerrors.Errorf("transfer %s %s->%s failed: %w", t.Amt, t.From, t.To, err)
|
return cid.Undef, xerrors.Errorf("transfer %s %s->%s failed: %w", t.Amt, t.From, t.To, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// transfer all burnt funds back to the reserve account
|
// transfer all burnt funds back to the reserve account
|
||||||
burntAct, err := tree.GetActor(builtin0.BurntFundsActorAddr)
|
burntAct, err := tree.GetActor(builtin0.BurntFundsActorAddr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("failed to load burnt funds actor: %w", err)
|
return cid.Undef, xerrors.Errorf("failed to load burnt funds actor: %w", err)
|
||||||
}
|
}
|
||||||
if err := doTransfer(tree, builtin0.BurntFundsActorAddr, ReserveAddress, burntAct.Balance); err != nil {
|
if err := doTransfer(cb, tree, builtin0.BurntFundsActorAddr, ReserveAddress, burntAct.Balance); err != nil {
|
||||||
return xerrors.Errorf("failed to unburn funds: %w", err)
|
return cid.Undef, xerrors.Errorf("failed to unburn funds: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Top up the reimbursement service
|
// Top up the reimbursement service
|
||||||
reimbAddr, err := address.NewFromString("t0111")
|
reimbAddr, err := address.NewFromString("t0111")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("failed to parse reimbursement service address")
|
return cid.Undef, xerrors.Errorf("failed to parse reimbursement service address")
|
||||||
}
|
}
|
||||||
|
|
||||||
reimb, err := tree.GetActor(reimbAddr)
|
reimb, err := tree.GetActor(reimbAddr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("failed to load reimbursement account actor: %w", err)
|
return cid.Undef, xerrors.Errorf("failed to load reimbursement account actor: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
difference := types.BigSub(DesiredReimbursementBalance, reimb.Balance)
|
difference := types.BigSub(DesiredReimbursementBalance, reimb.Balance)
|
||||||
if err := doTransfer(tree, ReserveAddress, reimbAddr, difference); err != nil {
|
if err := doTransfer(cb, tree, ReserveAddress, reimbAddr, difference); err != nil {
|
||||||
return xerrors.Errorf("failed to top up reimbursement account: %w", err)
|
return cid.Undef, xerrors.Errorf("failed to top up reimbursement account: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Now, a final sanity check to make sure the balances all check out
|
// Now, a final sanity check to make sure the balances all check out
|
||||||
total := abi.NewTokenAmount(0)
|
total := abi.NewTokenAmount(0)
|
||||||
err = fetree.ForEach(func(addr address.Address, act *types.Actor) error {
|
err = tree.ForEach(func(addr address.Address, act *types.Actor) error {
|
||||||
total = types.BigAdd(total, act.Balance)
|
total = types.BigAdd(total, act.Balance)
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("checking final state balance failed: %w", err)
|
return cid.Undef, xerrors.Errorf("checking final state balance failed: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
exp := types.FromFil(build.FilBase)
|
exp := types.FromFil(build.FilBase)
|
||||||
if !exp.Equals(total) {
|
if !exp.Equals(total) {
|
||||||
return xerrors.Errorf("resultant state tree account balance was not correct: %s", total)
|
return cid.Undef, xerrors.Errorf("resultant state tree account balance was not correct: %s", total)
|
||||||
|
}
|
||||||
|
|
||||||
|
return tree.Flush(ctx)
|
||||||
|
}
|
||||||
|
|
||||||
|
func UpgradeIgnition(ctx context.Context, sm *StateManager, cb ExecCallback, root cid.Cid, ts *types.TipSet) (cid.Cid, error) {
|
||||||
|
store := sm.cs.Store(ctx)
|
||||||
|
|
||||||
|
nst, err := nv3.MigrateStateTree(ctx, store, root, build.UpgradeIgnitionHeight)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("migrating actors state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
tree, err := sm.StateTree(nst)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("getting state tree: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = setNetworkName(ctx, store, tree, "ignition")
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("setting network name: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
split1, err := address.NewFromString("t0115")
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("first split address: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
split2, err := address.NewFromString("t0116")
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("second split address: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = resetGenesisMsigs(ctx, sm, store, tree)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("resetting genesis msig start epochs: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = splitGenesisMultisig(ctx, cb, split1, store, tree, 50)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("splitting first msig: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = splitGenesisMultisig(ctx, cb, split2, store, tree, 50)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("splitting second msig: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = nv3.CheckStateTree(ctx, store, nst, build.UpgradeIgnitionHeight, builtin0.TotalFilecoin)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("sanity check after ignition upgrade failed: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return tree.Flush(ctx)
|
||||||
|
}
|
||||||
|
|
||||||
|
func UpgradeLiftoff(ctx context.Context, sm *StateManager, cb ExecCallback, root cid.Cid, ts *types.TipSet) (cid.Cid, error) {
|
||||||
|
tree, err := sm.StateTree(root)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("getting state tree: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = setNetworkName(ctx, sm.cs.Store(ctx), tree, "mainnet")
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("setting network name: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return tree.Flush(ctx)
|
||||||
|
}
|
||||||
|
|
||||||
|
func setNetworkName(ctx context.Context, store adt0.Store, tree *state.StateTree, name string) error {
|
||||||
|
ia, err := tree.GetActor(builtin0.InitActorAddr)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting init actor: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
var initState init0.State
|
||||||
|
if err := store.Get(ctx, ia.Head, &initState); err != nil {
|
||||||
|
return xerrors.Errorf("reading init state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
initState.NetworkName = name
|
||||||
|
|
||||||
|
ia.Head, err = store.Put(ctx, &initState)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("writing new init state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := tree.SetActor(builtin0.InitActorAddr, ia); err != nil {
|
||||||
|
return xerrors.Errorf("setting init actor: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func splitGenesisMultisig(ctx context.Context, cb ExecCallback, addr address.Address, store adt0.Store, tree *state.StateTree, portions uint64) error {
|
||||||
|
if portions < 1 {
|
||||||
|
return xerrors.Errorf("cannot split into 0 portions")
|
||||||
|
}
|
||||||
|
|
||||||
|
mact, err := tree.GetActor(addr)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting msig actor: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
mst, err := multisig.Load(store, mact)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting msig state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
signers, err := mst.Signers()
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting msig signers: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
thresh, err := mst.Threshold()
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting msig threshold: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
ibal, err := mst.InitialBalance()
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting msig initial balance: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
se, err := mst.StartEpoch()
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting msig start epoch: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
ud, err := mst.UnlockDuration()
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting msig unlock duration: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
pending, err := adt0.MakeEmptyMap(store).Root()
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("failed to create empty map: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
newIbal := big.Div(ibal, types.NewInt(portions))
|
||||||
|
newState := &multisig0.State{
|
||||||
|
Signers: signers,
|
||||||
|
NumApprovalsThreshold: thresh,
|
||||||
|
NextTxnID: 0,
|
||||||
|
InitialBalance: newIbal,
|
||||||
|
StartEpoch: se,
|
||||||
|
UnlockDuration: ud,
|
||||||
|
PendingTxns: pending,
|
||||||
|
}
|
||||||
|
|
||||||
|
scid, err := store.Put(ctx, newState)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("storing new state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
newActor := types.Actor{
|
||||||
|
Code: builtin0.MultisigActorCodeID,
|
||||||
|
Head: scid,
|
||||||
|
Nonce: 0,
|
||||||
|
Balance: big.Zero(),
|
||||||
|
}
|
||||||
|
|
||||||
|
i := uint64(0)
|
||||||
|
for i < portions {
|
||||||
|
keyAddr, err := makeKeyAddr(addr, i)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("creating key address: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
idAddr, err := tree.RegisterNewAddress(keyAddr)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("registering new address: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = tree.SetActor(idAddr, &newActor)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("setting new msig actor state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := doTransfer(cb, tree, addr, idAddr, newIbal); err != nil {
|
||||||
|
return xerrors.Errorf("transferring split msig balance: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
i++
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func makeKeyAddr(splitAddr address.Address, count uint64) (address.Address, error) {
|
||||||
|
var b bytes.Buffer
|
||||||
|
if err := splitAddr.MarshalCBOR(&b); err != nil {
|
||||||
|
return address.Undef, xerrors.Errorf("marshalling split address: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := binary.Write(&b, binary.BigEndian, count); err != nil {
|
||||||
|
return address.Undef, xerrors.Errorf("writing count into a buffer: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := binary.Write(&b, binary.BigEndian, []byte("Ignition upgrade")); err != nil {
|
||||||
|
return address.Undef, xerrors.Errorf("writing fork name into a buffer: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
addr, err := address.NewActorAddress(b.Bytes())
|
||||||
|
if err != nil {
|
||||||
|
return address.Undef, xerrors.Errorf("create actor address: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return addr, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func resetGenesisMsigs(ctx context.Context, sm *StateManager, store adt0.Store, tree *state.StateTree) error {
|
||||||
|
gb, err := sm.cs.GetGenesis()
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting genesis block: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
gts, err := types.NewTipSet([]*types.BlockHeader{gb})
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting genesis tipset: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
cst := cbor.NewCborStore(sm.cs.Blockstore())
|
||||||
|
genesisTree, err := state.LoadStateTree(cst, gts.ParentState())
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("loading state tree: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = genesisTree.ForEach(func(addr address.Address, genesisActor *types.Actor) error {
|
||||||
|
if genesisActor.Code == builtin0.MultisigActorCodeID {
|
||||||
|
currActor, err := tree.GetActor(addr)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("loading actor: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
var currState multisig0.State
|
||||||
|
if err := store.Get(ctx, currActor.Head, &currState); err != nil {
|
||||||
|
return xerrors.Errorf("reading multisig state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
currState.StartEpoch = build.UpgradeLiftoffHeight
|
||||||
|
|
||||||
|
currActor.Head, err = store.Put(ctx, &currState)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("writing new multisig state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := tree.SetActor(addr, currActor); err != nil {
|
||||||
|
return xerrors.Errorf("setting multisig actor: %w", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("iterating over genesis actors: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
@ -25,6 +25,7 @@ import (
|
|||||||
_ "github.com/filecoin-project/lotus/lib/sigs/bls"
|
_ "github.com/filecoin-project/lotus/lib/sigs/bls"
|
||||||
_ "github.com/filecoin-project/lotus/lib/sigs/secp"
|
_ "github.com/filecoin-project/lotus/lib/sigs/secp"
|
||||||
|
|
||||||
|
"github.com/ipfs/go-cid"
|
||||||
cbor "github.com/ipfs/go-ipld-cbor"
|
cbor "github.com/ipfs/go-ipld-cbor"
|
||||||
logging "github.com/ipfs/go-log"
|
logging "github.com/ipfs/go-log"
|
||||||
cbg "github.com/whyrusleeping/cbor-gen"
|
cbg "github.com/whyrusleeping/cbor-gen"
|
||||||
@ -114,33 +115,38 @@ func TestForkHeightTriggers(t *testing.T) {
|
|||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
stmgr.ForksAtHeight[testForkHeight] = func(ctx context.Context, sm *StateManager, st types.StateTree, ts *types.TipSet) error {
|
stmgr.ForksAtHeight[testForkHeight] = func(ctx context.Context, sm *StateManager, cb ExecCallback, root cid.Cid, ts *types.TipSet) (cid.Cid, error) {
|
||||||
cst := cbor.NewCborStore(sm.ChainStore().Blockstore())
|
cst := cbor.NewCborStore(sm.ChainStore().Blockstore())
|
||||||
|
|
||||||
|
st, err := sm.StateTree(root)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("getting state tree: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
act, err := st.GetActor(taddr)
|
act, err := st.GetActor(taddr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return cid.Undef, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var tas testActorState
|
var tas testActorState
|
||||||
if err := cst.Get(ctx, act.Head, &tas); err != nil {
|
if err := cst.Get(ctx, act.Head, &tas); err != nil {
|
||||||
return xerrors.Errorf("in fork handler, failed to run get: %w", err)
|
return cid.Undef, xerrors.Errorf("in fork handler, failed to run get: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
tas.HasUpgraded = 55
|
tas.HasUpgraded = 55
|
||||||
|
|
||||||
ns, err := cst.Put(ctx, &tas)
|
ns, err := cst.Put(ctx, &tas)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return cid.Undef, err
|
||||||
}
|
}
|
||||||
|
|
||||||
act.Head = ns
|
act.Head = ns
|
||||||
|
|
||||||
if err := st.SetActor(taddr, act); err != nil {
|
if err := st.SetActor(taddr, act); err != nil {
|
||||||
return err
|
return cid.Undef, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return st.Flush(ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
inv.Register(builtin.PaymentChannelActorCodeID, &testActor{}, &testActorState{})
|
inv.Register(builtin.PaymentChannelActorCodeID, &testActor{}, &testActorState{})
|
||||||
|
@ -41,12 +41,13 @@ var log = logging.Logger("statemgr")
|
|||||||
type StateManager struct {
|
type StateManager struct {
|
||||||
cs *store.ChainStore
|
cs *store.ChainStore
|
||||||
|
|
||||||
stCache map[string][]cid.Cid
|
stCache map[string][]cid.Cid
|
||||||
compWait map[string]chan struct{}
|
compWait map[string]chan struct{}
|
||||||
stlk sync.Mutex
|
stlk sync.Mutex
|
||||||
genesisMsigLk sync.Mutex
|
genesisMsigLk sync.Mutex
|
||||||
newVM func(context.Context, *vm.VMOpts) (*vm.VM, error)
|
newVM func(context.Context, *vm.VMOpts) (*vm.VM, error)
|
||||||
genInfo *genesisInfo
|
preIgnitionGenInfos *genesisInfo
|
||||||
|
postIgnitionGenInfos *genesisInfo
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewStateManager(cs *store.ChainStore) *StateManager {
|
func NewStateManager(cs *store.ChainStore) *StateManager {
|
||||||
@ -123,9 +124,8 @@ func (sm *StateManager) TipSetState(ctx context.Context, ts *types.TipSet) (st c
|
|||||||
return st, rec, nil
|
return st, rec, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (sm *StateManager) ExecutionTrace(ctx context.Context, ts *types.TipSet) (cid.Cid, []*api.InvocResult, error) {
|
func traceFunc(trace *[]*api.InvocResult) func(mcid cid.Cid, msg *types.Message, ret *vm.ApplyRet) error {
|
||||||
var trace []*api.InvocResult
|
return func(mcid cid.Cid, msg *types.Message, ret *vm.ApplyRet) error {
|
||||||
st, _, err := sm.computeTipSetState(ctx, ts, func(mcid cid.Cid, msg *types.Message, ret *vm.ApplyRet) error {
|
|
||||||
ir := &api.InvocResult{
|
ir := &api.InvocResult{
|
||||||
Msg: msg,
|
Msg: msg,
|
||||||
MsgRct: &ret.MessageReceipt,
|
MsgRct: &ret.MessageReceipt,
|
||||||
@ -135,9 +135,14 @@ func (sm *StateManager) ExecutionTrace(ctx context.Context, ts *types.TipSet) (c
|
|||||||
if ret.ActorErr != nil {
|
if ret.ActorErr != nil {
|
||||||
ir.Error = ret.ActorErr.Error()
|
ir.Error = ret.ActorErr.Error()
|
||||||
}
|
}
|
||||||
trace = append(trace, ir)
|
*trace = append(*trace, ir)
|
||||||
return nil
|
return nil
|
||||||
})
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (sm *StateManager) ExecutionTrace(ctx context.Context, ts *types.TipSet) (cid.Cid, []*api.InvocResult, error) {
|
||||||
|
var trace []*api.InvocResult
|
||||||
|
st, _, err := sm.computeTipSetState(ctx, ts, traceFunc(&trace))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return cid.Undef, nil, err
|
return cid.Undef, nil, err
|
||||||
}
|
}
|
||||||
@ -149,20 +154,24 @@ type ExecCallback func(cid.Cid, *types.Message, *vm.ApplyRet) error
|
|||||||
|
|
||||||
func (sm *StateManager) ApplyBlocks(ctx context.Context, parentEpoch abi.ChainEpoch, pstate cid.Cid, bms []store.BlockMessages, epoch abi.ChainEpoch, r vm.Rand, cb ExecCallback, baseFee abi.TokenAmount, ts *types.TipSet) (cid.Cid, cid.Cid, error) {
|
func (sm *StateManager) ApplyBlocks(ctx context.Context, parentEpoch abi.ChainEpoch, pstate cid.Cid, bms []store.BlockMessages, epoch abi.ChainEpoch, r vm.Rand, cb ExecCallback, baseFee abi.TokenAmount, ts *types.TipSet) (cid.Cid, cid.Cid, error) {
|
||||||
|
|
||||||
vmopt := &vm.VMOpts{
|
makeVmWithBaseState := func(base cid.Cid) (*vm.VM, error) {
|
||||||
StateBase: pstate,
|
vmopt := &vm.VMOpts{
|
||||||
Epoch: epoch,
|
StateBase: base,
|
||||||
Rand: r,
|
Epoch: epoch,
|
||||||
Bstore: sm.cs.Blockstore(),
|
Rand: r,
|
||||||
Syscalls: sm.cs.VMSys(),
|
Bstore: sm.cs.Blockstore(),
|
||||||
CircSupplyCalc: sm.GetCirculatingSupply,
|
Syscalls: sm.cs.VMSys(),
|
||||||
NtwkVersion: sm.GetNtwkVersion,
|
CircSupplyCalc: sm.GetCirculatingSupply,
|
||||||
BaseFee: baseFee,
|
NtwkVersion: sm.GetNtwkVersion,
|
||||||
|
BaseFee: baseFee,
|
||||||
|
}
|
||||||
|
|
||||||
|
return sm.newVM(ctx, vmopt)
|
||||||
}
|
}
|
||||||
|
|
||||||
vmi, err := sm.newVM(ctx, vmopt)
|
vmi, err := makeVmWithBaseState(pstate)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return cid.Undef, cid.Undef, xerrors.Errorf("instantiating VM failed: %w", err)
|
return cid.Undef, cid.Undef, xerrors.Errorf("making vm: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
runCron := func() error {
|
runCron := func() error {
|
||||||
@ -202,19 +211,32 @@ func (sm *StateManager) ApplyBlocks(ctx context.Context, parentEpoch abi.ChainEp
|
|||||||
for i := parentEpoch; i < epoch; i++ {
|
for i := parentEpoch; i < epoch; i++ {
|
||||||
// handle state forks
|
// handle state forks
|
||||||
// XXX: The state tree
|
// XXX: The state tree
|
||||||
err = sm.handleStateForks(ctx, vmi.StateTree(), i, ts)
|
newState, err := sm.handleStateForks(ctx, pstate, i, cb, ts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return cid.Undef, cid.Undef, xerrors.Errorf("error handling state forks: %w", err)
|
return cid.Undef, cid.Undef, xerrors.Errorf("error handling state forks: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if pstate != newState {
|
||||||
|
vmi, err = makeVmWithBaseState(newState)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, cid.Undef, xerrors.Errorf("making vm: %w", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if i > parentEpoch {
|
if i > parentEpoch {
|
||||||
// run cron for null rounds if any
|
// run cron for null rounds if any
|
||||||
if err := runCron(); err != nil {
|
if err := runCron(); err != nil {
|
||||||
return cid.Cid{}, cid.Cid{}, err
|
return cid.Cid{}, cid.Cid{}, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
newState, err = vmi.Flush(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, cid.Undef, xerrors.Errorf("flushing vm: %w", err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
vmi.SetBlockHeight(i + 1)
|
vmi.SetBlockHeight(i + 1)
|
||||||
|
pstate = newState
|
||||||
}
|
}
|
||||||
|
|
||||||
var receipts []cbg.CBORMarshaler
|
var receipts []cbg.CBORMarshaler
|
||||||
@ -904,7 +926,7 @@ func (sm *StateManager) setupGenesisActors(ctx context.Context) error {
|
|||||||
gi.genesisMsigs = append(gi.genesisMsigs, ns)
|
gi.genesisMsigs = append(gi.genesisMsigs, ns)
|
||||||
}
|
}
|
||||||
|
|
||||||
sm.genInfo = &gi
|
sm.preIgnitionGenInfos = &gi
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -912,7 +934,7 @@ func (sm *StateManager) setupGenesisActors(ctx context.Context) error {
|
|||||||
// sets up information about the actors in the genesis state
|
// sets up information about the actors in the genesis state
|
||||||
// For testnet we use a hardcoded set of multisig states, instead of what's actually in the genesis multisigs
|
// For testnet we use a hardcoded set of multisig states, instead of what's actually in the genesis multisigs
|
||||||
// We also do not consider ANY account actors (including the faucet)
|
// We also do not consider ANY account actors (including the faucet)
|
||||||
func (sm *StateManager) setupGenesisActorsTestnet(ctx context.Context) error {
|
func (sm *StateManager) setupPreIgnitionGenesisActorsTestnet(ctx context.Context) error {
|
||||||
|
|
||||||
gi := genesisInfo{}
|
gi := genesisInfo{}
|
||||||
|
|
||||||
@ -981,7 +1003,87 @@ func (sm *StateManager) setupGenesisActorsTestnet(ctx context.Context) error {
|
|||||||
gi.genesisMsigs = append(gi.genesisMsigs, ns)
|
gi.genesisMsigs = append(gi.genesisMsigs, ns)
|
||||||
}
|
}
|
||||||
|
|
||||||
sm.genInfo = &gi
|
sm.preIgnitionGenInfos = &gi
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// sets up information about the actors in the genesis state, post the ignition fork
|
||||||
|
func (sm *StateManager) setupPostIgnitionGenesisActors(ctx context.Context) error {
|
||||||
|
|
||||||
|
gi := genesisInfo{}
|
||||||
|
|
||||||
|
gb, err := sm.cs.GetGenesis()
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting genesis block: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
gts, err := types.NewTipSet([]*types.BlockHeader{gb})
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting genesis tipset: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
st, _, err := sm.TipSetState(ctx, gts)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("getting genesis tipset state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
cst := cbor.NewCborStore(sm.cs.Blockstore())
|
||||||
|
sTree, err := state.LoadStateTree(cst, st)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("loading state tree: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unnecessary, should be removed
|
||||||
|
gi.genesisMarketFunds, err = getFilMarketLocked(ctx, sTree)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("setting up genesis market funds: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unnecessary, should be removed
|
||||||
|
gi.genesisPledge, err = getFilPowerLocked(ctx, sTree)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("setting up genesis pledge: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
totalsByEpoch := make(map[abi.ChainEpoch]abi.TokenAmount)
|
||||||
|
|
||||||
|
// 6 months
|
||||||
|
sixMonths := abi.ChainEpoch(183 * builtin0.EpochsInDay)
|
||||||
|
totalsByEpoch[sixMonths] = big.NewInt(49_929_341)
|
||||||
|
totalsByEpoch[sixMonths] = big.Add(totalsByEpoch[sixMonths], big.NewInt(32_787_700))
|
||||||
|
|
||||||
|
// 1 year
|
||||||
|
oneYear := abi.ChainEpoch(365 * builtin0.EpochsInDay)
|
||||||
|
totalsByEpoch[oneYear] = big.NewInt(22_421_712)
|
||||||
|
|
||||||
|
// 2 years
|
||||||
|
twoYears := abi.ChainEpoch(2 * 365 * builtin0.EpochsInDay)
|
||||||
|
totalsByEpoch[twoYears] = big.NewInt(7_223_364)
|
||||||
|
|
||||||
|
// 3 years
|
||||||
|
threeYears := abi.ChainEpoch(3 * 365 * builtin0.EpochsInDay)
|
||||||
|
totalsByEpoch[threeYears] = big.NewInt(87_637_883)
|
||||||
|
|
||||||
|
// 6 years
|
||||||
|
sixYears := abi.ChainEpoch(6 * 365 * builtin0.EpochsInDay)
|
||||||
|
totalsByEpoch[sixYears] = big.NewInt(100_000_000)
|
||||||
|
totalsByEpoch[sixYears] = big.Add(totalsByEpoch[sixYears], big.NewInt(300_000_000))
|
||||||
|
|
||||||
|
gi.genesisMsigs = make([]msig0.State, 0, len(totalsByEpoch))
|
||||||
|
for k, v := range totalsByEpoch {
|
||||||
|
ns := msig0.State{
|
||||||
|
// In the pre-ignition logic, we incorrectly set this value in Fil, not attoFil, an off-by-10^18 error
|
||||||
|
InitialBalance: big.Mul(v, big.NewInt(int64(build.FilecoinPrecision))),
|
||||||
|
UnlockDuration: k,
|
||||||
|
PendingTxns: cid.Undef,
|
||||||
|
// In the pre-ignition logic, the start epoch was 0. This changes in the fork logic of the Ignition upgrade itself.
|
||||||
|
StartEpoch: build.UpgradeLiftoffHeight,
|
||||||
|
}
|
||||||
|
gi.genesisMsigs = append(gi.genesisMsigs, ns)
|
||||||
|
}
|
||||||
|
|
||||||
|
sm.postIgnitionGenInfos = &gi
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -991,13 +1093,23 @@ func (sm *StateManager) setupGenesisActorsTestnet(ctx context.Context) error {
|
|||||||
// - For Accounts, it counts max(currentBalance - genesisBalance, 0).
|
// - For Accounts, it counts max(currentBalance - genesisBalance, 0).
|
||||||
func (sm *StateManager) GetFilVested(ctx context.Context, height abi.ChainEpoch, st *state.StateTree) (abi.TokenAmount, error) {
|
func (sm *StateManager) GetFilVested(ctx context.Context, height abi.ChainEpoch, st *state.StateTree) (abi.TokenAmount, error) {
|
||||||
vf := big.Zero()
|
vf := big.Zero()
|
||||||
for _, v := range sm.genInfo.genesisMsigs {
|
if height <= build.UpgradeIgnitionHeight {
|
||||||
au := big.Sub(v.InitialBalance, v.AmountLocked(height))
|
for _, v := range sm.preIgnitionGenInfos.genesisMsigs {
|
||||||
vf = big.Add(vf, au)
|
au := big.Sub(v.InitialBalance, v.AmountLocked(height))
|
||||||
|
vf = big.Add(vf, au)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for _, v := range sm.postIgnitionGenInfos.genesisMsigs {
|
||||||
|
// In the pre-ignition logic, we simply called AmountLocked(height), assuming startEpoch was 0.
|
||||||
|
// The start epoch changed in the Ignition upgrade.
|
||||||
|
au := big.Sub(v.InitialBalance, v.AmountLocked(height-v.StartEpoch))
|
||||||
|
vf = big.Add(vf, au)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// there should not be any such accounts in testnet (and also none in mainnet?)
|
// there should not be any such accounts in testnet (and also none in mainnet?)
|
||||||
for _, v := range sm.genInfo.genesisActors {
|
// continue to use preIgnitionGenInfos, nothing changed at the Ignition epoch
|
||||||
|
for _, v := range sm.preIgnitionGenInfos.genesisActors {
|
||||||
act, err := st.GetActor(v.addr)
|
act, err := st.GetActor(v.addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return big.Zero(), xerrors.Errorf("failed to get actor: %w", err)
|
return big.Zero(), xerrors.Errorf("failed to get actor: %w", err)
|
||||||
@ -1009,8 +1121,10 @@ func (sm *StateManager) GetFilVested(ctx context.Context, height abi.ChainEpoch,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
vf = big.Add(vf, sm.genInfo.genesisPledge)
|
// continue to use preIgnitionGenInfos, nothing changed at the Ignition epoch
|
||||||
vf = big.Add(vf, sm.genInfo.genesisMarketFunds)
|
vf = big.Add(vf, sm.preIgnitionGenInfos.genesisPledge)
|
||||||
|
// continue to use preIgnitionGenInfos, nothing changed at the Ignition epoch
|
||||||
|
vf = big.Add(vf, sm.preIgnitionGenInfos.genesisMarketFunds)
|
||||||
|
|
||||||
return vf, nil
|
return vf, nil
|
||||||
}
|
}
|
||||||
@ -1084,10 +1198,16 @@ func GetFilBurnt(ctx context.Context, st *state.StateTree) (abi.TokenAmount, err
|
|||||||
func (sm *StateManager) GetCirculatingSupplyDetailed(ctx context.Context, height abi.ChainEpoch, st *state.StateTree) (api.CirculatingSupply, error) {
|
func (sm *StateManager) GetCirculatingSupplyDetailed(ctx context.Context, height abi.ChainEpoch, st *state.StateTree) (api.CirculatingSupply, error) {
|
||||||
sm.genesisMsigLk.Lock()
|
sm.genesisMsigLk.Lock()
|
||||||
defer sm.genesisMsigLk.Unlock()
|
defer sm.genesisMsigLk.Unlock()
|
||||||
if sm.genInfo == nil {
|
if sm.preIgnitionGenInfos == nil {
|
||||||
err := sm.setupGenesisActorsTestnet(ctx)
|
err := sm.setupPreIgnitionGenesisActorsTestnet(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return api.CirculatingSupply{}, xerrors.Errorf("failed to setup genesis information: %w", err)
|
return api.CirculatingSupply{}, xerrors.Errorf("failed to setup pre-ignition genesis information: %w", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if sm.postIgnitionGenInfos == nil {
|
||||||
|
err := sm.setupPostIgnitionGenesisActors(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return api.CirculatingSupply{}, xerrors.Errorf("failed to setup post-ignition genesis information: %w", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1152,6 +1272,10 @@ func (sm *StateManager) GetNtwkVersion(ctx context.Context, height abi.ChainEpoc
|
|||||||
return network.Version1
|
return network.Version1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if height <= build.UpgradeIgnitionHeight {
|
||||||
|
return network.Version2
|
||||||
|
}
|
||||||
|
|
||||||
return build.NewestNetworkVersion
|
return build.NewestNetworkVersion
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -368,6 +368,16 @@ func ComputeState(ctx context.Context, sm *StateManager, height abi.ChainEpoch,
|
|||||||
return cid.Undef, nil, err
|
return cid.Undef, nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for i := ts.Height(); i < height; i++ {
|
||||||
|
// handle state forks
|
||||||
|
base, err = sm.handleStateForks(ctx, base, i, traceFunc(&trace), ts)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, nil, xerrors.Errorf("error handling state forks: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: should we also run cron here?
|
||||||
|
}
|
||||||
|
|
||||||
r := store.NewChainRand(sm.cs, ts.Cids())
|
r := store.NewChainRand(sm.cs, ts.Cids())
|
||||||
vmopt := &vm.VMOpts{
|
vmopt := &vm.VMOpts{
|
||||||
StateBase: base,
|
StateBase: base,
|
||||||
@ -384,16 +394,6 @@ func ComputeState(ctx context.Context, sm *StateManager, height abi.ChainEpoch,
|
|||||||
return cid.Undef, nil, err
|
return cid.Undef, nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
for i := ts.Height(); i < height; i++ {
|
|
||||||
// handle state forks
|
|
||||||
err = sm.handleStateForks(ctx, vmi.StateTree(), i, ts)
|
|
||||||
if err != nil {
|
|
||||||
return cid.Undef, nil, xerrors.Errorf("error handling state forks: %w", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: should we also run cron here?
|
|
||||||
}
|
|
||||||
|
|
||||||
for i, msg := range msgs {
|
for i, msg := range msgs {
|
||||||
// TODO: Use the signed message length for secp messages
|
// TODO: Use the signed message length for secp messages
|
||||||
ret, err := vmi.ApplyMessage(ctx, msg)
|
ret, err := vmi.ApplyMessage(ctx, msg)
|
||||||
|
24
cli/state.go
24
cli/state.go
@ -19,6 +19,7 @@ import (
|
|||||||
"github.com/multiformats/go-multiaddr"
|
"github.com/multiformats/go-multiaddr"
|
||||||
|
|
||||||
"github.com/ipfs/go-cid"
|
"github.com/ipfs/go-cid"
|
||||||
|
cbor "github.com/ipfs/go-ipld-cbor"
|
||||||
"github.com/libp2p/go-libp2p-core/peer"
|
"github.com/libp2p/go-libp2p-core/peer"
|
||||||
"github.com/multiformats/go-multihash"
|
"github.com/multiformats/go-multihash"
|
||||||
"github.com/urfave/cli/v2"
|
"github.com/urfave/cli/v2"
|
||||||
@ -33,7 +34,9 @@ import (
|
|||||||
"github.com/filecoin-project/specs-actors/actors/builtin/exported"
|
"github.com/filecoin-project/specs-actors/actors/builtin/exported"
|
||||||
|
|
||||||
"github.com/filecoin-project/lotus/api"
|
"github.com/filecoin-project/lotus/api"
|
||||||
|
"github.com/filecoin-project/lotus/api/apibstore"
|
||||||
"github.com/filecoin-project/lotus/build"
|
"github.com/filecoin-project/lotus/build"
|
||||||
|
"github.com/filecoin-project/lotus/chain/state"
|
||||||
"github.com/filecoin-project/lotus/chain/stmgr"
|
"github.com/filecoin-project/lotus/chain/stmgr"
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
)
|
)
|
||||||
@ -834,14 +837,14 @@ var stateComputeStateCmd = &cli.Command{
|
|||||||
}
|
}
|
||||||
|
|
||||||
h := abi.ChainEpoch(cctx.Uint64("vm-height"))
|
h := abi.ChainEpoch(cctx.Uint64("vm-height"))
|
||||||
if h == 0 {
|
if ts == nil {
|
||||||
if ts == nil {
|
head, err := api.ChainHead(ctx)
|
||||||
head, err := api.ChainHead(ctx)
|
if err != nil {
|
||||||
if err != nil {
|
return err
|
||||||
return err
|
|
||||||
}
|
|
||||||
ts = head
|
|
||||||
}
|
}
|
||||||
|
ts = head
|
||||||
|
}
|
||||||
|
if h == 0 {
|
||||||
h = ts.Height()
|
h = ts.Height()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -863,13 +866,18 @@ var stateComputeStateCmd = &cli.Command{
|
|||||||
}
|
}
|
||||||
|
|
||||||
if cctx.Bool("html") {
|
if cctx.Bool("html") {
|
||||||
|
st, err := state.LoadStateTree(cbor.NewCborStore(apibstore.NewAPIBlockstore(api)), stout.Root)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("loading state tree: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
codeCache := map[address.Address]cid.Cid{}
|
codeCache := map[address.Address]cid.Cid{}
|
||||||
getCode := func(addr address.Address) (cid.Cid, error) {
|
getCode := func(addr address.Address) (cid.Cid, error) {
|
||||||
if c, found := codeCache[addr]; found {
|
if c, found := codeCache[addr]; found {
|
||||||
return c, nil
|
return c, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
c, err := api.StateGetActor(ctx, addr, ts.Key())
|
c, err := st.GetActor(addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return cid.Cid{}, err
|
return cid.Cid{}, err
|
||||||
}
|
}
|
||||||
|
@ -3,9 +3,16 @@ package main
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"strconv"
|
||||||
|
|
||||||
|
"github.com/docker/go-units"
|
||||||
|
lotusbuiltin "github.com/filecoin-project/lotus/chain/actors/builtin"
|
||||||
|
"github.com/filecoin-project/lotus/chain/actors/builtin/power"
|
||||||
|
"github.com/filecoin-project/lotus/chain/actors/builtin/reward"
|
||||||
|
|
||||||
"github.com/ipfs/go-cid"
|
"github.com/ipfs/go-cid"
|
||||||
cbor "github.com/ipfs/go-ipld-cbor"
|
cbor "github.com/ipfs/go-ipld-cbor"
|
||||||
|
logging "github.com/ipfs/go-log/v2"
|
||||||
"github.com/urfave/cli/v2"
|
"github.com/urfave/cli/v2"
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
@ -44,6 +51,7 @@ var auditsCmd = &cli.Command{
|
|||||||
Subcommands: []*cli.Command{
|
Subcommands: []*cli.Command{
|
||||||
chainBalanceCmd,
|
chainBalanceCmd,
|
||||||
chainBalanceStateCmd,
|
chainBalanceStateCmd,
|
||||||
|
chainPledgeCmd,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -248,3 +256,133 @@ var chainBalanceStateCmd = &cli.Command{
|
|||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var chainPledgeCmd = &cli.Command{
|
||||||
|
Name: "stateroot-pledge",
|
||||||
|
Description: "Calculate sector pledge numbers",
|
||||||
|
Flags: []cli.Flag{
|
||||||
|
&cli.StringFlag{
|
||||||
|
Name: "repo",
|
||||||
|
Value: "~/.lotus",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
ArgsUsage: "[stateroot epoch]",
|
||||||
|
Action: func(cctx *cli.Context) error {
|
||||||
|
logging.SetLogLevel("badger", "ERROR")
|
||||||
|
ctx := context.TODO()
|
||||||
|
|
||||||
|
if !cctx.Args().Present() {
|
||||||
|
return fmt.Errorf("must pass state root")
|
||||||
|
}
|
||||||
|
|
||||||
|
sroot, err := cid.Decode(cctx.Args().First())
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("failed to parse input: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
epoch, err := strconv.ParseInt(cctx.Args().Get(1), 10, 64)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("parsing epoch arg: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
fsrepo, err := repo.NewFS(cctx.String("repo"))
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
lkrepo, err := fsrepo.Lock(repo.FullNode)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
defer lkrepo.Close() //nolint:errcheck
|
||||||
|
|
||||||
|
ds, err := lkrepo.Datastore("/chain")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
mds, err := lkrepo.Datastore("/metadata")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
bs := blockstore.NewBlockstore(ds)
|
||||||
|
|
||||||
|
cs := store.NewChainStore(bs, mds, vm.Syscalls(ffiwrapper.ProofVerifier))
|
||||||
|
|
||||||
|
cst := cbor.NewCborStore(bs)
|
||||||
|
store := adt.WrapStore(ctx, cst)
|
||||||
|
|
||||||
|
sm := stmgr.NewStateManager(cs)
|
||||||
|
|
||||||
|
state, err := state.LoadStateTree(cst, sroot)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
powerSmoothed lotusbuiltin.FilterEstimate
|
||||||
|
pledgeCollateral abi.TokenAmount
|
||||||
|
)
|
||||||
|
if act, err := state.GetActor(power.Address); err != nil {
|
||||||
|
return xerrors.Errorf("loading miner actor: %w", err)
|
||||||
|
} else if s, err := power.Load(store, act); err != nil {
|
||||||
|
return xerrors.Errorf("loading power actor state: %w", err)
|
||||||
|
} else if p, err := s.TotalPowerSmoothed(); err != nil {
|
||||||
|
return xerrors.Errorf("failed to determine total power: %w", err)
|
||||||
|
} else if c, err := s.TotalLocked(); err != nil {
|
||||||
|
return xerrors.Errorf("failed to determine pledge collateral: %w", err)
|
||||||
|
} else {
|
||||||
|
powerSmoothed = p
|
||||||
|
pledgeCollateral = c
|
||||||
|
}
|
||||||
|
|
||||||
|
circ, err := sm.GetCirculatingSupplyDetailed(ctx, abi.ChainEpoch(epoch), state)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Println("(real) circulating supply: ", types.FIL(circ.FilCirculating))
|
||||||
|
if circ.FilCirculating.LessThan(big.Zero()) {
|
||||||
|
circ.FilCirculating = big.Zero()
|
||||||
|
}
|
||||||
|
|
||||||
|
rewardActor, err := state.GetActor(reward.Address)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("loading miner actor: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
rewardState, err := reward.Load(store, rewardActor)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("loading reward actor state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Println("FilVested", types.FIL(circ.FilVested))
|
||||||
|
fmt.Println("FilMined", types.FIL(circ.FilMined))
|
||||||
|
fmt.Println("FilBurnt", types.FIL(circ.FilBurnt))
|
||||||
|
fmt.Println("FilLocked", types.FIL(circ.FilLocked))
|
||||||
|
fmt.Println("FilCirculating", types.FIL(circ.FilCirculating))
|
||||||
|
|
||||||
|
for _, sectorWeight := range []abi.StoragePower{
|
||||||
|
types.NewInt(32 << 30),
|
||||||
|
types.NewInt(64 << 30),
|
||||||
|
types.NewInt(32 << 30 * 10),
|
||||||
|
types.NewInt(64 << 30 * 10),
|
||||||
|
} {
|
||||||
|
initialPledge, err := rewardState.InitialPledgeForPower(
|
||||||
|
sectorWeight,
|
||||||
|
pledgeCollateral,
|
||||||
|
&powerSmoothed,
|
||||||
|
circ.FilCirculating,
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
return xerrors.Errorf("calculating initial pledge: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Println("IP ", units.HumanSize(float64(sectorWeight.Uint64())), types.FIL(initialPledge))
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
},
|
||||||
|
}
|
||||||
|
@ -3825,7 +3825,7 @@ Inputs:
|
|||||||
]
|
]
|
||||||
```
|
```
|
||||||
|
|
||||||
Response: `2`
|
Response: `3`
|
||||||
|
|
||||||
### StateReadState
|
### StateReadState
|
||||||
StateReadState returns the indicated actor's state.
|
StateReadState returns the indicated actor's state.
|
||||||
|
2
go.mod
2
go.mod
@ -36,7 +36,7 @@ require (
|
|||||||
github.com/filecoin-project/go-statemachine v0.0.0-20200813232949-df9b130df370
|
github.com/filecoin-project/go-statemachine v0.0.0-20200813232949-df9b130df370
|
||||||
github.com/filecoin-project/go-statestore v0.1.0
|
github.com/filecoin-project/go-statestore v0.1.0
|
||||||
github.com/filecoin-project/go-storedcounter v0.0.0-20200421200003-1c99c62e8a5b
|
github.com/filecoin-project/go-storedcounter v0.0.0-20200421200003-1c99c62e8a5b
|
||||||
github.com/filecoin-project/specs-actors v0.9.10
|
github.com/filecoin-project/specs-actors v0.9.11
|
||||||
github.com/filecoin-project/specs-storage v0.1.1-0.20200907031224-ed2e5cd13796
|
github.com/filecoin-project/specs-storage v0.1.1-0.20200907031224-ed2e5cd13796
|
||||||
github.com/filecoin-project/test-vectors/schema v0.0.1
|
github.com/filecoin-project/test-vectors/schema v0.0.1
|
||||||
github.com/gbrlsnchs/jwt/v3 v3.0.0-beta.1
|
github.com/gbrlsnchs/jwt/v3 v3.0.0-beta.1
|
||||||
|
4
go.sum
4
go.sum
@ -254,8 +254,8 @@ github.com/filecoin-project/go-storedcounter v0.0.0-20200421200003-1c99c62e8a5b
|
|||||||
github.com/filecoin-project/go-storedcounter v0.0.0-20200421200003-1c99c62e8a5b/go.mod h1:Q0GQOBtKf1oE10eSXSlhN45kDBdGvEcVOqMiffqX+N8=
|
github.com/filecoin-project/go-storedcounter v0.0.0-20200421200003-1c99c62e8a5b/go.mod h1:Q0GQOBtKf1oE10eSXSlhN45kDBdGvEcVOqMiffqX+N8=
|
||||||
github.com/filecoin-project/specs-actors v0.9.4/go.mod h1:BStZQzx5x7TmCkLv0Bpa07U6cPKol6fd3w9KjMPZ6Z4=
|
github.com/filecoin-project/specs-actors v0.9.4/go.mod h1:BStZQzx5x7TmCkLv0Bpa07U6cPKol6fd3w9KjMPZ6Z4=
|
||||||
github.com/filecoin-project/specs-actors v0.9.7/go.mod h1:wM2z+kwqYgXn5Z7scV1YHLyd1Q1cy0R8HfTIWQ0BFGU=
|
github.com/filecoin-project/specs-actors v0.9.7/go.mod h1:wM2z+kwqYgXn5Z7scV1YHLyd1Q1cy0R8HfTIWQ0BFGU=
|
||||||
github.com/filecoin-project/specs-actors v0.9.10 h1:gU0TrRhgkCsBEOP42sGDE7RQuR0Cov9hJhBqq+RJmjU=
|
github.com/filecoin-project/specs-actors v0.9.11 h1:TnpG7HAeiUrfj0mJM7UaPW0P2137H62RGof7ftT5Mas=
|
||||||
github.com/filecoin-project/specs-actors v0.9.10/go.mod h1:czlvLQGEX0fjLLfdNHD7xLymy6L3n7aQzRWzsYGf+ys=
|
github.com/filecoin-project/specs-actors v0.9.11/go.mod h1:czlvLQGEX0fjLLfdNHD7xLymy6L3n7aQzRWzsYGf+ys=
|
||||||
github.com/filecoin-project/specs-storage v0.1.1-0.20200907031224-ed2e5cd13796 h1:dJsTPWpG2pcTeojO2pyn0c6l+x/3MZYCBgo/9d11JEk=
|
github.com/filecoin-project/specs-storage v0.1.1-0.20200907031224-ed2e5cd13796 h1:dJsTPWpG2pcTeojO2pyn0c6l+x/3MZYCBgo/9d11JEk=
|
||||||
github.com/filecoin-project/specs-storage v0.1.1-0.20200907031224-ed2e5cd13796/go.mod h1:nJRRM7Aa9XVvygr3W9k6xGF46RWzr2zxF/iGoAIfA/g=
|
github.com/filecoin-project/specs-storage v0.1.1-0.20200907031224-ed2e5cd13796/go.mod h1:nJRRM7Aa9XVvygr3W9k6xGF46RWzr2zxF/iGoAIfA/g=
|
||||||
github.com/filecoin-project/test-vectors/schema v0.0.1 h1:5fNF76nl4qolEvcIsjc0kUADlTMVHO73tW4kXXPnsus=
|
github.com/filecoin-project/test-vectors/schema v0.0.1 h1:5fNF76nl4qolEvcIsjc0kUADlTMVHO73tW4kXXPnsus=
|
||||||
|
@ -18,6 +18,7 @@ import (
|
|||||||
|
|
||||||
"github.com/filecoin-project/lotus/extern/sector-storage/ffiwrapper"
|
"github.com/filecoin-project/lotus/extern/sector-storage/ffiwrapper"
|
||||||
|
|
||||||
|
"github.com/filecoin-project/lotus/build"
|
||||||
"github.com/filecoin-project/lotus/chain"
|
"github.com/filecoin-project/lotus/chain"
|
||||||
"github.com/filecoin-project/lotus/chain/beacon"
|
"github.com/filecoin-project/lotus/chain/beacon"
|
||||||
"github.com/filecoin-project/lotus/chain/exchange"
|
"github.com/filecoin-project/lotus/chain/exchange"
|
||||||
@ -157,6 +158,10 @@ func SetGenesis(cs *store.ChainStore, g Genesis) (dtypes.AfterGenesisSet, error)
|
|||||||
}
|
}
|
||||||
|
|
||||||
func NetworkName(mctx helpers.MetricsCtx, lc fx.Lifecycle, cs *store.ChainStore, _ dtypes.AfterGenesisSet) (dtypes.NetworkName, error) {
|
func NetworkName(mctx helpers.MetricsCtx, lc fx.Lifecycle, cs *store.ChainStore, _ dtypes.AfterGenesisSet) (dtypes.NetworkName, error) {
|
||||||
|
if !build.Devnet {
|
||||||
|
return "testnetnet", nil
|
||||||
|
}
|
||||||
|
|
||||||
ctx := helpers.LifecycleCtx(mctx, lc)
|
ctx := helpers.LifecycleCtx(mctx, lc)
|
||||||
|
|
||||||
netName, err := stmgr.GetNetworkName(ctx, stmgr.NewStateManager(cs), cs.GetHeaviestTipSet().ParentState())
|
netName, err := stmgr.GetNetworkName(ctx, stmgr.NewStateManager(cs), cs.GetHeaviestTipSet().ParentState())
|
||||||
|
@ -109,6 +109,9 @@ func MinerID(ma dtypes.MinerAddress) (dtypes.MinerID, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func StorageNetworkName(ctx helpers.MetricsCtx, a lapi.FullNode) (dtypes.NetworkName, error) {
|
func StorageNetworkName(ctx helpers.MetricsCtx, a lapi.FullNode) (dtypes.NetworkName, error) {
|
||||||
|
if !build.Devnet {
|
||||||
|
return "testnetnet", nil
|
||||||
|
}
|
||||||
return a.StateNetworkName(ctx)
|
return a.StateNetworkName(ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -371,6 +371,10 @@ func (s *WindowPoStScheduler) runPost(ctx context.Context, di dline.Info, ts *ty
|
|||||||
return j
|
return j
|
||||||
})
|
})
|
||||||
|
|
||||||
|
if ts.Height() > build.UpgradeIgnitionHeight {
|
||||||
|
return // FORK: declaring faults after ignition upgrade makes no sense
|
||||||
|
}
|
||||||
|
|
||||||
if faults, sigmsg, err = s.checkNextFaults(context.TODO(), declDeadline, partitions); err != nil {
|
if faults, sigmsg, err = s.checkNextFaults(context.TODO(), declDeadline, partitions); err != nil {
|
||||||
// TODO: This is also potentially really bad, but we try to post anyways
|
// TODO: This is also potentially really bad, but we try to post anyways
|
||||||
log.Errorf("checking sector faults: %v", err)
|
log.Errorf("checking sector faults: %v", err)
|
||||||
|
Loading…
Reference in New Issue
Block a user