fix: nv21fix migration: correctly upgrade system actor
This commit is contained in:
parent
ee0152fac4
commit
fb3c16207f
@ -2063,6 +2063,19 @@ func upgradeActorsV12Fix(ctx context.Context, sm *stmgr.StateManager, cache stmg
|
|||||||
return cid.Undef, xerrors.Errorf("failed to perform migration: %w", err)
|
return cid.Undef, xerrors.Errorf("failed to perform migration: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
systemState.BuiltinActors = newManifest.Data
|
||||||
|
newSystemHead, err := adtStore.Put(ctx, systemState)
|
||||||
|
if err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("failed to put new system state: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
systemActor.Head = newSystemHead
|
||||||
|
if err = actorsOut.SetActor(builtin.SystemActorAddr, systemActor); err != nil {
|
||||||
|
return cid.Undef, xerrors.Errorf("failed to put new system actor: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Sanity checking
|
||||||
|
|
||||||
err = actorsIn.ForEach(func(a address.Address, inActor *types.Actor) error {
|
err = actorsIn.ForEach(func(a address.Address, inActor *types.Actor) error {
|
||||||
outActor, err := actorsOut.GetActor(a)
|
outActor, err := actorsOut.GetActor(a)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -177,7 +177,7 @@ func (us UpgradeSchedule) GetNtwkVersion(e abi.ChainEpoch) (network.Version, err
|
|||||||
func (sm *StateManager) HandleStateForks(ctx context.Context, root cid.Cid, height abi.ChainEpoch, cb ExecMonitor, ts *types.TipSet) (cid.Cid, error) {
|
func (sm *StateManager) HandleStateForks(ctx context.Context, root cid.Cid, height abi.ChainEpoch, cb ExecMonitor, ts *types.TipSet) (cid.Cid, error) {
|
||||||
retCid := root
|
retCid := root
|
||||||
u := sm.stateMigrations[height]
|
u := sm.stateMigrations[height]
|
||||||
if u != nil && u.upgrade != nil {
|
if u != nil && u.upgrade != nil && height != build.UpgradeWatermelonFixHeight {
|
||||||
migCid, ok, err := u.migrationResultCache.Get(ctx, root)
|
migCid, ok, err := u.migrationResultCache.Get(ctx, root)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
if ok {
|
if ok {
|
||||||
|
@ -92,6 +92,15 @@ func (x *FvmExtern) VerifyConsensusFault(ctx context.Context, a, b, extra []byte
|
|||||||
log.Info("invalid consensus fault: submitted blocks are the same")
|
log.Info("invalid consensus fault: submitted blocks are the same")
|
||||||
return ret, totalGas
|
return ret, totalGas
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// workaround chain halt
|
||||||
|
if build.IsNearUpgrade(blockA.Height, build.UpgradeWatermelonFixHeight) {
|
||||||
|
return ret, totalGas
|
||||||
|
}
|
||||||
|
if build.IsNearUpgrade(blockB.Height, build.UpgradeWatermelonFixHeight) {
|
||||||
|
return ret, totalGas
|
||||||
|
}
|
||||||
|
|
||||||
// (1) check conditions necessary to any consensus fault
|
// (1) check conditions necessary to any consensus fault
|
||||||
|
|
||||||
// were blocks mined by same miner?
|
// were blocks mined by same miner?
|
||||||
|
@ -324,7 +324,7 @@ minerLoop:
|
|||||||
"block-time", btime, "time", build.Clock.Now(), "difference", build.Clock.Since(btime))
|
"block-time", btime, "time", build.Clock.Now(), "difference", build.Clock.Since(btime))
|
||||||
}
|
}
|
||||||
|
|
||||||
if os.Getenv("LOTUS_MINER_NO_SLASHFILTER") != "_yes_i_know_i_can_and_probably_will_lose_all_my_fil_and_power_" {
|
if os.Getenv("LOTUS_MINER_NO_SLASHFILTER") != "_yes_i_know_i_can_and_probably_will_lose_all_my_fil_and_power_" && !build.IsNearUpgrade(base.TipSet.Height(), build.UpgradeWatermelonFixHeight) {
|
||||||
witness, fault, err := m.sf.MinedBlock(ctx, b.Header, base.TipSet.Height()+base.NullRounds)
|
witness, fault, err := m.sf.MinedBlock(ctx, b.Header, base.TipSet.Height()+base.NullRounds)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Errorf("<!!> SLASH FILTER ERRORED: %s", err)
|
log.Errorf("<!!> SLASH FILTER ERRORED: %s", err)
|
||||||
|
Loading…
Reference in New Issue
Block a user