Skip to content

Commit

Permalink
make user tipst Do NOT include more than one blocks mined by a miner
Browse files Browse the repository at this point in the history
  • Loading branch information
zl03jsj committed Feb 28, 2022
1 parent 4044c8f commit 5016051
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 0 deletions.
63 changes: 63 additions & 0 deletions pkg/chainsync/types/target_tracker.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,10 @@ package types

import (
"container/list"
"github.com/filecoin-project/go-address"
"github.com/filecoin-project/go-state-types/abi"
"github.com/filecoin-project/venus/venus-shared/actors/builtin"
"github.com/filecoin-project/venus/venus-shared/actors/policy"
"sort"
"strconv"
"sync"
Expand Down Expand Up @@ -81,6 +85,8 @@ type TargetTracker struct {

subs map[string]chan struct{}
subLk sync.Mutex

tipsetCache map[abi.ChainEpoch][]*types.BlockHeader
}

// NewTargetTracker returns a new target queue.
Expand All @@ -94,6 +100,7 @@ func NewTargetTracker(size int) *TargetTracker {
lk: sync.Mutex{},
lowWeight: fbig.NewInt(0),
subs: make(map[string]chan struct{}),
tipsetCache: make(map[abi.ChainEpoch][]*types.BlockHeader),
}
}

Expand Down Expand Up @@ -127,6 +134,47 @@ func (tq *TargetTracker) pubNewTarget() {
}
}

func (tq *TargetTracker) checkBlock(block *types.BlockHeader) bool {
bls, exists := tq.tipsetCache[block.Height]
if !exists {
cache := make([]*types.BlockHeader, 0, builtin.ExpectedLeadersPerEpoch)
tq.tipsetCache[block.Height] = append(cache, block)
return true
}

for _, b := range bls {
if b.Cid() == block.Cid() {
log.Warnf("block(%s) already in tipset:%d", b.Cid().String(), b.Height)
return true
}
if b.Miner == block.Miner {
log.Warnf("miner:%d packed more than none block in single tipset:%d, it's illegle.", b.Miner.String(), b.Height)
return false
}
}

tq.tipsetCache[block.Height] = append(bls, block)

return true
}

func (tq *TargetTracker) checkTipset(target *Target) (*Target, error) {
bls := target.Head.Blocks()
var newBls []*types.BlockHeader

for _, b := range bls {
if tq.checkBlock(b) {
newBls = append(newBls, b)
}
}
var err error
target.Head, err = types.NewTipSet(newBls)

delete(tq.tipsetCache, target.Head.Height()-policy.ChainFinality)

return target, err
}

// Add adds a sync target to the target queue.
// First, check whether the weight is received or not, and the message will record the minimum weight.
// If the weight is less than the current weight, it will exit automatically.
Expand All @@ -143,11 +191,18 @@ func (tq *TargetTracker) Add(t *Target) bool {

tq.lk.Lock()
defer tq.lk.Unlock()

//do not sync less weight
if t.Head.At(0).ParentWeight.LessThan(tq.lowWeight) {
return false
}

var err error
if t, err = tq.checkTipset(t); err != nil {
log.Errorf("targettracker add failed, check tipsit failed:%s", err.Error())
return false
}

t, ok := tq.widen(t)
if !ok {
return false
Expand Down Expand Up @@ -258,6 +313,8 @@ func (tq *TargetTracker) widen(t *Target) (*Target, bool) {
}
}

miners := make(map[address.Address]interface{})

//collect neighbor block in queue include history to get block with same weight and height
sameWeightBlks := make(map[cid.Cid]*types.BlockHeader)
for _, val := range tq.targetSet {
Expand All @@ -266,7 +323,13 @@ func (tq *TargetTracker) widen(t *Target) (*Target, bool) {
bid := blk.Cid()
if !t.Head.Key().Has(bid) {
if _, ok := sameWeightBlks[bid]; !ok {
if _, isok := miners[blk.Miner]; isok {
// TODO: a miner mined more than one blocks ?
log.Warnf("miner : %s mined more than one blocks, this is illegal", blk.Miner.String())
return nil, false
}
sameWeightBlks[bid] = blk
miners[blk.Miner] = nil
}
}
}
Expand Down
4 changes: 4 additions & 0 deletions pkg/consensus/block_validator.go
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,8 @@ type BlockValidator struct {
validateBlockCache *lru.ARCCache

Stmgr StateTransformer

tsCaches map[abi.ChainEpoch][]cid.Cid
}

//NewBlockValidator create a new block validator
Expand Down Expand Up @@ -121,6 +123,8 @@ func (bv *BlockValidator) ValidateBlockMsg(ctx context.Context, blk *types.Block
logExpect.Debugw("block validation header", "Cid", blk.Cid(), "took", time.Since(validationStart), "height", blk.Header.Height, "age", time.Since(time.Unix(int64(blk.Header.Timestamp), 0)))
}()



return bv.validateBlockMsg(ctx, blk)
}

Expand Down

0 comments on commit 5016051

Please sign in to comment.