Patch for concurrent iterator & others (onto v1.11.6) #386
@ -318,30 +318,35 @@ func (f *Freezer) Sync() error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// validate checks that every table has the same length.
|
// validate checks that every table has the same boundary.
|
||||||
// Used instead of `repair` in readonly mode.
|
// Used instead of `repair` in readonly mode.
|
||||||
func (f *Freezer) validate() error {
|
func (f *Freezer) validate() error {
|
||||||
if len(f.tables) == 0 {
|
if len(f.tables) == 0 {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
var (
|
var (
|
||||||
length uint64
|
head uint64
|
||||||
|
tail uint64
|
||||||
name string
|
name string
|
||||||
)
|
)
|
||||||
// Hack to get length of any table
|
// Hack to get boundary of any table
|
||||||
for kind, table := range f.tables {
|
for kind, table := range f.tables {
|
||||||
length = atomic.LoadUint64(&table.items)
|
head = atomic.LoadUint64(&table.items)
|
||||||
|
tail = atomic.LoadUint64(&table.itemHidden)
|
||||||
name = kind
|
name = kind
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
// Now check every table against that length
|
// Now check every table against those boundaries.
|
||||||
for kind, table := range f.tables {
|
for kind, table := range f.tables {
|
||||||
items := atomic.LoadUint64(&table.items)
|
if head != atomic.LoadUint64(&table.items) {
|
||||||
if length != items {
|
return fmt.Errorf("freezer tables %s and %s have differing head: %d != %d", kind, name, atomic.LoadUint64(&table.items), head)
|
||||||
return fmt.Errorf("freezer tables %s and %s have differing lengths: %d != %d", kind, name, items, length)
|
}
|
||||||
|
if tail != atomic.LoadUint64(&table.itemHidden) {
|
||||||
|
return fmt.Errorf("freezer tables %s and %s have differing tail: %d != %d", kind, name, atomic.LoadUint64(&table.itemHidden), tail)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
atomic.StoreUint64(&f.frozen, length)
|
atomic.StoreUint64(&f.frozen, head)
|
||||||
|
atomic.StoreUint64(&f.tail, tail)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user