1cabdff1aSopenharmony_ci/*
2cabdff1aSopenharmony_ci * copyright (c) 2002-2004 Michael Niedermayer <michaelni@gmx.at>
3cabdff1aSopenharmony_ci * copyright (c) 2004 Maarten Daniels
4cabdff1aSopenharmony_ci *
5cabdff1aSopenharmony_ci * This file is part of FFmpeg.
6cabdff1aSopenharmony_ci *
7cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or
8cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public
9cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either
10cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version.
11cabdff1aSopenharmony_ci *
12cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful,
13cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of
14cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15cabdff1aSopenharmony_ci * Lesser General Public License for more details.
16cabdff1aSopenharmony_ci *
17cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public
18cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software
19cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20cabdff1aSopenharmony_ci */
21cabdff1aSopenharmony_ci
22cabdff1aSopenharmony_ci/**
23cabdff1aSopenharmony_ci * @file
24cabdff1aSopenharmony_ci * H.261 tables.
25cabdff1aSopenharmony_ci */
26cabdff1aSopenharmony_ci
27cabdff1aSopenharmony_ci#include <stdint.h>
28cabdff1aSopenharmony_ci
29cabdff1aSopenharmony_ci#include "mpegutils.h"
30cabdff1aSopenharmony_ci#include "rl.h"
31cabdff1aSopenharmony_ci#include "h261.h"
32cabdff1aSopenharmony_ci
33cabdff1aSopenharmony_ci// H.261 VLC table for macroblock addressing
34cabdff1aSopenharmony_ciconst uint8_t ff_h261_mba_code[35] = {
35cabdff1aSopenharmony_ci     1,  3,  2,  3,
36cabdff1aSopenharmony_ci     2,  3,  2,  7,
37cabdff1aSopenharmony_ci     6, 11, 10,  9,
38cabdff1aSopenharmony_ci     8,  7,  6, 23,
39cabdff1aSopenharmony_ci    22, 21, 20, 19,
40cabdff1aSopenharmony_ci    18, 35, 34, 33,
41cabdff1aSopenharmony_ci    32, 31, 30, 29,
42cabdff1aSopenharmony_ci    28, 27, 26, 25,
43cabdff1aSopenharmony_ci    24,
44cabdff1aSopenharmony_ci    15, // (MBA stuffing)
45cabdff1aSopenharmony_ci     1  // (start code)
46cabdff1aSopenharmony_ci};
47cabdff1aSopenharmony_ci
48cabdff1aSopenharmony_ciconst uint8_t ff_h261_mba_bits[35] = {
49cabdff1aSopenharmony_ci     1,  3,  3,  4,
50cabdff1aSopenharmony_ci     4,  5,  5,  7,
51cabdff1aSopenharmony_ci     7,  8,  8,  8,
52cabdff1aSopenharmony_ci     8,  8,  8, 10,
53cabdff1aSopenharmony_ci    10, 10, 10, 10,
54cabdff1aSopenharmony_ci    10, 11, 11, 11,
55cabdff1aSopenharmony_ci    11, 11, 11, 11,
56cabdff1aSopenharmony_ci    11, 11, 11, 11,
57cabdff1aSopenharmony_ci    11,
58cabdff1aSopenharmony_ci    11, // (MBA stuffing)
59cabdff1aSopenharmony_ci    16  // (start code)
60cabdff1aSopenharmony_ci};
61cabdff1aSopenharmony_ci
62cabdff1aSopenharmony_ci// H.261 VLC table for macroblock type
63cabdff1aSopenharmony_ciconst uint8_t ff_h261_mtype_code[10] = {
64cabdff1aSopenharmony_ci    1, 1, 1, 1,
65cabdff1aSopenharmony_ci    1, 1, 1, 1,
66cabdff1aSopenharmony_ci    1, 1
67cabdff1aSopenharmony_ci};
68cabdff1aSopenharmony_ci
69cabdff1aSopenharmony_ciconst uint8_t ff_h261_mtype_bits[10] = {
70cabdff1aSopenharmony_ci    4, 7,  1, 5,
71cabdff1aSopenharmony_ci    9, 8, 10, 3,
72cabdff1aSopenharmony_ci    2, 6
73cabdff1aSopenharmony_ci};
74cabdff1aSopenharmony_ci
75cabdff1aSopenharmony_ciconst int ff_h261_mtype_map[10] = {
76cabdff1aSopenharmony_ci    MB_TYPE_INTRA4x4,
77cabdff1aSopenharmony_ci    MB_TYPE_INTRA4x4 | MB_TYPE_QUANT,
78cabdff1aSopenharmony_ci    MB_TYPE_CBP,
79cabdff1aSopenharmony_ci    MB_TYPE_CBP | MB_TYPE_QUANT,
80cabdff1aSopenharmony_ci    MB_TYPE_16x16,
81cabdff1aSopenharmony_ci    MB_TYPE_16x16 | MB_TYPE_CBP,
82cabdff1aSopenharmony_ci    MB_TYPE_16x16 | MB_TYPE_CBP | MB_TYPE_QUANT,
83cabdff1aSopenharmony_ci    MB_TYPE_16x16 | MB_TYPE_H261_FIL,
84cabdff1aSopenharmony_ci    MB_TYPE_16x16 | MB_TYPE_H261_FIL | MB_TYPE_CBP,
85cabdff1aSopenharmony_ci    MB_TYPE_16x16 | MB_TYPE_H261_FIL | MB_TYPE_CBP | MB_TYPE_QUANT
86cabdff1aSopenharmony_ci};
87cabdff1aSopenharmony_ci
88cabdff1aSopenharmony_ci// H.261 VLC table for motion vectors
89cabdff1aSopenharmony_ciconst uint8_t ff_h261_mv_tab[17][2] = {
90cabdff1aSopenharmony_ci    {  1, 1 }, {  1, 2 }, { 1, 3 }, {  1,  4 }, {  3,  6 }, {  5,  7 }, {  4,  7 }, {  3,  7 },
91cabdff1aSopenharmony_ci    { 11, 9 }, { 10, 9 }, { 9, 9 }, { 17, 10 }, { 16, 10 }, { 15, 10 }, { 14, 10 }, { 13, 10 }, { 12, 10 }
92cabdff1aSopenharmony_ci};
93cabdff1aSopenharmony_ci
94cabdff1aSopenharmony_ci// H.261 VLC table for coded block pattern
95cabdff1aSopenharmony_ciconst uint8_t ff_h261_cbp_tab[63][2] = {
96cabdff1aSopenharmony_ci    { 11, 5 }, {  9, 5 }, { 13, 6 }, { 13, 4 }, { 23, 7 }, { 19, 7 }, { 31, 8 }, { 12, 4 },
97cabdff1aSopenharmony_ci    { 22, 7 }, { 18, 7 }, { 30, 8 }, { 19, 5 }, { 27, 8 }, { 23, 8 }, { 19, 8 }, { 11, 4 },
98cabdff1aSopenharmony_ci    { 21, 7 }, { 17, 7 }, { 29, 8 }, { 17, 5 }, { 25, 8 }, { 21, 8 }, { 17, 8 }, { 15, 6 },
99cabdff1aSopenharmony_ci    { 15, 8 }, { 13, 8 }, {  3, 9 }, { 15, 5 }, { 11, 8 }, {  7, 8 }, {  7, 9 }, { 10, 4 },
100cabdff1aSopenharmony_ci    { 20, 7 }, { 16, 7 }, { 28, 8 }, { 14, 6 }, { 14, 8 }, { 12, 8 }, {  2, 9 }, { 16, 5 },
101cabdff1aSopenharmony_ci    { 24, 8 }, { 20, 8 }, { 16, 8 }, { 14, 5 }, { 10, 8 }, {  6, 8 }, {  6, 9 }, { 18, 5 },
102cabdff1aSopenharmony_ci    { 26, 8 }, { 22, 8 }, { 18, 8 }, { 13, 5 }, {  9, 8 }, {  5, 8 }, {  5, 9 }, { 12, 5 },
103cabdff1aSopenharmony_ci    {  8, 8 }, {  4, 8 }, {  4, 9 }, {  7, 3 }, { 10, 5 }, {  8, 5 }, { 12, 6 }
104cabdff1aSopenharmony_ci};
105cabdff1aSopenharmony_ci
106cabdff1aSopenharmony_ci// H.261 VLC table for transform coefficients
107cabdff1aSopenharmony_cistatic const uint16_t h261_tcoeff_vlc[65][2] = {
108cabdff1aSopenharmony_ci    {  0x2,  2 }, {  0x3,  2 }, {  0x4,  4 }, {  0x5,  5 },
109cabdff1aSopenharmony_ci    {  0x6,  7 }, { 0x26,  8 }, { 0x21,  8 }, {  0xa, 10 },
110cabdff1aSopenharmony_ci    { 0x1d, 12 }, { 0x18, 12 }, { 0x13, 12 }, { 0x10, 12 },
111cabdff1aSopenharmony_ci    { 0x1a, 13 }, { 0x19, 13 }, { 0x18, 13 }, { 0x17, 13 },
112cabdff1aSopenharmony_ci    {  0x3,  3 }, {  0x6,  6 }, { 0x25,  8 }, {  0xc, 10 },
113cabdff1aSopenharmony_ci    { 0x1b, 12 }, { 0x16, 13 }, { 0x15, 13 }, {  0x5,  4 },
114cabdff1aSopenharmony_ci    {  0x4,  7 }, {  0xb, 10 }, { 0x14, 12 }, { 0x14, 13 },
115cabdff1aSopenharmony_ci    {  0x7,  5 }, { 0x24,  8 }, { 0x1c, 12 }, { 0x13, 13 },
116cabdff1aSopenharmony_ci    {  0x6,  5 }, {  0xf, 10 }, { 0x12, 12 }, {  0x7,  6 },
117cabdff1aSopenharmony_ci    {  0x9, 10 }, { 0x12, 13 }, {  0x5,  6 }, { 0x1e, 12 },
118cabdff1aSopenharmony_ci    {  0x4,  6 }, { 0x15, 12 }, {  0x7,  7 }, { 0x11, 12 },
119cabdff1aSopenharmony_ci    {  0x5,  7 }, { 0x11, 13 }, { 0x27,  8 }, { 0x10, 13 },
120cabdff1aSopenharmony_ci    { 0x23,  8 }, { 0x22,  8 }, { 0x20,  8 }, {  0xe, 10 },
121cabdff1aSopenharmony_ci    {  0xd, 10 }, {  0x8, 10 }, { 0x1f, 12 }, { 0x1a, 12 },
122cabdff1aSopenharmony_ci    { 0x19, 12 }, { 0x17, 12 }, { 0x16, 12 }, { 0x1f, 13 },
123cabdff1aSopenharmony_ci    { 0x1e, 13 }, { 0x1d, 13 }, { 0x1c, 13 }, { 0x1b, 13 },
124cabdff1aSopenharmony_ci    {  0x1,  6 }  // escape
125cabdff1aSopenharmony_ci};
126cabdff1aSopenharmony_ci
127cabdff1aSopenharmony_cistatic const int8_t h261_tcoeff_level[64] = {
128cabdff1aSopenharmony_ci    0, 1,  2,  3,  4,  5,  6,  7,
129cabdff1aSopenharmony_ci    8, 9, 10, 11, 12, 13, 14, 15,
130cabdff1aSopenharmony_ci    1, 2,  3,  4,  5,  6,  7,  1,
131cabdff1aSopenharmony_ci    2, 3,  4,  5,  1,  2,  3,  4,
132cabdff1aSopenharmony_ci    1, 2,  3,  1,  2,  3,  1,  2,
133cabdff1aSopenharmony_ci    1, 2,  1,  2,  1,  2,  1,  2,
134cabdff1aSopenharmony_ci    1, 1,  1,  1,  1,  1,  1,  1,
135cabdff1aSopenharmony_ci    1, 1,  1,  1,  1,  1,  1,  1
136cabdff1aSopenharmony_ci};
137cabdff1aSopenharmony_ci
138cabdff1aSopenharmony_cistatic const int8_t h261_tcoeff_run[64] = {
139cabdff1aSopenharmony_ci     0,
140cabdff1aSopenharmony_ci     0,  0,  0,  0,  0,  0,  0,  0,
141cabdff1aSopenharmony_ci     0,  0,  0,  0,  0,  0,  0,  1,
142cabdff1aSopenharmony_ci     1,  1,  1,  1,  1,  1,  2,  2,
143cabdff1aSopenharmony_ci     2,  2,  2,  3,  3,  3,  3,  4,
144cabdff1aSopenharmony_ci     4,  4,  5,  5,  5,  6,  6,  7,
145cabdff1aSopenharmony_ci     7,  8,  8,  9,  9, 10, 10, 11,
146cabdff1aSopenharmony_ci    12, 13, 14, 15, 16, 17, 18, 19,
147cabdff1aSopenharmony_ci    20, 21, 22, 23, 24, 25, 26
148cabdff1aSopenharmony_ci};
149cabdff1aSopenharmony_ci
150cabdff1aSopenharmony_ciRLTable ff_h261_rl_tcoeff = {
151cabdff1aSopenharmony_ci    64,
152cabdff1aSopenharmony_ci    64,
153cabdff1aSopenharmony_ci    h261_tcoeff_vlc,
154cabdff1aSopenharmony_ci    h261_tcoeff_run,
155cabdff1aSopenharmony_ci    h261_tcoeff_level,
156cabdff1aSopenharmony_ci};
157