*
* [block][gap][block]
**/
-static void SBBInit(StreamingBuffer *sb,
- uint32_t rel_offset, uint32_t data_len)
+static int WARN_UNUSED SBBInit(StreamingBuffer *sb, uint32_t rel_offset, uint32_t data_len)
{
DEBUG_VALIDATE_BUG_ON(!RB_EMPTY(&sb->sbb_tree));
DEBUG_VALIDATE_BUG_ON(sb->buf_offset > sb->stream_offset + rel_offset);
/* need to set up 2: existing data block and new data block */
StreamingBufferBlock *sbb = CALLOC(sb->cfg, 1, sizeof(*sbb));
if (sbb == NULL) {
- return;
+ return -1;
}
sbb->offset = sb->stream_offset;
sbb->len = sb->buf_offset;
StreamingBufferBlock *sbb2 = CALLOC(sb->cfg, 1, sizeof(*sbb2));
if (sbb2 == NULL) {
FREE(sb->cfg, sbb, sizeof(*sbb));
- return;
+ return -1;
}
sbb2->offset = sb->stream_offset + rel_offset;
sbb2->len = data_len;
SBBPrintList(sb);
#endif
BUG_ON(sbb2->offset < sbb->len);
+ return 0;
}
/* setup with leading gap
*
* [gap][block]
**/
-static void SBBInitLeadingGap(StreamingBuffer *sb,
- uint64_t offset, uint32_t data_len)
+static int WARN_UNUSED SBBInitLeadingGap(StreamingBuffer *sb, uint64_t offset, uint32_t data_len)
{
DEBUG_VALIDATE_BUG_ON(!RB_EMPTY(&sb->sbb_tree));
StreamingBufferBlock *sbb = CALLOC(sb->cfg, 1, sizeof(*sbb));
if (sbb == NULL)
- return;
+ return -1;
sbb->offset = offset;
sbb->len = data_len;
#ifdef DEBUG
SBBPrintList(sb);
#endif
+ return 0;
}
static inline void ConsolidateFwd(StreamingBuffer *sb,
return 0;
}
-static void SBBUpdate(StreamingBuffer *sb,
- uint32_t rel_offset, uint32_t data_len)
+static int SBBUpdate(StreamingBuffer *sb, uint32_t rel_offset, uint32_t data_len)
{
- Insert(sb, &sb->sbb_tree, rel_offset, data_len);
+ return Insert(sb, &sb->sbb_tree, rel_offset, data_len);
}
static void SBBFree(StreamingBuffer *sb)
sb->buf_offset += data_len;
if (!RB_EMPTY(&sb->sbb_tree)) {
- SBBUpdate(sb, rel_offset, data_len);
+ return SBBUpdate(sb, rel_offset, data_len);
+ } else {
+ return 0;
}
- return 0;
}
/**
sb->buf_offset += data_len;
if (!RB_EMPTY(&sb->sbb_tree)) {
- SBBUpdate(sb, rel_offset, data_len);
+ return SBBUpdate(sb, rel_offset, data_len);
+ } else {
+ return 0;
}
- return 0;
}
#define DATA_FITS_AT_OFFSET(sb, len, offset) \
// nothing to do
} else if (sb->buf_offset) {
/* existing data, but there is a gap between us */
- SBBInit(sb, rel_offset, data_len);
+ if (SBBInit(sb, rel_offset, data_len) < 0)
+ return -1;
} else {
/* gap before data in empty list */
SCLogDebug("empty sbb list: invoking SBBInitLeadingGap");
- SBBInitLeadingGap(sb, offset, data_len);
+ if (SBBInitLeadingGap(sb, offset, data_len) < 0)
+ return -1;
}
}
} else {
/* already have blocks, so append new block based on new data */
- SBBUpdate(sb, rel_offset, data_len);
+ if (SBBUpdate(sb, rel_offset, data_len) < 0)
+ return -1;
}
if (rel_offset + data_len > sb->buf_offset)