38 VP56mv *pmv,
int ref,
int z,
int idx,
int sb)
40 static const int8_t mv_ref_blk_off[
N_BS_SIZES][8][2] = {
41 [
BS_64x64] = { { 3, -1 }, { -1, 3 }, { 4, -1 }, { -1, 4 },
42 { -1, -1 }, { 0, -1 }, { -1, 0 }, { 6, -1 } },
43 [
BS_64x32] = { { 0, -1 }, { -1, 0 }, { 4, -1 }, { -1, 2 },
44 { -1, -1 }, { 0, -3 }, { -3, 0 }, { 2, -1 } },
45 [
BS_32x64] = { { -1, 0 }, { 0, -1 }, { -1, 4 }, { 2, -1 },
46 { -1, -1 }, { -3, 0 }, { 0, -3 }, { -1, 2 } },
47 [
BS_32x32] = { { 1, -1 }, { -1, 1 }, { 2, -1 }, { -1, 2 },
48 { -1, -1 }, { 0, -3 }, { -3, 0 }, { -3, -3 } },
49 [
BS_32x16] = { { 0, -1 }, { -1, 0 }, { 2, -1 }, { -1, -1 },
50 { -1, 1 }, { 0, -3 }, { -3, 0 }, { -3, -3 } },
51 [
BS_16x32] = { { -1, 0 }, { 0, -1 }, { -1, 2 }, { -1, -1 },
52 { 1, -1 }, { -3, 0 }, { 0, -3 }, { -3, -3 } },
53 [
BS_16x16] = { { 0, -1 }, { -1, 0 }, { 1, -1 }, { -1, 1 },
54 { -1, -1 }, { 0, -3 }, { -3, 0 }, { -3, -3 } },
55 [
BS_16x8] = { { 0, -1 }, { -1, 0 }, { 1, -1 }, { -1, -1 },
56 { 0, -2 }, { -2, 0 }, { -2, -1 }, { -1, -2 } },
57 [
BS_8x16] = { { -1, 0 }, { 0, -1 }, { -1, 1 }, { -1, -1 },
58 { -2, 0 }, { 0, -2 }, { -1, -2 }, { -2, -1 } },
59 [
BS_8x8] = { { 0, -1 }, { -1, 0 }, { -1, -1 }, { 0, -2 },
60 { -2, 0 }, { -1, -2 }, { -2, -1 }, { -2, -2 } },
61 [
BS_8x4] = { { 0, -1 }, { -1, 0 }, { -1, -1 }, { 0, -2 },
62 { -2, 0 }, { -1, -2 }, { -2, -1 }, { -2, -2 } },
63 [
BS_4x8] = { { 0, -1 }, { -1, 0 }, { -1, -1 }, { 0, -2 },
64 { -2, 0 }, { -1, -2 }, { -2, -1 }, { -2, -2 } },
65 [
BS_4x4] = { { 0, -1 }, { -1, 0 }, { -1, -1 }, { 0, -2 },
66 { -2, 0 }, { -1, -2 }, { -2, -1 }, { -2, -2 } },
70 int row = td->
row, col = td->
col, row7 = td->
row7;
71 const int8_t (*p)[2] = mv_ref_blk_off[b->
bs];
72 #define INVALID_MV 0x80008000U
76 #define RETURN_DIRECT_MV(mv) \
78 uint32_t m = AV_RN32A(&mv); \
82 } else if (mem == INVALID_MV) { \
84 } else if (m != mem) { \
91 if (sb == 2 || sb == 1) {
99 #define RETURN_MV(mv) \
104 av_assert2(idx == 1); \
105 av_assert2(mem != INVALID_MV); \
106 if (mem_sub8x8 == INVALID_MV) { \
107 clamp_mv(&tmp, &mv, td); \
108 m = AV_RN32A(&tmp); \
113 mem_sub8x8 = AV_RN32A(&mv); \
114 } else if (mem_sub8x8 != AV_RN32A(&mv)) { \
115 clamp_mv(&tmp, &mv, td); \
116 m = AV_RN32A(&tmp); \
126 uint32_t m = AV_RN32A(&mv); \
128 clamp_mv(pmv, &mv, td); \
130 } else if (mem == INVALID_MV) { \
132 } else if (m != mem) { \
133 clamp_mv(pmv, &mv, td); \
141 if (mv->
ref[0] == ref)
143 else if (mv->
ref[1] == ref)
148 if (mv->
ref[0] == ref)
150 else if (mv->
ref[1] == ref)
160 int c = p[i][0] + col,
r = p[i][1] + row;
163 r >= 0 && r < s->rows) {
166 if (mv->
ref[0] == ref)
168 else if (mv->
ref[1] == ref)
179 if (mv->
ref[0] == ref)
181 else if (mv->
ref[1] == ref)
185 #define RETURN_SCALE_MV(mv, scale) \
188 VP56mv mv_temp = { -mv.x, -mv.y }; \
189 RETURN_MV(mv_temp); \
196 for (i = 0; i < 8; i++) {
197 int c = p[i][0] + col,
r = p[i][1] + row;
199 if (c >= td->
tile_col_start && c < s->cols && r >= 0 && r < s->rows) {
202 if (mv->
ref[0] != ref && mv->
ref[0] >= 0)
205 if (mv->
ref[1] != ref && mv->
ref[1] >= 0 &&
219 if (mv->
ref[0] != ref && mv->
ref[0] >= 0)
221 if (mv->
ref[1] != ref && mv->
ref[1] >= 0 &&
233 #undef RETURN_SCALE_MV
248 for (n = 0, m = 0; m <
c; m++) {
275 n = (n << 3) | (bit << 1);
288 return sign ? -(n + 1) : (n + 1);
303 mode ==
NEWMV ? -1 : sb);
305 if ((mode ==
NEWMV || sb == -1) &&
307 abs(mv[0].x) < 64 && abs(mv[0].y) < 64)) {
335 mode ==
NEWMV ? -1 : sb);
336 if ((mode ==
NEWMV || sb == -1) &&
338 abs(mv[1].x) < 64 && abs(mv[1].y) < 64)) {
const int8_t ff_vp9_mv_joint_tree[3][2]
static av_always_inline int read_mv_component(VP9TileData *td, int idx, int hp)
VP5 and VP6 compatible video decoder (common features)
static av_always_inline int vp8_rac_get_tree(VP56RangeCoder *c, const int8_t(*tree)[2], const uint8_t *probs)
void ff_thread_await_progress(ThreadFrame *f, int n, int field)
Wait for earlier decoding threads to finish reference pictures.
const int8_t ff_vp9_mv_class_tree[10][2]
static void find_ref_mvs(VP9TileData *td, VP56mv *pmv, int ref, int z, int idx, int sb)
struct VP9TileData::@183::@185 mv_comp[2]
static av_always_inline void clamp_mv(VP56mv *dst, const VP56mv *src, VP9TileData *td)
struct ProbContext::@179 mv_comp[2]
const int8_t ff_vp9_mv_fp_tree[3][2]
#define vp56_rac_get_prob
#define RETURN_SCALE_MV(mv, scale)
static const int8_t mv[256][2]
VP56mv(* above_mv_ctx)[2]
struct VP9TileData::@183 counts
struct VP9Context::@182 prob
common internal api header.
static int ref[MAX_W *MAX_W]
struct VP9TileData::@184 min_mv
#define RETURN_DIRECT_MV(mv)
struct VP9TileData::@184 max_mv
void ff_vp9_fill_mv(VP9TileData *td, VP56mv *mv, int mode, int sb)
VP56mv left_mv_ctx[16][2]
mode
Use these values in ebur128_init (or'ed).