Merge pull request #1035 from filecoin-project/fix/rle-count

Verify RLE+ counts
This commit is contained in:
Łukasz Magiera 2020-01-08 18:41:06 +01:00 committed by GitHub
commit 5a12d60c6f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -24,6 +24,7 @@ import (
) )
const MaxSectors = 1 << 48 const MaxSectors = 1 << 48
const RLEMax = 100e3
type StorageMinerActor struct{} type StorageMinerActor struct{}
@ -576,6 +577,17 @@ func (sma StorageMinerActor) SubmitFallbackPoSt(act *types.Actor, vmctx types.VM
return nil, aerrors.HandleExternalError(lerr, "could not load proving set node") return nil, aerrors.HandleExternalError(lerr, "could not load proving set node")
} }
{
c, nerr := self.FaultSet.Count()
if nerr != nil {
return nil, aerrors.Absorb(nerr, 6, "invalid bitfield")
}
if c > RLEMax {
return nil, aerrors.Newf(7, "too many items in bitfield: %d", c)
}
}
faults, nerr := self.FaultSet.AllMap() faults, nerr := self.FaultSet.AllMap()
if nerr != nil { if nerr != nil {
return nil, aerrors.Absorb(err, 5, "RLE+ invalid") return nil, aerrors.Absorb(err, 5, "RLE+ invalid")
@ -1147,6 +1159,16 @@ func onSuccessfulPoStV1(self *StorageMinerActorState, vmctx types.VMContext) aer
return aerrors.HandleExternalError(nerr, "failed to load proving set") return aerrors.HandleExternalError(nerr, "failed to load proving set")
} }
{
c, nerr := self.FaultSet.Count()
if nerr != nil {
return aerrors.Absorb(nerr, 2, "invalid bitfield")
}
if c > RLEMax {
return aerrors.Newf(3, "too many items in bitfield: %d", c)
}
}
faults, nerr := self.FaultSet.All() faults, nerr := self.FaultSet.All()
if nerr != nil { if nerr != nil {
return aerrors.Absorb(nerr, 1, "invalid bitfield (fatal?)") return aerrors.Absorb(nerr, 1, "invalid bitfield (fatal?)")