Merge branch 'public-single-node' into victorialogs-wip

This commit is contained in:
Aliaksandr Valialkin 2024-05-14 01:41:28 +02:00
commit 5c4679ba01
No known key found for this signature in database
GPG key ID: 52C003EE2BCDB9EB
5 changed files with 19 additions and 16 deletions

View file

@ -517,11 +517,12 @@ func UnmarshalBytes(src []byte) ([]byte, int) {
if nSize <= 0 { if nSize <= 0 {
return nil, 0 return nil, 0
} }
src = src[nSize:] if uint64(nSize)+n > uint64(len(src)) {
if uint64(len(src)) < n {
return nil, 0 return nil, 0
} }
return src[:n], nSize + int(n) start := nSize
nSize += int(n)
return src[start:nSize], nSize
} }
// GetInt64s returns an int64 slice with the given size. // GetInt64s returns an int64 slice with the given size.

View file

@ -87,7 +87,7 @@ func (bh *blockHeader) unmarshal(src []byte) ([]byte, error) {
// unmarshal bh.uncompressedSizeBytes // unmarshal bh.uncompressedSizeBytes
n, nSize := encoding.UnmarshalVarUint64(src) n, nSize := encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return srcOrig, fmt.Errorf("cannot unmarshal uncompressedSizeBytes from uvarint") return srcOrig, fmt.Errorf("cannot unmarshal uncompressedSizeBytes")
} }
src = src[nSize:] src = src[nSize:]
bh.uncompressedSizeBytes = n bh.uncompressedSizeBytes = n
@ -95,7 +95,7 @@ func (bh *blockHeader) unmarshal(src []byte) ([]byte, error) {
// unmarshal bh.rowsCount // unmarshal bh.rowsCount
n, nSize = encoding.UnmarshalVarUint64(src) n, nSize = encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return srcOrig, fmt.Errorf("cannot unmarshal rowsCount from uvarint") return srcOrig, fmt.Errorf("cannot unmarshal rowsCount")
} }
src = src[nSize:] src = src[nSize:]
if n > maxRowsPerBlock { if n > maxRowsPerBlock {
@ -113,7 +113,7 @@ func (bh *blockHeader) unmarshal(src []byte) ([]byte, error) {
// unmarshal columnsHeaderOffset // unmarshal columnsHeaderOffset
n, nSize = encoding.UnmarshalVarUint64(src) n, nSize = encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return srcOrig, fmt.Errorf("cannot unmarshal columnsHeaderOffset from uvarint") return srcOrig, fmt.Errorf("cannot unmarshal columnsHeaderOffset")
} }
src = src[nSize:] src = src[nSize:]
bh.columnsHeaderOffset = n bh.columnsHeaderOffset = n
@ -121,7 +121,7 @@ func (bh *blockHeader) unmarshal(src []byte) ([]byte, error) {
// unmarshal columnsHeaderSize // unmarshal columnsHeaderSize
n, nSize = encoding.UnmarshalVarUint64(src) n, nSize = encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return srcOrig, fmt.Errorf("cannot unmarshal columnsHeaderSize from uvarint") return srcOrig, fmt.Errorf("cannot unmarshal columnsHeaderSize")
} }
src = src[nSize:] src = src[nSize:]
if n > maxColumnsHeaderSize { if n > maxColumnsHeaderSize {
@ -298,12 +298,13 @@ func (csh *columnsHeader) unmarshal(a *arena, src []byte) error {
// unmarshal columnHeaders // unmarshal columnHeaders
n, nSize := encoding.UnmarshalVarUint64(src) n, nSize := encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return fmt.Errorf("cannot unmarshal columnHeaders len from uvarint") return fmt.Errorf("cannot unmarshal columnHeaders len")
} }
src = src[nSize:] src = src[nSize:]
if n > maxColumnsPerBlock { if n > maxColumnsPerBlock {
return fmt.Errorf("too many column headers: %d; mustn't exceed %d", n, maxColumnsPerBlock) return fmt.Errorf("too many column headers: %d; mustn't exceed %d", n, maxColumnsPerBlock)
} }
chs := csh.resizeColumnHeaders(int(n)) chs := csh.resizeColumnHeaders(int(n))
for i := range chs { for i := range chs {
tail, err := chs[i].unmarshal(a, src) tail, err := chs[i].unmarshal(a, src)
@ -317,12 +318,13 @@ func (csh *columnsHeader) unmarshal(a *arena, src []byte) error {
// unmarshal constColumns // unmarshal constColumns
n, nSize = encoding.UnmarshalVarUint64(src) n, nSize = encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return fmt.Errorf("cannot unmarshal constColumns len from uvarint") return fmt.Errorf("cannot unmarshal constColumns len")
} }
src = src[nSize:] src = src[nSize:]
if n+uint64(len(csh.columnHeaders)) > maxColumnsPerBlock { if n+uint64(len(csh.columnHeaders)) > maxColumnsPerBlock {
return fmt.Errorf("too many columns: %d; mustn't exceed %d", n+uint64(len(csh.columnHeaders)), maxColumnsPerBlock) return fmt.Errorf("too many columns: %d; mustn't exceed %d", n+uint64(len(csh.columnHeaders)), maxColumnsPerBlock)
} }
ccs := csh.resizeConstColumns(int(n)) ccs := csh.resizeConstColumns(int(n))
for i := range ccs { for i := range ccs {
tail, err := ccs[i].unmarshal(a, src) tail, err := ccs[i].unmarshal(a, src)
@ -661,14 +663,14 @@ func (ch *columnHeader) unmarshalValues(src []byte) ([]byte, error) {
n, nSize := encoding.UnmarshalVarUint64(src) n, nSize := encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return srcOrig, fmt.Errorf("cannot unmarshal valuesOffset from uvarint") return srcOrig, fmt.Errorf("cannot unmarshal valuesOffset")
} }
src = src[nSize:] src = src[nSize:]
ch.valuesOffset = n ch.valuesOffset = n
n, nSize = encoding.UnmarshalVarUint64(src) n, nSize = encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return srcOrig, fmt.Errorf("cannot unmarshal valuesSize from uvarint") return srcOrig, fmt.Errorf("cannot unmarshal valuesSize")
} }
src = src[nSize:] src = src[nSize:]
if n > maxValuesBlockSize { if n > maxValuesBlockSize {
@ -684,14 +686,14 @@ func (ch *columnHeader) unmarshalBloomFilters(src []byte) ([]byte, error) {
n, nSize := encoding.UnmarshalVarUint64(src) n, nSize := encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return srcOrig, fmt.Errorf("cannot unmarshal bloomFilterOffset from uvarint") return srcOrig, fmt.Errorf("cannot unmarshal bloomFilterOffset")
} }
src = src[nSize:] src = src[nSize:]
ch.bloomFilterOffset = n ch.bloomFilterOffset = n
n, nSize = encoding.UnmarshalVarUint64(src) n, nSize = encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return srcOrig, fmt.Errorf("cannot unmarshal bloomFilterSize from uvarint") return srcOrig, fmt.Errorf("cannot unmarshal bloomFilterSize")
} }
src = src[nSize:] src = src[nSize:]
if n > maxBloomFilterBlockSize { if n > maxBloomFilterBlockSize {

View file

@ -281,7 +281,7 @@ func unmarshalBytesBlock(dst, src []byte) ([]byte, []byte, error) {
// Read block length // Read block length
blockLen, nSize := encoding.UnmarshalVarUint64(src) blockLen, nSize := encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return dst, src, fmt.Errorf("cannot unmarshal compressed block size from uvarint") return dst, src, fmt.Errorf("cannot unmarshal compressed block size")
} }
src = src[nSize:] src = src[nSize:]
if uint64(len(src)) < blockLen { if uint64(len(src)) < blockLen {

View file

@ -509,7 +509,7 @@ func (idb *indexdb) loadStreamIDsFromCache(tenantIDs []TenantID, sf *StreamFilte
// Cache hit - unpack streamIDs from data. // Cache hit - unpack streamIDs from data.
n, nSize := encoding.UnmarshalVarUint64(data) n, nSize := encoding.UnmarshalVarUint64(data)
if nSize <= 0 { if nSize <= 0 {
logger.Panicf("BUG: cannot unmarshal the number of streamIDs from cache") logger.Panicf("BUG: unexpected error when unmarshaling the number of streamIDs from cache")
} }
src := data[nSize:] src := data[nSize:]
streamIDs := make([]streamID, n) streamIDs := make([]streamID, n)

View file

@ -121,7 +121,7 @@ func (st *StreamTags) UnmarshalCanonical(src []byte) ([]byte, error) {
n, nSize := encoding.UnmarshalVarUint64(src) n, nSize := encoding.UnmarshalVarUint64(src)
if nSize <= 0 { if nSize <= 0 {
return srcOrig, fmt.Errorf("cannot unmarshal tags len from uvarint") return srcOrig, fmt.Errorf("cannot unmarshal tags len")
} }
src = src[nSize:] src = src[nSize:]
for i := uint64(0); i < n; i++ { for i := uint64(0); i < n; i++ {