ref: c38b3923bbb14fcdf00f6fa31104bf57d27150b3
parent: 1f32abd286557fc2fb1bee3dbf31c2dcce337c17
author: Janne Grunau <[email protected]>
date: Wed Oct 17 14:07:18 EDT 2018
decode: allow returning an error from decode_b and pass it on
--- a/src/decode.c
+++ b/src/decode.c
@@ -666,11 +666,11 @@
return seg_id;
}
-static void decode_b(Dav1dTileContext *const t,
- const enum BlockLevel bl,
- const enum BlockSize bs,
- const enum BlockPartition bp,
- const enum EdgeFlags intra_edge_flags)
+static int decode_b(Dav1dTileContext *const t,
+ const enum BlockLevel bl,
+ const enum BlockSize bs,
+ const enum BlockPartition bp,
+ const enum EdgeFlags intra_edge_flags)
{
Dav1dTileState *const ts = t->ts;
const Dav1dFrameContext *const f = t->f;
@@ -723,7 +723,7 @@
}
memset(&t->l.intra[by4], b->intra, bh4);
memset(&t->a->intra[bx4], b->intra, bw4);
- return;
+ return 0;
}
const int cw4 = (w4 + ss_hor) >> ss_hor, ch4 = (h4 + ss_ver) >> ss_ver;
@@ -1762,6 +1762,8 @@
for (int y = 0; y < bh4; y++)
*noskip_mask++ |= mask;
}
+
+ return 0;
}
static int decode_sb(Dav1dTileContext *const t, const enum BlockLevel bl,
@@ -1813,18 +1815,23 @@
switch (bp) {
case PARTITION_NONE:
- decode_b(t, bl, b[0], PARTITION_NONE, node->o);
+ if (decode_b(t, bl, b[0], PARTITION_NONE, node->o))
+ return -1;
break;
case PARTITION_H:
- decode_b(t, bl, b[0], PARTITION_H, node->h[0]);
+ if (decode_b(t, bl, b[0], PARTITION_H, node->h[0]))
+ return -1;
t->by += hsz;
- decode_b(t, bl, b[0], PARTITION_H, node->h[1]);
+ if (decode_b(t, bl, b[0], PARTITION_H, node->h[1]))
+ return -1;
t->by -= hsz;
break;
case PARTITION_V:
- decode_b(t, bl, b[0], PARTITION_V, node->v[0]);
+ if (decode_b(t, bl, b[0], PARTITION_V, node->v[0]))
+ return -1;
t->bx += hsz;
- decode_b(t, bl, b[0], PARTITION_V, node->v[1]);
+ if (decode_b(t, bl, b[0], PARTITION_V, node->v[1]))
+ return -1;
t->bx -= hsz;
break;
case PARTITION_SPLIT:
@@ -1831,28 +1838,36 @@
if (bl == BL_8X8) {
const EdgeTip *const tip = (const EdgeTip *) node;
assert(hsz == 1);
- decode_b(t, bl, BS_4x4, PARTITION_SPLIT, tip->split[0]);
+ if (decode_b(t, bl, BS_4x4, PARTITION_SPLIT, tip->split[0]))
+ return -1;
const enum Filter2d tl_filter = t->tl_4x4_filter;
t->bx++;
- decode_b(t, bl, BS_4x4, PARTITION_SPLIT, tip->split[1]);
+ if (decode_b(t, bl, BS_4x4, PARTITION_SPLIT, tip->split[1]))
+ return -1;
t->bx--;
t->by++;
- decode_b(t, bl, BS_4x4, PARTITION_SPLIT, tip->split[2]);
+ if (decode_b(t, bl, BS_4x4, PARTITION_SPLIT, tip->split[2]))
+ return -1;
t->bx++;
t->tl_4x4_filter = tl_filter;
- decode_b(t, bl, BS_4x4, PARTITION_SPLIT, tip->split[3]);
+ if (decode_b(t, bl, BS_4x4, PARTITION_SPLIT, tip->split[3]))
+ return -1;
t->bx--;
t->by--;
} else {
const EdgeBranch *const branch = (const EdgeBranch *) node;
- if (decode_sb(t, bl + 1, branch->split[0])) return 1;
+ if (decode_sb(t, bl + 1, branch->split[0]))
+ return 1;
t->bx += hsz;
- if (decode_sb(t, bl + 1, branch->split[1])) return 1;
+ if (decode_sb(t, bl + 1, branch->split[1]))
+ return 1;
t->bx -= hsz;
t->by += hsz;
- if (decode_sb(t, bl + 1, branch->split[2])) return 1;
+ if (decode_sb(t, bl + 1, branch->split[2]))
+ return 1;
t->bx += hsz;
- if (decode_sb(t, bl + 1, branch->split[3])) return 1;
+ if (decode_sb(t, bl + 1, branch->split[3]))
+ return 1;
t->bx -= hsz;
t->by -= hsz;
}
@@ -1859,22 +1874,28 @@
break;
case PARTITION_T_TOP_SPLIT: {
const EdgeBranch *const branch = (const EdgeBranch *) node;
- decode_b(t, bl, b[0], PARTITION_T_TOP_SPLIT, branch->tts[0]);
+ if (decode_b(t, bl, b[0], PARTITION_T_TOP_SPLIT, branch->tts[0]))
+ return -1;
t->bx += hsz;
- decode_b(t, bl, b[0], PARTITION_T_TOP_SPLIT, branch->tts[1]);
+ if (decode_b(t, bl, b[0], PARTITION_T_TOP_SPLIT, branch->tts[1]))
+ return -1;
t->bx -= hsz;
t->by += hsz;
- decode_b(t, bl, b[1], PARTITION_T_TOP_SPLIT, branch->tts[2]);
+ if (decode_b(t, bl, b[1], PARTITION_T_TOP_SPLIT, branch->tts[2]))
+ return -1;
t->by -= hsz;
break;
}
case PARTITION_T_BOTTOM_SPLIT: {
const EdgeBranch *const branch = (const EdgeBranch *) node;
- decode_b(t, bl, b[0], PARTITION_T_BOTTOM_SPLIT, branch->tbs[0]);
+ if (decode_b(t, bl, b[0], PARTITION_T_BOTTOM_SPLIT, branch->tbs[0]))
+ return -1;
t->by += hsz;
- decode_b(t, bl, b[1], PARTITION_T_BOTTOM_SPLIT, branch->tbs[1]);
+ if (decode_b(t, bl, b[1], PARTITION_T_BOTTOM_SPLIT, branch->tbs[1]))
+ return -1;
t->bx += hsz;
- decode_b(t, bl, b[1], PARTITION_T_BOTTOM_SPLIT, branch->tbs[2]);
+ if (decode_b(t, bl, b[1], PARTITION_T_BOTTOM_SPLIT, branch->tbs[2]))
+ return -1;
t->bx -= hsz;
t->by -= hsz;
break;
@@ -1881,22 +1902,28 @@
}
case PARTITION_T_LEFT_SPLIT: {
const EdgeBranch *const branch = (const EdgeBranch *) node;
- decode_b(t, bl, b[0], PARTITION_T_LEFT_SPLIT, branch->tls[0]);
+ if (decode_b(t, bl, b[0], PARTITION_T_LEFT_SPLIT, branch->tls[0]))
+ return -1;
t->by += hsz;
- decode_b(t, bl, b[0], PARTITION_T_LEFT_SPLIT, branch->tls[1]);
+ if (decode_b(t, bl, b[0], PARTITION_T_LEFT_SPLIT, branch->tls[1]))
+ return -1;
t->by -= hsz;
t->bx += hsz;
- decode_b(t, bl, b[1], PARTITION_T_LEFT_SPLIT, branch->tls[2]);
+ if (decode_b(t, bl, b[1], PARTITION_T_LEFT_SPLIT, branch->tls[2]))
+ return -1;
t->bx -= hsz;
break;
}
case PARTITION_T_RIGHT_SPLIT: {
const EdgeBranch *const branch = (const EdgeBranch *) node;
- decode_b(t, bl, b[0], PARTITION_T_RIGHT_SPLIT, branch->trs[0]);
+ if (decode_b(t, bl, b[0], PARTITION_T_RIGHT_SPLIT, branch->trs[0]))
+ return -1;
t->bx += hsz;
- decode_b(t, bl, b[1], PARTITION_T_RIGHT_SPLIT, branch->trs[1]);
+ if (decode_b(t, bl, b[1], PARTITION_T_RIGHT_SPLIT, branch->trs[1]))
+ return -1;
t->by += hsz;
- decode_b(t, bl, b[1], PARTITION_T_RIGHT_SPLIT, branch->trs[2]);
+ if (decode_b(t, bl, b[1], PARTITION_T_RIGHT_SPLIT, branch->trs[2]))
+ return -1;
t->by -= hsz;
t->bx -= hsz;
break;
@@ -1903,27 +1930,35 @@
}
case PARTITION_H4: {
const EdgeBranch *const branch = (const EdgeBranch *) node;
- decode_b(t, bl, b[0], PARTITION_H4, branch->h4[0]);
+ if (decode_b(t, bl, b[0], PARTITION_H4, branch->h4[0]))
+ return -1;
t->by += hsz >> 1;
- decode_b(t, bl, b[0], PARTITION_H4, branch->h4[1]);
+ if (decode_b(t, bl, b[0], PARTITION_H4, branch->h4[1]))
+ return -1;
t->by += hsz >> 1;
- decode_b(t, bl, b[0], PARTITION_H4, branch->h4[2]);
+ if (decode_b(t, bl, b[0], PARTITION_H4, branch->h4[2]))
+ return -1;
t->by += hsz >> 1;
if (t->by < f->bh)
- decode_b(t, bl, b[0], PARTITION_H4, branch->h4[3]);
+ if (decode_b(t, bl, b[0], PARTITION_H4, branch->h4[3]))
+ return -1;
t->by -= hsz * 3 >> 1;
break;
}
case PARTITION_V4: {
const EdgeBranch *const branch = (const EdgeBranch *) node;
- decode_b(t, bl, b[0], PARTITION_V4, branch->v4[0]);
+ if (decode_b(t, bl, b[0], PARTITION_V4, branch->v4[0]))
+ return -1;
t->bx += hsz >> 1;
- decode_b(t, bl, b[0], PARTITION_V4, branch->v4[1]);
+ if (decode_b(t, bl, b[0], PARTITION_V4, branch->v4[1]))
+ return -1;
t->bx += hsz >> 1;
- decode_b(t, bl, b[0], PARTITION_V4, branch->v4[2]);
+ if (decode_b(t, bl, b[0], PARTITION_V4, branch->v4[2]))
+ return -1;
t->bx += hsz >> 1;
if (t->bx < f->bw)
- decode_b(t, bl, b[0], PARTITION_V4, branch->v4[3]);
+ if (decode_b(t, bl, b[0], PARTITION_V4, branch->v4[3]))
+ return -1;
t->bx -= hsz * 3 >> 1;
break;
}
@@ -1953,8 +1988,9 @@
t->bx -= hsz;
} else {
bp = PARTITION_H;
- decode_b(t, bl, dav1d_block_sizes[bl][PARTITION_H][0], PARTITION_H,
- node->h[0]);
+ if (decode_b(t, bl, dav1d_block_sizes[bl][PARTITION_H][0],
+ PARTITION_H, node->h[0]))
+ return -1;
}
} else {
assert(have_v_split);
@@ -1983,8 +2019,9 @@
t->by -= hsz;
} else {
bp = PARTITION_V;
- decode_b(t, bl, dav1d_block_sizes[bl][PARTITION_V][0], PARTITION_V,
- node->v[0]);
+ if (decode_b(t, bl, dav1d_block_sizes[bl][PARTITION_V][0],
+ PARTITION_V, node->v[0]))
+ return -1;
}
}