clean up usage of stmgr.TipSetState

This commit is contained in:
whyrusleeping 2019-10-02 14:03:27 -06:00
parent 65def6cc58
commit c0e6e611be
8 changed files with 20 additions and 37 deletions

View File

@ -143,10 +143,7 @@ func (h *Handler) saveAsk(a *types.SignedStorageAsk) error {
} }
func (c *Client) checkAskSignature(ask *types.SignedStorageAsk) error { func (c *Client) checkAskSignature(ask *types.SignedStorageAsk) error {
tss, _, err := c.sm.TipSetState(c.sm.ChainStore().GetHeaviestTipSet().Cids()) tss := c.sm.ChainStore().GetHeaviestTipSet().ParentState()
if err != nil {
return xerrors.Errorf("failed to get tipsetstate to query for miner worker: %w", err)
}
w, err := stmgr.GetMinerWorker(context.TODO(), c.sm, tss, ask.Ask.Miner) w, err := stmgr.GetMinerWorker(context.TODO(), c.sm, tss, ask.Ask.Miner)
if err != nil { if err != nil {

View File

@ -201,10 +201,7 @@ func (cg *ChainGen) nextBlockProof(ctx context.Context, m address.Address, ticks
lastTicket = ticks[len(ticks)-1] lastTicket = ticks[len(ticks)-1]
} }
st, _, err := cg.sm.TipSetState(pts.Cids()) st := cg.curTipset.TipSet().ParentState()
if err != nil {
return nil, nil, err
}
worker, err := stmgr.GetMinerWorker(ctx, cg.sm, st, m) worker, err := stmgr.GetMinerWorker(ctx, cg.sm, st, m)
if err != nil { if err != nil {
@ -376,12 +373,7 @@ func (mca mca) StateMinerPower(ctx context.Context, maddr address.Address, ts *t
} }
func (mca mca) StateMinerWorker(ctx context.Context, maddr address.Address, ts *types.TipSet) (address.Address, error) { func (mca mca) StateMinerWorker(ctx context.Context, maddr address.Address, ts *types.TipSet) (address.Address, error) {
st, _, err := mca.sm.TipSetState(ts.Cids()) return stmgr.GetMinerWorker(ctx, mca.sm, ts.ParentState(), maddr)
if err != nil {
return address.Undef, err
}
return stmgr.GetMinerWorker(ctx, mca.sm, st, maddr)
} }
func (mca mca) WalletSign(ctx context.Context, a address.Address, v []byte) (*types.Signature, error) { func (mca mca) WalletSign(ctx context.Context, a address.Address, v []byte) (*types.Signature, error) {

View File

@ -20,7 +20,7 @@ import (
) )
func MinerCreateBlock(ctx context.Context, sm *stmgr.StateManager, w *wallet.Wallet, miner address.Address, parents *types.TipSet, tickets []*types.Ticket, proof types.ElectionProof, msgs []*types.SignedMessage, timestamp uint64) (*types.FullBlock, error) { func MinerCreateBlock(ctx context.Context, sm *stmgr.StateManager, w *wallet.Wallet, miner address.Address, parents *types.TipSet, tickets []*types.Ticket, proof types.ElectionProof, msgs []*types.SignedMessage, timestamp uint64) (*types.FullBlock, error) {
st, recpts, err := sm.TipSetState(parents.Cids()) st, recpts, err := sm.TipSetState(parents)
if err != nil { if err != nil {
return nil, errors.Wrap(err, "failed to load tipset state") return nil, errors.Wrap(err, "failed to load tipset state")
} }

View File

@ -53,10 +53,7 @@ func (sm *StateManager) Call(ctx context.Context, msg *types.Message, ts *types.
ts = sm.cs.GetHeaviestTipSet() ts = sm.cs.GetHeaviestTipSet()
} }
state, _, err := sm.TipSetState(ts.Cids()) state := ts.ParentState()
if err != nil {
return nil, xerrors.Errorf("getting tipset state: %w", err)
}
r := vm.NewChainRand(sm.cs, ts.Cids(), ts.Height(), nil) r := vm.NewChainRand(sm.cs, ts.Cids(), ts.Height(), nil)

View File

@ -43,10 +43,10 @@ func cidsToKey(cids []cid.Cid) string {
return out return out
} }
func (sm *StateManager) TipSetState(cids []cid.Cid) (cid.Cid, cid.Cid, error) { func (sm *StateManager) TipSetState(ts *types.TipSet) (cid.Cid, cid.Cid, error) {
ctx := context.TODO() ctx := context.TODO()
ck := cidsToKey(cids) ck := cidsToKey(ts.Cids())
sm.stlk.Lock() sm.stlk.Lock()
cached, ok := sm.stCache[ck] cached, ok := sm.stCache[ck]
sm.stlk.Unlock() sm.stlk.Unlock()
@ -54,11 +54,6 @@ func (sm *StateManager) TipSetState(cids []cid.Cid) (cid.Cid, cid.Cid, error) {
return cached[0], cached[1], nil return cached[0], cached[1], nil
} }
ts, err := sm.cs.LoadTipSet(cids)
if err != nil {
return cid.Undef, cid.Undef, err
}
if ts.Height() == 0 { if ts.Height() == 0 {
// NB: Genesis block is a weird case here... // NB: Genesis block is a weird case here...
return ts.Blocks()[0].ParentStateRoot, ts.Blocks()[0].ParentMessageReceipts, nil return ts.Blocks()[0].ParentStateRoot, ts.Blocks()[0].ParentMessageReceipts, nil
@ -198,10 +193,7 @@ func (sm *StateManager) GetActor(addr address.Address, ts *types.TipSet) (*types
ts = sm.cs.GetHeaviestTipSet() ts = sm.cs.GetHeaviestTipSet()
} }
stcid, _, err := sm.TipSetState(ts.Cids()) stcid := ts.ParentState()
if err != nil {
return nil, xerrors.Errorf("tipset state: %w", err)
}
cst := hamt.CSTFromBstore(sm.cs.Blockstore()) cst := hamt.CSTFromBstore(sm.cs.Blockstore())
state, err := state.LoadStateTree(cst, stcid) state, err := state.LoadStateTree(cst, stcid)

View File

@ -381,7 +381,13 @@ func (syncer *Syncer) validateTickets(ctx context.Context, mworker address.Addre
// Should match up with 'Semantical Validation' in validation.md in the spec // Should match up with 'Semantical Validation' in validation.md in the spec
func (syncer *Syncer) ValidateBlock(ctx context.Context, b *types.FullBlock) error { func (syncer *Syncer) ValidateBlock(ctx context.Context, b *types.FullBlock) error {
h := b.Header h := b.Header
stateroot, precp, err := syncer.sm.TipSetState(h.Parents)
baseTs, err := syncer.store.LoadTipSet(h.Parents)
if err != nil {
return xerrors.Errorf("load tipset failed: %w", err)
}
stateroot, precp, err := syncer.sm.TipSetState(baseTs)
if err != nil { if err != nil {
return xerrors.Errorf("get tipsetstate(%d, %s) failed: %w", h.Height, h.Parents, err) return xerrors.Errorf("get tipsetstate(%d, %s) failed: %w", h.Height, h.Parents, err)
} }
@ -394,11 +400,6 @@ func (syncer *Syncer) ValidateBlock(ctx context.Context, b *types.FullBlock) err
return xerrors.Errorf("parent receipts root did not match computed value (%s != %s)", precp, h.ParentMessageReceipts) return xerrors.Errorf("parent receipts root did not match computed value (%s != %s)", precp, h.ParentMessageReceipts)
} }
baseTs, err := syncer.store.LoadTipSet(h.Parents)
if err != nil {
return xerrors.Errorf("load tipset failed: %w", err)
}
if h.Timestamp > uint64(time.Now().Unix()+build.AllowableClockDrift) { if h.Timestamp > uint64(time.Now().Unix()+build.AllowableClockDrift) {
return xerrors.Errorf("block was from the future") return xerrors.Errorf("block was from the future")
} }

View File

@ -150,6 +150,10 @@ func (ts *TipSet) MinTicketBlock() *BlockHeader {
return min return min
} }
func (ts *TipSet) ParentState() cid.Cid {
return ts.blks[0].ParentStateRoot
}
func (ts *TipSet) Contains(oc cid.Cid) bool { func (ts *TipSet) Contains(oc cid.Cid) bool {
for _, c := range ts.cids { for _, c := range ts.cids {
if c == oc { if c == oc {

View File

@ -134,7 +134,7 @@ func (a *StateAPI) stateForTs(ts *types.TipSet) (*state.StateTree, error) {
ts = a.Chain.GetHeaviestTipSet() ts = a.Chain.GetHeaviestTipSet()
} }
st, _, err := a.StateManager.TipSetState(ts.Cids()) st, _, err := a.StateManager.TipSetState(ts)
if err != nil { if err != nil {
return nil, err return nil, err
} }