You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1270 lines
41KB

  1. /*
  2. * MSMPEG4 backend for encoder and decoder
  3. * Copyright (c) 2001 Fabrice Bellard
  4. * Copyright (c) 2002-2004 Michael Niedermayer <michaelni@gmx.at>
  5. *
  6. * msmpeg4v1 & v2 stuff by Michael Niedermayer <michaelni@gmx.at>
  7. *
  8. * This file is part of FFmpeg.
  9. *
  10. * FFmpeg is free software; you can redistribute it and/or
  11. * modify it under the terms of the GNU Lesser General Public
  12. * License as published by the Free Software Foundation; either
  13. * version 2.1 of the License, or (at your option) any later version.
  14. *
  15. * FFmpeg is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  18. * Lesser General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU Lesser General Public
  21. * License along with FFmpeg; if not, write to the Free Software
  22. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  23. */
  24. /**
  25. * @file
  26. * MSMPEG4 backend for encoder and decoder
  27. */
  28. #include "avcodec.h"
  29. #include "dsputil.h"
  30. #include "mpegvideo.h"
  31. #include "msmpeg4.h"
  32. #include "libavutil/x86/asm.h"
  33. #include "h263.h"
  34. #include "mpeg4video.h"
  35. #include "msmpeg4data.h"
  36. #include "vc1data.h"
  37. #include "libavutil/imgutils.h"
  38. /*
  39. * You can also call this codec : MPEG4 with a twist !
  40. *
  41. * TODO:
  42. * - (encoding) select best mv table (two choices)
  43. * - (encoding) select best vlc/dc table
  44. */
  45. //#define DEBUG
  46. #define DC_VLC_BITS 9
  47. #define V2_INTRA_CBPC_VLC_BITS 3
  48. #define V2_MB_TYPE_VLC_BITS 7
  49. #define MV_VLC_BITS 9
  50. #define V2_MV_VLC_BITS 9
  51. #define TEX_VLC_BITS 9
  52. #define DEFAULT_INTER_INDEX 3
  53. /* This table is practically identical to the one from h263
  54. * except that it is inverted. */
  55. static av_cold void init_h263_dc_for_msmpeg4(void)
  56. {
  57. int level, uni_code, uni_len;
  58. if(ff_v2_dc_chroma_table[255 + 256][1])
  59. return;
  60. for(level=-256; level<256; level++){
  61. int size, v, l;
  62. /* find number of bits */
  63. size = 0;
  64. v = abs(level);
  65. while (v) {
  66. v >>= 1;
  67. size++;
  68. }
  69. if (level < 0)
  70. l= (-level) ^ ((1 << size) - 1);
  71. else
  72. l= level;
  73. /* luminance h263 */
  74. uni_code= ff_mpeg4_DCtab_lum[size][0];
  75. uni_len = ff_mpeg4_DCtab_lum[size][1];
  76. uni_code ^= (1<<uni_len)-1; //M$ does not like compatibility
  77. if (size > 0) {
  78. uni_code<<=size; uni_code|=l;
  79. uni_len+=size;
  80. if (size > 8){
  81. uni_code<<=1; uni_code|=1;
  82. uni_len++;
  83. }
  84. }
  85. ff_v2_dc_lum_table[level + 256][0] = uni_code;
  86. ff_v2_dc_lum_table[level + 256][1] = uni_len;
  87. /* chrominance h263 */
  88. uni_code= ff_mpeg4_DCtab_chrom[size][0];
  89. uni_len = ff_mpeg4_DCtab_chrom[size][1];
  90. uni_code ^= (1<<uni_len)-1; //M$ does not like compatibility
  91. if (size > 0) {
  92. uni_code<<=size; uni_code|=l;
  93. uni_len+=size;
  94. if (size > 8){
  95. uni_code<<=1; uni_code|=1;
  96. uni_len++;
  97. }
  98. }
  99. ff_v2_dc_chroma_table[level + 256][0] = uni_code;
  100. ff_v2_dc_chroma_table[level + 256][1] = uni_len;
  101. }
  102. }
  103. av_cold void ff_msmpeg4_common_init(MpegEncContext *s)
  104. {
  105. switch(s->msmpeg4_version){
  106. case 1:
  107. case 2:
  108. s->y_dc_scale_table=
  109. s->c_dc_scale_table= ff_mpeg1_dc_scale_table;
  110. break;
  111. case 3:
  112. if(s->workaround_bugs){
  113. s->y_dc_scale_table= ff_old_ff_y_dc_scale_table;
  114. s->c_dc_scale_table= ff_wmv1_c_dc_scale_table;
  115. } else{
  116. s->y_dc_scale_table= ff_mpeg4_y_dc_scale_table;
  117. s->c_dc_scale_table= ff_mpeg4_c_dc_scale_table;
  118. }
  119. break;
  120. case 4:
  121. case 5:
  122. s->y_dc_scale_table= ff_wmv1_y_dc_scale_table;
  123. s->c_dc_scale_table= ff_wmv1_c_dc_scale_table;
  124. break;
  125. #if CONFIG_VC1_DECODER
  126. case 6:
  127. s->y_dc_scale_table= ff_wmv3_dc_scale_table;
  128. s->c_dc_scale_table= ff_wmv3_dc_scale_table;
  129. break;
  130. #endif
  131. }
  132. if(s->msmpeg4_version>=4){
  133. ff_init_scantable(s->dsp.idct_permutation, &s->intra_scantable , ff_wmv1_scantable[1]);
  134. ff_init_scantable(s->dsp.idct_permutation, &s->intra_h_scantable, ff_wmv1_scantable[2]);
  135. ff_init_scantable(s->dsp.idct_permutation, &s->intra_v_scantable, ff_wmv1_scantable[3]);
  136. ff_init_scantable(s->dsp.idct_permutation, &s->inter_scantable , ff_wmv1_scantable[0]);
  137. }
  138. //Note the default tables are set in common_init in mpegvideo.c
  139. init_h263_dc_for_msmpeg4();
  140. }
  141. /* predict coded block */
  142. int ff_msmpeg4_coded_block_pred(MpegEncContext * s, int n, uint8_t **coded_block_ptr)
  143. {
  144. int xy, wrap, pred, a, b, c;
  145. xy = s->block_index[n];
  146. wrap = s->b8_stride;
  147. /* B C
  148. * A X
  149. */
  150. a = s->coded_block[xy - 1 ];
  151. b = s->coded_block[xy - 1 - wrap];
  152. c = s->coded_block[xy - wrap];
  153. if (b == c) {
  154. pred = a;
  155. } else {
  156. pred = c;
  157. }
  158. /* store value */
  159. *coded_block_ptr = &s->coded_block[xy];
  160. return pred;
  161. }
  162. static inline int msmpeg4v1_pred_dc(MpegEncContext * s, int n,
  163. int32_t **dc_val_ptr)
  164. {
  165. int i;
  166. if (n < 4) {
  167. i= 0;
  168. } else {
  169. i= n-3;
  170. }
  171. *dc_val_ptr= &s->last_dc[i];
  172. return s->last_dc[i];
  173. }
  174. static int get_dc(uint8_t *src, int stride, int scale)
  175. {
  176. int y;
  177. int sum=0;
  178. for(y=0; y<8; y++){
  179. int x;
  180. for(x=0; x<8; x++){
  181. sum+=src[x + y*stride];
  182. }
  183. }
  184. return FASTDIV((sum + (scale>>1)), scale);
  185. }
  186. /* dir = 0: left, dir = 1: top prediction */
  187. int ff_msmpeg4_pred_dc(MpegEncContext *s, int n,
  188. int16_t **dc_val_ptr, int *dir_ptr)
  189. {
  190. int a, b, c, wrap, pred, scale;
  191. int16_t *dc_val;
  192. /* find prediction */
  193. if (n < 4) {
  194. scale = s->y_dc_scale;
  195. } else {
  196. scale = s->c_dc_scale;
  197. }
  198. wrap = s->block_wrap[n];
  199. dc_val= s->dc_val[0] + s->block_index[n];
  200. /* B C
  201. * A X
  202. */
  203. a = dc_val[ - 1];
  204. b = dc_val[ - 1 - wrap];
  205. c = dc_val[ - wrap];
  206. if(s->first_slice_line && (n&2)==0 && s->msmpeg4_version<4){
  207. b=c=1024;
  208. }
  209. /* XXX: the following solution consumes divisions, but it does not
  210. necessitate to modify mpegvideo.c. The problem comes from the
  211. fact they decided to store the quantized DC (which would lead
  212. to problems if Q could vary !) */
  213. #if ARCH_X86 && HAVE_7REGS && HAVE_EBX_AVAILABLE
  214. __asm__ volatile(
  215. "movl %3, %%eax \n\t"
  216. "shrl $1, %%eax \n\t"
  217. "addl %%eax, %2 \n\t"
  218. "addl %%eax, %1 \n\t"
  219. "addl %0, %%eax \n\t"
  220. "mull %4 \n\t"
  221. "movl %%edx, %0 \n\t"
  222. "movl %1, %%eax \n\t"
  223. "mull %4 \n\t"
  224. "movl %%edx, %1 \n\t"
  225. "movl %2, %%eax \n\t"
  226. "mull %4 \n\t"
  227. "movl %%edx, %2 \n\t"
  228. : "+b" (a), "+c" (b), "+D" (c)
  229. : "g" (scale), "S" (ff_inverse[scale])
  230. : "%eax", "%edx"
  231. );
  232. #else
  233. /* #elif ARCH_ALPHA */
  234. /* Divisions are extremely costly on Alpha; optimize the most
  235. common case. But they are costly everywhere...
  236. */
  237. if (scale == 8) {
  238. a = (a + (8 >> 1)) / 8;
  239. b = (b + (8 >> 1)) / 8;
  240. c = (c + (8 >> 1)) / 8;
  241. } else {
  242. a = FASTDIV((a + (scale >> 1)), scale);
  243. b = FASTDIV((b + (scale >> 1)), scale);
  244. c = FASTDIV((c + (scale >> 1)), scale);
  245. }
  246. #endif
  247. /* XXX: WARNING: they did not choose the same test as MPEG4. This
  248. is very important ! */
  249. if(s->msmpeg4_version>3){
  250. if(s->inter_intra_pred){
  251. uint8_t *dest;
  252. int wrap;
  253. if(n==1){
  254. pred=a;
  255. *dir_ptr = 0;
  256. }else if(n==2){
  257. pred=c;
  258. *dir_ptr = 1;
  259. }else if(n==3){
  260. if (abs(a - b) < abs(b - c)) {
  261. pred = c;
  262. *dir_ptr = 1;
  263. } else {
  264. pred = a;
  265. *dir_ptr = 0;
  266. }
  267. }else{
  268. if(n<4){
  269. wrap= s->linesize;
  270. dest= s->current_picture.f.data[0] + (((n >> 1) + 2*s->mb_y) * 8* wrap ) + ((n & 1) + 2*s->mb_x) * 8;
  271. }else{
  272. wrap= s->uvlinesize;
  273. dest= s->current_picture.f.data[n - 3] + (s->mb_y * 8 * wrap) + s->mb_x * 8;
  274. }
  275. if(s->mb_x==0) a= (1024 + (scale>>1))/scale;
  276. else a= get_dc(dest-8, wrap, scale*8);
  277. if(s->mb_y==0) c= (1024 + (scale>>1))/scale;
  278. else c= get_dc(dest-8*wrap, wrap, scale*8);
  279. if (s->h263_aic_dir==0) {
  280. pred= a;
  281. *dir_ptr = 0;
  282. }else if (s->h263_aic_dir==1) {
  283. if(n==0){
  284. pred= c;
  285. *dir_ptr = 1;
  286. }else{
  287. pred= a;
  288. *dir_ptr = 0;
  289. }
  290. }else if (s->h263_aic_dir==2) {
  291. if(n==0){
  292. pred= a;
  293. *dir_ptr = 0;
  294. }else{
  295. pred= c;
  296. *dir_ptr = 1;
  297. }
  298. } else {
  299. pred= c;
  300. *dir_ptr = 1;
  301. }
  302. }
  303. }else{
  304. if (abs(a - b) < abs(b - c)) {
  305. pred = c;
  306. *dir_ptr = 1;
  307. } else {
  308. pred = a;
  309. *dir_ptr = 0;
  310. }
  311. }
  312. }else{
  313. if (abs(a - b) <= abs(b - c)) {
  314. pred = c;
  315. *dir_ptr = 1;
  316. } else {
  317. pred = a;
  318. *dir_ptr = 0;
  319. }
  320. }
  321. /* update predictor */
  322. *dc_val_ptr = &dc_val[0];
  323. return pred;
  324. }
  325. /****************************************/
  326. /* decoding stuff */
  327. VLC ff_mb_non_intra_vlc[4];
  328. static VLC v2_dc_lum_vlc;
  329. static VLC v2_dc_chroma_vlc;
  330. static VLC v2_intra_cbpc_vlc;
  331. static VLC v2_mb_type_vlc;
  332. static VLC v2_mv_vlc;
  333. VLC ff_inter_intra_vlc;
  334. /* This is identical to h263 except that its range is multiplied by 2. */
  335. static int msmpeg4v2_decode_motion(MpegEncContext * s, int pred, int f_code)
  336. {
  337. int code, val, sign, shift;
  338. code = get_vlc2(&s->gb, v2_mv_vlc.table, V2_MV_VLC_BITS, 2);
  339. av_dlog(s, "MV code %d at %d %d pred: %d\n", code, s->mb_x,s->mb_y, pred);
  340. if (code < 0)
  341. return 0xffff;
  342. if (code == 0)
  343. return pred;
  344. sign = get_bits1(&s->gb);
  345. shift = f_code - 1;
  346. val = code;
  347. if (shift) {
  348. val = (val - 1) << shift;
  349. val |= get_bits(&s->gb, shift);
  350. val++;
  351. }
  352. if (sign)
  353. val = -val;
  354. val += pred;
  355. if (val <= -64)
  356. val += 64;
  357. else if (val >= 64)
  358. val -= 64;
  359. return val;
  360. }
  361. static int msmpeg4v12_decode_mb(MpegEncContext *s, int16_t block[6][64])
  362. {
  363. int cbp, code, i;
  364. uint32_t * const mb_type_ptr = &s->current_picture.f.mb_type[s->mb_x + s->mb_y*s->mb_stride];
  365. if (s->pict_type == AV_PICTURE_TYPE_P) {
  366. if (s->use_skip_mb_code) {
  367. if (get_bits1(&s->gb)) {
  368. /* skip mb */
  369. s->mb_intra = 0;
  370. for(i=0;i<6;i++)
  371. s->block_last_index[i] = -1;
  372. s->mv_dir = MV_DIR_FORWARD;
  373. s->mv_type = MV_TYPE_16X16;
  374. s->mv[0][0][0] = 0;
  375. s->mv[0][0][1] = 0;
  376. s->mb_skipped = 1;
  377. *mb_type_ptr = MB_TYPE_SKIP | MB_TYPE_L0 | MB_TYPE_16x16;
  378. return 0;
  379. }
  380. }
  381. if(s->msmpeg4_version==2)
  382. code = get_vlc2(&s->gb, v2_mb_type_vlc.table, V2_MB_TYPE_VLC_BITS, 1);
  383. else
  384. code = get_vlc2(&s->gb, ff_h263_inter_MCBPC_vlc.table, INTER_MCBPC_VLC_BITS, 2);
  385. if(code<0 || code>7){
  386. av_log(s->avctx, AV_LOG_ERROR, "cbpc %d invalid at %d %d\n", code, s->mb_x, s->mb_y);
  387. return -1;
  388. }
  389. s->mb_intra = code >>2;
  390. cbp = code & 0x3;
  391. } else {
  392. s->mb_intra = 1;
  393. if(s->msmpeg4_version==2)
  394. cbp= get_vlc2(&s->gb, v2_intra_cbpc_vlc.table, V2_INTRA_CBPC_VLC_BITS, 1);
  395. else
  396. cbp= get_vlc2(&s->gb, ff_h263_intra_MCBPC_vlc.table, INTRA_MCBPC_VLC_BITS, 1);
  397. if(cbp<0 || cbp>3){
  398. av_log(s->avctx, AV_LOG_ERROR, "cbpc %d invalid at %d %d\n", cbp, s->mb_x, s->mb_y);
  399. return -1;
  400. }
  401. }
  402. if (!s->mb_intra) {
  403. int mx, my, cbpy;
  404. cbpy= get_vlc2(&s->gb, ff_h263_cbpy_vlc.table, CBPY_VLC_BITS, 1);
  405. if(cbpy<0){
  406. av_log(s->avctx, AV_LOG_ERROR, "cbpy %d invalid at %d %d\n", cbp, s->mb_x, s->mb_y);
  407. return -1;
  408. }
  409. cbp|= cbpy<<2;
  410. if(s->msmpeg4_version==1 || (cbp&3) != 3) cbp^= 0x3C;
  411. ff_h263_pred_motion(s, 0, 0, &mx, &my);
  412. mx= msmpeg4v2_decode_motion(s, mx, 1);
  413. my= msmpeg4v2_decode_motion(s, my, 1);
  414. s->mv_dir = MV_DIR_FORWARD;
  415. s->mv_type = MV_TYPE_16X16;
  416. s->mv[0][0][0] = mx;
  417. s->mv[0][0][1] = my;
  418. *mb_type_ptr = MB_TYPE_L0 | MB_TYPE_16x16;
  419. } else {
  420. if(s->msmpeg4_version==2){
  421. s->ac_pred = get_bits1(&s->gb);
  422. cbp|= get_vlc2(&s->gb, ff_h263_cbpy_vlc.table, CBPY_VLC_BITS, 1)<<2; //FIXME check errors
  423. } else{
  424. s->ac_pred = 0;
  425. cbp|= get_vlc2(&s->gb, ff_h263_cbpy_vlc.table, CBPY_VLC_BITS, 1)<<2; //FIXME check errors
  426. if(s->pict_type==AV_PICTURE_TYPE_P) cbp^=0x3C;
  427. }
  428. *mb_type_ptr = MB_TYPE_INTRA;
  429. }
  430. s->dsp.clear_blocks(s->block[0]);
  431. for (i = 0; i < 6; i++) {
  432. if (ff_msmpeg4_decode_block(s, block[i], i, (cbp >> (5 - i)) & 1, NULL) < 0)
  433. {
  434. av_log(s->avctx, AV_LOG_ERROR, "\nerror while decoding block: %d x %d (%d)\n", s->mb_x, s->mb_y, i);
  435. return -1;
  436. }
  437. }
  438. return 0;
  439. }
  440. static int msmpeg4v34_decode_mb(MpegEncContext *s, int16_t block[6][64])
  441. {
  442. int cbp, code, i;
  443. uint8_t *coded_val;
  444. uint32_t * const mb_type_ptr = &s->current_picture.f.mb_type[s->mb_x + s->mb_y*s->mb_stride];
  445. if (s->pict_type == AV_PICTURE_TYPE_P) {
  446. if (s->use_skip_mb_code) {
  447. if (get_bits1(&s->gb)) {
  448. /* skip mb */
  449. s->mb_intra = 0;
  450. for(i=0;i<6;i++)
  451. s->block_last_index[i] = -1;
  452. s->mv_dir = MV_DIR_FORWARD;
  453. s->mv_type = MV_TYPE_16X16;
  454. s->mv[0][0][0] = 0;
  455. s->mv[0][0][1] = 0;
  456. s->mb_skipped = 1;
  457. *mb_type_ptr = MB_TYPE_SKIP | MB_TYPE_L0 | MB_TYPE_16x16;
  458. return 0;
  459. }
  460. }
  461. code = get_vlc2(&s->gb, ff_mb_non_intra_vlc[DEFAULT_INTER_INDEX].table, MB_NON_INTRA_VLC_BITS, 3);
  462. if (code < 0)
  463. return -1;
  464. //s->mb_intra = (code & 0x40) ? 0 : 1;
  465. s->mb_intra = (~code & 0x40) >> 6;
  466. cbp = code & 0x3f;
  467. } else {
  468. s->mb_intra = 1;
  469. code = get_vlc2(&s->gb, ff_msmp4_mb_i_vlc.table, MB_INTRA_VLC_BITS, 2);
  470. if (code < 0)
  471. return -1;
  472. /* predict coded block pattern */
  473. cbp = 0;
  474. for(i=0;i<6;i++) {
  475. int val = ((code >> (5 - i)) & 1);
  476. if (i < 4) {
  477. int pred = ff_msmpeg4_coded_block_pred(s, i, &coded_val);
  478. val = val ^ pred;
  479. *coded_val = val;
  480. }
  481. cbp |= val << (5 - i);
  482. }
  483. }
  484. if (!s->mb_intra) {
  485. int mx, my;
  486. if(s->per_mb_rl_table && cbp){
  487. s->rl_table_index = decode012(&s->gb);
  488. s->rl_chroma_table_index = s->rl_table_index;
  489. }
  490. ff_h263_pred_motion(s, 0, 0, &mx, &my);
  491. if (ff_msmpeg4_decode_motion(s, &mx, &my) < 0)
  492. return -1;
  493. s->mv_dir = MV_DIR_FORWARD;
  494. s->mv_type = MV_TYPE_16X16;
  495. s->mv[0][0][0] = mx;
  496. s->mv[0][0][1] = my;
  497. *mb_type_ptr = MB_TYPE_L0 | MB_TYPE_16x16;
  498. } else {
  499. av_dlog(s, "I at %d %d %d %06X\n", s->mb_x, s->mb_y,
  500. ((cbp & 3) ? 1 : 0) +((cbp & 0x3C)? 2 : 0),
  501. show_bits(&s->gb, 24));
  502. s->ac_pred = get_bits1(&s->gb);
  503. *mb_type_ptr = MB_TYPE_INTRA;
  504. if(s->inter_intra_pred){
  505. s->h263_aic_dir= get_vlc2(&s->gb, ff_inter_intra_vlc.table, INTER_INTRA_VLC_BITS, 1);
  506. av_dlog(s, "%d%d %d %d/",
  507. s->ac_pred, s->h263_aic_dir, s->mb_x, s->mb_y);
  508. }
  509. if(s->per_mb_rl_table && cbp){
  510. s->rl_table_index = decode012(&s->gb);
  511. s->rl_chroma_table_index = s->rl_table_index;
  512. }
  513. }
  514. s->dsp.clear_blocks(s->block[0]);
  515. for (i = 0; i < 6; i++) {
  516. if (ff_msmpeg4_decode_block(s, block[i], i, (cbp >> (5 - i)) & 1, NULL) < 0)
  517. {
  518. av_log(s->avctx, AV_LOG_ERROR, "\nerror while decoding block: %d x %d (%d)\n", s->mb_x, s->mb_y, i);
  519. return -1;
  520. }
  521. }
  522. return 0;
  523. }
  524. /* init all vlc decoding tables */
  525. av_cold int ff_msmpeg4_decode_init(AVCodecContext *avctx)
  526. {
  527. MpegEncContext *s = avctx->priv_data;
  528. static volatile int done = 0;
  529. int i, ret;
  530. MVTable *mv;
  531. if ((ret = av_image_check_size(avctx->width, avctx->height, 0, avctx)) < 0)
  532. return ret;
  533. if (ff_h263_decode_init(avctx) < 0)
  534. return -1;
  535. ff_msmpeg4_common_init(s);
  536. if (!done) {
  537. for(i=0;i<NB_RL_TABLES;i++) {
  538. ff_init_rl(&ff_rl_table[i], ff_static_rl_table_store[i]);
  539. }
  540. INIT_VLC_RL(ff_rl_table[0], 642);
  541. INIT_VLC_RL(ff_rl_table[1], 1104);
  542. INIT_VLC_RL(ff_rl_table[2], 554);
  543. INIT_VLC_RL(ff_rl_table[3], 940);
  544. INIT_VLC_RL(ff_rl_table[4], 962);
  545. INIT_VLC_RL(ff_rl_table[5], 554);
  546. mv = &ff_mv_tables[0];
  547. INIT_VLC_STATIC(&mv->vlc, MV_VLC_BITS, mv->n + 1,
  548. mv->table_mv_bits, 1, 1,
  549. mv->table_mv_code, 2, 2, 3714);
  550. mv = &ff_mv_tables[1];
  551. INIT_VLC_STATIC(&mv->vlc, MV_VLC_BITS, mv->n + 1,
  552. mv->table_mv_bits, 1, 1,
  553. mv->table_mv_code, 2, 2, 2694);
  554. INIT_VLC_STATIC(&ff_msmp4_dc_luma_vlc[0], DC_VLC_BITS, 120,
  555. &ff_table0_dc_lum[0][1], 8, 4,
  556. &ff_table0_dc_lum[0][0], 8, 4, 1158);
  557. INIT_VLC_STATIC(&ff_msmp4_dc_chroma_vlc[0], DC_VLC_BITS, 120,
  558. &ff_table0_dc_chroma[0][1], 8, 4,
  559. &ff_table0_dc_chroma[0][0], 8, 4, 1118);
  560. INIT_VLC_STATIC(&ff_msmp4_dc_luma_vlc[1], DC_VLC_BITS, 120,
  561. &ff_table1_dc_lum[0][1], 8, 4,
  562. &ff_table1_dc_lum[0][0], 8, 4, 1476);
  563. INIT_VLC_STATIC(&ff_msmp4_dc_chroma_vlc[1], DC_VLC_BITS, 120,
  564. &ff_table1_dc_chroma[0][1], 8, 4,
  565. &ff_table1_dc_chroma[0][0], 8, 4, 1216);
  566. INIT_VLC_STATIC(&v2_dc_lum_vlc, DC_VLC_BITS, 512,
  567. &ff_v2_dc_lum_table[0][1], 8, 4,
  568. &ff_v2_dc_lum_table[0][0], 8, 4, 1472);
  569. INIT_VLC_STATIC(&v2_dc_chroma_vlc, DC_VLC_BITS, 512,
  570. &ff_v2_dc_chroma_table[0][1], 8, 4,
  571. &ff_v2_dc_chroma_table[0][0], 8, 4, 1506);
  572. INIT_VLC_STATIC(&v2_intra_cbpc_vlc, V2_INTRA_CBPC_VLC_BITS, 4,
  573. &ff_v2_intra_cbpc[0][1], 2, 1,
  574. &ff_v2_intra_cbpc[0][0], 2, 1, 8);
  575. INIT_VLC_STATIC(&v2_mb_type_vlc, V2_MB_TYPE_VLC_BITS, 8,
  576. &ff_v2_mb_type[0][1], 2, 1,
  577. &ff_v2_mb_type[0][0], 2, 1, 128);
  578. INIT_VLC_STATIC(&v2_mv_vlc, V2_MV_VLC_BITS, 33,
  579. &ff_mvtab[0][1], 2, 1,
  580. &ff_mvtab[0][0], 2, 1, 538);
  581. INIT_VLC_STATIC(&ff_mb_non_intra_vlc[0], MB_NON_INTRA_VLC_BITS, 128,
  582. &ff_wmv2_inter_table[0][0][1], 8, 4,
  583. &ff_wmv2_inter_table[0][0][0], 8, 4, 1636);
  584. INIT_VLC_STATIC(&ff_mb_non_intra_vlc[1], MB_NON_INTRA_VLC_BITS, 128,
  585. &ff_wmv2_inter_table[1][0][1], 8, 4,
  586. &ff_wmv2_inter_table[1][0][0], 8, 4, 2648);
  587. INIT_VLC_STATIC(&ff_mb_non_intra_vlc[2], MB_NON_INTRA_VLC_BITS, 128,
  588. &ff_wmv2_inter_table[2][0][1], 8, 4,
  589. &ff_wmv2_inter_table[2][0][0], 8, 4, 1532);
  590. INIT_VLC_STATIC(&ff_mb_non_intra_vlc[3], MB_NON_INTRA_VLC_BITS, 128,
  591. &ff_wmv2_inter_table[3][0][1], 8, 4,
  592. &ff_wmv2_inter_table[3][0][0], 8, 4, 2488);
  593. INIT_VLC_STATIC(&ff_msmp4_mb_i_vlc, MB_INTRA_VLC_BITS, 64,
  594. &ff_msmp4_mb_i_table[0][1], 4, 2,
  595. &ff_msmp4_mb_i_table[0][0], 4, 2, 536);
  596. INIT_VLC_STATIC(&ff_inter_intra_vlc, INTER_INTRA_VLC_BITS, 4,
  597. &ff_table_inter_intra[0][1], 2, 1,
  598. &ff_table_inter_intra[0][0], 2, 1, 8);
  599. done = 1;
  600. }
  601. switch(s->msmpeg4_version){
  602. case 1:
  603. case 2:
  604. s->decode_mb= msmpeg4v12_decode_mb;
  605. break;
  606. case 3:
  607. case 4:
  608. s->decode_mb= msmpeg4v34_decode_mb;
  609. break;
  610. case 5:
  611. if (CONFIG_WMV2_DECODER)
  612. s->decode_mb= ff_wmv2_decode_mb;
  613. case 6:
  614. //FIXME + TODO VC1 decode mb
  615. break;
  616. }
  617. s->slice_height= s->mb_height; //to avoid 1/0 if the first frame is not a keyframe
  618. return 0;
  619. }
  620. int ff_msmpeg4_decode_picture_header(MpegEncContext * s)
  621. {
  622. int code;
  623. if(s->msmpeg4_version==1){
  624. int start_code = get_bits_long(&s->gb, 32);
  625. if(start_code!=0x00000100){
  626. av_log(s->avctx, AV_LOG_ERROR, "invalid startcode\n");
  627. return -1;
  628. }
  629. skip_bits(&s->gb, 5); // frame number */
  630. }
  631. s->pict_type = get_bits(&s->gb, 2) + 1;
  632. if (s->pict_type != AV_PICTURE_TYPE_I &&
  633. s->pict_type != AV_PICTURE_TYPE_P){
  634. av_log(s->avctx, AV_LOG_ERROR, "invalid picture type\n");
  635. return -1;
  636. }
  637. #if 0
  638. {
  639. static int had_i=0;
  640. if(s->pict_type == AV_PICTURE_TYPE_I) had_i=1;
  641. if(!had_i) return -1;
  642. }
  643. #endif
  644. s->chroma_qscale= s->qscale = get_bits(&s->gb, 5);
  645. if(s->qscale==0){
  646. av_log(s->avctx, AV_LOG_ERROR, "invalid qscale\n");
  647. return -1;
  648. }
  649. if (s->pict_type == AV_PICTURE_TYPE_I) {
  650. code = get_bits(&s->gb, 5);
  651. if(s->msmpeg4_version==1){
  652. if(code==0 || code>s->mb_height){
  653. av_log(s->avctx, AV_LOG_ERROR, "invalid slice height %d\n", code);
  654. return -1;
  655. }
  656. s->slice_height = code;
  657. }else{
  658. /* 0x17: one slice, 0x18: two slices, ... */
  659. if (code < 0x17){
  660. av_log(s->avctx, AV_LOG_ERROR, "error, slice code was %X\n", code);
  661. return -1;
  662. }
  663. s->slice_height = s->mb_height / (code - 0x16);
  664. }
  665. switch(s->msmpeg4_version){
  666. case 1:
  667. case 2:
  668. s->rl_chroma_table_index = 2;
  669. s->rl_table_index = 2;
  670. s->dc_table_index = 0; //not used
  671. break;
  672. case 3:
  673. s->rl_chroma_table_index = decode012(&s->gb);
  674. s->rl_table_index = decode012(&s->gb);
  675. s->dc_table_index = get_bits1(&s->gb);
  676. break;
  677. case 4:
  678. ff_msmpeg4_decode_ext_header(s, (2+5+5+17+7)/8);
  679. if(s->bit_rate > MBAC_BITRATE) s->per_mb_rl_table= get_bits1(&s->gb);
  680. else s->per_mb_rl_table= 0;
  681. if(!s->per_mb_rl_table){
  682. s->rl_chroma_table_index = decode012(&s->gb);
  683. s->rl_table_index = decode012(&s->gb);
  684. }
  685. s->dc_table_index = get_bits1(&s->gb);
  686. s->inter_intra_pred= 0;
  687. break;
  688. }
  689. s->no_rounding = 1;
  690. if(s->avctx->debug&FF_DEBUG_PICT_INFO)
  691. av_log(s->avctx, AV_LOG_DEBUG, "qscale:%d rlc:%d rl:%d dc:%d mbrl:%d slice:%d \n",
  692. s->qscale,
  693. s->rl_chroma_table_index,
  694. s->rl_table_index,
  695. s->dc_table_index,
  696. s->per_mb_rl_table,
  697. s->slice_height);
  698. } else {
  699. switch(s->msmpeg4_version){
  700. case 1:
  701. case 2:
  702. if(s->msmpeg4_version==1)
  703. s->use_skip_mb_code = 1;
  704. else
  705. s->use_skip_mb_code = get_bits1(&s->gb);
  706. s->rl_table_index = 2;
  707. s->rl_chroma_table_index = s->rl_table_index;
  708. s->dc_table_index = 0; //not used
  709. s->mv_table_index = 0;
  710. break;
  711. case 3:
  712. s->use_skip_mb_code = get_bits1(&s->gb);
  713. s->rl_table_index = decode012(&s->gb);
  714. s->rl_chroma_table_index = s->rl_table_index;
  715. s->dc_table_index = get_bits1(&s->gb);
  716. s->mv_table_index = get_bits1(&s->gb);
  717. break;
  718. case 4:
  719. s->use_skip_mb_code = get_bits1(&s->gb);
  720. if(s->bit_rate > MBAC_BITRATE) s->per_mb_rl_table= get_bits1(&s->gb);
  721. else s->per_mb_rl_table= 0;
  722. if(!s->per_mb_rl_table){
  723. s->rl_table_index = decode012(&s->gb);
  724. s->rl_chroma_table_index = s->rl_table_index;
  725. }
  726. s->dc_table_index = get_bits1(&s->gb);
  727. s->mv_table_index = get_bits1(&s->gb);
  728. s->inter_intra_pred= (s->width*s->height < 320*240 && s->bit_rate<=II_BITRATE);
  729. break;
  730. }
  731. if(s->avctx->debug&FF_DEBUG_PICT_INFO)
  732. av_log(s->avctx, AV_LOG_DEBUG, "skip:%d rl:%d rlc:%d dc:%d mv:%d mbrl:%d qp:%d \n",
  733. s->use_skip_mb_code,
  734. s->rl_table_index,
  735. s->rl_chroma_table_index,
  736. s->dc_table_index,
  737. s->mv_table_index,
  738. s->per_mb_rl_table,
  739. s->qscale);
  740. if(s->flipflop_rounding){
  741. s->no_rounding ^= 1;
  742. }else{
  743. s->no_rounding = 0;
  744. }
  745. }
  746. av_dlog(s->avctx, "%d %d %d %d %d\n", s->pict_type, s->bit_rate,
  747. s->inter_intra_pred, s->width, s->height);
  748. s->esc3_level_length= 0;
  749. s->esc3_run_length= 0;
  750. return 0;
  751. }
  752. int ff_msmpeg4_decode_ext_header(MpegEncContext * s, int buf_size)
  753. {
  754. int left= buf_size*8 - get_bits_count(&s->gb);
  755. int length= s->msmpeg4_version>=3 ? 17 : 16;
  756. /* the alt_bitstream reader could read over the end so we need to check it */
  757. if(left>=length && left<length+8)
  758. {
  759. skip_bits(&s->gb, 5); /* fps */
  760. s->bit_rate= get_bits(&s->gb, 11)*1024;
  761. if(s->msmpeg4_version>=3)
  762. s->flipflop_rounding= get_bits1(&s->gb);
  763. else
  764. s->flipflop_rounding= 0;
  765. }
  766. else if(left<length+8)
  767. {
  768. s->flipflop_rounding= 0;
  769. if(s->msmpeg4_version != 2)
  770. av_log(s->avctx, AV_LOG_ERROR, "ext header missing, %d left\n", left);
  771. }
  772. else
  773. {
  774. av_log(s->avctx, AV_LOG_ERROR, "I frame too long, ignoring ext header\n");
  775. }
  776. return 0;
  777. }
  778. static int msmpeg4_decode_dc(MpegEncContext * s, int n, int *dir_ptr)
  779. {
  780. int level, pred;
  781. if(s->msmpeg4_version<=2){
  782. if (n < 4) {
  783. level = get_vlc2(&s->gb, v2_dc_lum_vlc.table, DC_VLC_BITS, 3);
  784. } else {
  785. level = get_vlc2(&s->gb, v2_dc_chroma_vlc.table, DC_VLC_BITS, 3);
  786. }
  787. if (level < 0)
  788. return -1;
  789. level-=256;
  790. }else{ //FIXME optimize use unified tables & index
  791. if (n < 4) {
  792. level = get_vlc2(&s->gb, ff_msmp4_dc_luma_vlc[s->dc_table_index].table, DC_VLC_BITS, 3);
  793. } else {
  794. level = get_vlc2(&s->gb, ff_msmp4_dc_chroma_vlc[s->dc_table_index].table, DC_VLC_BITS, 3);
  795. }
  796. if (level < 0){
  797. av_log(s->avctx, AV_LOG_ERROR, "illegal dc vlc\n");
  798. return -1;
  799. }
  800. if (level == DC_MAX) {
  801. level = get_bits(&s->gb, 8);
  802. if (get_bits1(&s->gb))
  803. level = -level;
  804. } else if (level != 0) {
  805. if (get_bits1(&s->gb))
  806. level = -level;
  807. }
  808. }
  809. if(s->msmpeg4_version==1){
  810. int32_t *dc_val;
  811. pred = msmpeg4v1_pred_dc(s, n, &dc_val);
  812. level += pred;
  813. /* update predictor */
  814. *dc_val= level;
  815. }else{
  816. int16_t *dc_val;
  817. pred = ff_msmpeg4_pred_dc(s, n, &dc_val, dir_ptr);
  818. level += pred;
  819. /* update predictor */
  820. if (n < 4) {
  821. *dc_val = level * s->y_dc_scale;
  822. } else {
  823. *dc_val = level * s->c_dc_scale;
  824. }
  825. }
  826. return level;
  827. }
  828. //#define ERROR_DETAILS
  829. int ff_msmpeg4_decode_block(MpegEncContext * s, int16_t * block,
  830. int n, int coded, const uint8_t *scan_table)
  831. {
  832. int level, i, last, run, run_diff;
  833. int av_uninit(dc_pred_dir);
  834. RLTable *rl;
  835. RL_VLC_ELEM *rl_vlc;
  836. int qmul, qadd;
  837. if (s->mb_intra) {
  838. qmul=1;
  839. qadd=0;
  840. /* DC coef */
  841. level = msmpeg4_decode_dc(s, n, &dc_pred_dir);
  842. if (level < 0){
  843. av_log(s->avctx, AV_LOG_ERROR, "dc overflow- block: %d qscale: %d//\n", n, s->qscale);
  844. if(s->inter_intra_pred) level=0;
  845. else return -1;
  846. }
  847. if (n < 4) {
  848. rl = &ff_rl_table[s->rl_table_index];
  849. if(level > 256*s->y_dc_scale){
  850. av_log(s->avctx, AV_LOG_ERROR, "dc overflow+ L qscale: %d//\n", s->qscale);
  851. if(!s->inter_intra_pred) return -1;
  852. }
  853. } else {
  854. rl = &ff_rl_table[3 + s->rl_chroma_table_index];
  855. if(level > 256*s->c_dc_scale){
  856. av_log(s->avctx, AV_LOG_ERROR, "dc overflow+ C qscale: %d//\n", s->qscale);
  857. if(!s->inter_intra_pred) return -1;
  858. }
  859. }
  860. block[0] = level;
  861. run_diff = s->msmpeg4_version >= 4;
  862. i = 0;
  863. if (!coded) {
  864. goto not_coded;
  865. }
  866. if (s->ac_pred) {
  867. if (dc_pred_dir == 0)
  868. scan_table = s->intra_v_scantable.permutated; /* left */
  869. else
  870. scan_table = s->intra_h_scantable.permutated; /* top */
  871. } else {
  872. scan_table = s->intra_scantable.permutated;
  873. }
  874. rl_vlc= rl->rl_vlc[0];
  875. } else {
  876. qmul = s->qscale << 1;
  877. qadd = (s->qscale - 1) | 1;
  878. i = -1;
  879. rl = &ff_rl_table[3 + s->rl_table_index];
  880. if(s->msmpeg4_version==2)
  881. run_diff = 0;
  882. else
  883. run_diff = 1;
  884. if (!coded) {
  885. s->block_last_index[n] = i;
  886. return 0;
  887. }
  888. if(!scan_table)
  889. scan_table = s->inter_scantable.permutated;
  890. rl_vlc= rl->rl_vlc[s->qscale];
  891. }
  892. {
  893. OPEN_READER(re, &s->gb);
  894. for(;;) {
  895. UPDATE_CACHE(re, &s->gb);
  896. GET_RL_VLC(level, run, re, &s->gb, rl_vlc, TEX_VLC_BITS, 2, 0);
  897. if (level==0) {
  898. int cache;
  899. cache= GET_CACHE(re, &s->gb);
  900. /* escape */
  901. if (s->msmpeg4_version==1 || (cache&0x80000000)==0) {
  902. if (s->msmpeg4_version==1 || (cache&0x40000000)==0) {
  903. /* third escape */
  904. if(s->msmpeg4_version!=1) LAST_SKIP_BITS(re, &s->gb, 2);
  905. UPDATE_CACHE(re, &s->gb);
  906. if(s->msmpeg4_version<=3){
  907. last= SHOW_UBITS(re, &s->gb, 1); SKIP_CACHE(re, &s->gb, 1);
  908. run= SHOW_UBITS(re, &s->gb, 6); SKIP_CACHE(re, &s->gb, 6);
  909. level= SHOW_SBITS(re, &s->gb, 8);
  910. SKIP_COUNTER(re, &s->gb, 1+6+8);
  911. }else{
  912. int sign;
  913. last= SHOW_UBITS(re, &s->gb, 1); SKIP_BITS(re, &s->gb, 1);
  914. if(!s->esc3_level_length){
  915. int ll;
  916. av_dlog(s->avctx, "ESC-3 %X at %d %d\n",
  917. show_bits(&s->gb, 24), s->mb_x, s->mb_y);
  918. if(s->qscale<8){
  919. ll= SHOW_UBITS(re, &s->gb, 3); SKIP_BITS(re, &s->gb, 3);
  920. if(ll==0){
  921. ll= 8+SHOW_UBITS(re, &s->gb, 1); SKIP_BITS(re, &s->gb, 1);
  922. }
  923. }else{
  924. ll=2;
  925. while(ll<8 && SHOW_UBITS(re, &s->gb, 1)==0){
  926. ll++;
  927. SKIP_BITS(re, &s->gb, 1);
  928. }
  929. if(ll<8) SKIP_BITS(re, &s->gb, 1);
  930. }
  931. s->esc3_level_length= ll;
  932. s->esc3_run_length= SHOW_UBITS(re, &s->gb, 2) + 3; SKIP_BITS(re, &s->gb, 2);
  933. UPDATE_CACHE(re, &s->gb);
  934. }
  935. run= SHOW_UBITS(re, &s->gb, s->esc3_run_length);
  936. SKIP_BITS(re, &s->gb, s->esc3_run_length);
  937. sign= SHOW_UBITS(re, &s->gb, 1);
  938. SKIP_BITS(re, &s->gb, 1);
  939. level= SHOW_UBITS(re, &s->gb, s->esc3_level_length);
  940. SKIP_BITS(re, &s->gb, s->esc3_level_length);
  941. if(sign) level= -level;
  942. }
  943. #if 0 // waste of time / this will detect very few errors
  944. {
  945. const int abs_level= FFABS(level);
  946. const int run1= run - rl->max_run[last][abs_level] - run_diff;
  947. if(abs_level<=MAX_LEVEL && run<=MAX_RUN){
  948. if(abs_level <= rl->max_level[last][run]){
  949. av_log(s->avctx, AV_LOG_ERROR, "illegal 3. esc, vlc encoding possible\n");
  950. return DECODING_AC_LOST;
  951. }
  952. if(abs_level <= rl->max_level[last][run]*2){
  953. av_log(s->avctx, AV_LOG_ERROR, "illegal 3. esc, esc 1 encoding possible\n");
  954. return DECODING_AC_LOST;
  955. }
  956. if(run1>=0 && abs_level <= rl->max_level[last][run1]){
  957. av_log(s->avctx, AV_LOG_ERROR, "illegal 3. esc, esc 2 encoding possible\n");
  958. return DECODING_AC_LOST;
  959. }
  960. }
  961. }
  962. #endif
  963. //level = level * qmul + (level>0) * qadd - (level<=0) * qadd ;
  964. if (level>0) level= level * qmul + qadd;
  965. else level= level * qmul - qadd;
  966. #if 0 // waste of time too :(
  967. if(level>2048 || level<-2048){
  968. av_log(s->avctx, AV_LOG_ERROR, "|level| overflow in 3. esc\n");
  969. return DECODING_AC_LOST;
  970. }
  971. #endif
  972. i+= run + 1;
  973. if(last) i+=192;
  974. #ifdef ERROR_DETAILS
  975. if(run==66)
  976. av_log(s->avctx, AV_LOG_ERROR, "illegal vlc code in ESC3 level=%d\n", level);
  977. else if((i>62 && i<192) || i>192+63)
  978. av_log(s->avctx, AV_LOG_ERROR, "run overflow in ESC3 i=%d run=%d level=%d\n", i, run, level);
  979. #endif
  980. } else {
  981. /* second escape */
  982. SKIP_BITS(re, &s->gb, 2);
  983. GET_RL_VLC(level, run, re, &s->gb, rl_vlc, TEX_VLC_BITS, 2, 1);
  984. i+= run + rl->max_run[run>>7][level/qmul] + run_diff; //FIXME opt indexing
  985. level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
  986. LAST_SKIP_BITS(re, &s->gb, 1);
  987. #ifdef ERROR_DETAILS
  988. if(run==66)
  989. av_log(s->avctx, AV_LOG_ERROR, "illegal vlc code in ESC2 level=%d\n", level);
  990. else if((i>62 && i<192) || i>192+63)
  991. av_log(s->avctx, AV_LOG_ERROR, "run overflow in ESC2 i=%d run=%d level=%d\n", i, run, level);
  992. #endif
  993. }
  994. } else {
  995. /* first escape */
  996. SKIP_BITS(re, &s->gb, 1);
  997. GET_RL_VLC(level, run, re, &s->gb, rl_vlc, TEX_VLC_BITS, 2, 1);
  998. i+= run;
  999. level = level + rl->max_level[run>>7][(run-1)&63] * qmul;//FIXME opt indexing
  1000. level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
  1001. LAST_SKIP_BITS(re, &s->gb, 1);
  1002. #ifdef ERROR_DETAILS
  1003. if(run==66)
  1004. av_log(s->avctx, AV_LOG_ERROR, "illegal vlc code in ESC1 level=%d\n", level);
  1005. else if((i>62 && i<192) || i>192+63)
  1006. av_log(s->avctx, AV_LOG_ERROR, "run overflow in ESC1 i=%d run=%d level=%d\n", i, run, level);
  1007. #endif
  1008. }
  1009. } else {
  1010. i+= run;
  1011. level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
  1012. LAST_SKIP_BITS(re, &s->gb, 1);
  1013. #ifdef ERROR_DETAILS
  1014. if(run==66)
  1015. av_log(s->avctx, AV_LOG_ERROR, "illegal vlc code level=%d\n", level);
  1016. else if((i>62 && i<192) || i>192+63)
  1017. av_log(s->avctx, AV_LOG_ERROR, "run overflow i=%d run=%d level=%d\n", i, run, level);
  1018. #endif
  1019. }
  1020. if (i > 62){
  1021. i-= 192;
  1022. if(i&(~63)){
  1023. const int left= get_bits_left(&s->gb);
  1024. if(((i+192 == 64 && level/qmul==-1) || !(s->err_recognition&(AV_EF_BITSTREAM|AV_EF_COMPLIANT))) && left>=0){
  1025. av_log(s->avctx, AV_LOG_ERROR, "ignoring overflow at %d %d\n", s->mb_x, s->mb_y);
  1026. i = 63;
  1027. break;
  1028. }else{
  1029. av_log(s->avctx, AV_LOG_ERROR, "ac-tex damaged at %d %d\n", s->mb_x, s->mb_y);
  1030. return -1;
  1031. }
  1032. }
  1033. block[scan_table[i]] = level;
  1034. break;
  1035. }
  1036. block[scan_table[i]] = level;
  1037. }
  1038. CLOSE_READER(re, &s->gb);
  1039. }
  1040. not_coded:
  1041. if (s->mb_intra) {
  1042. ff_mpeg4_pred_ac(s, block, n, dc_pred_dir);
  1043. if (s->ac_pred) {
  1044. i = 63; /* XXX: not optimal */
  1045. }
  1046. }
  1047. if(s->msmpeg4_version>=4 && i>0) i=63; //FIXME/XXX optimize
  1048. s->block_last_index[n] = i;
  1049. return 0;
  1050. }
  1051. int ff_msmpeg4_decode_motion(MpegEncContext * s,
  1052. int *mx_ptr, int *my_ptr)
  1053. {
  1054. MVTable *mv;
  1055. int code, mx, my;
  1056. mv = &ff_mv_tables[s->mv_table_index];
  1057. code = get_vlc2(&s->gb, mv->vlc.table, MV_VLC_BITS, 2);
  1058. if (code < 0){
  1059. av_log(s->avctx, AV_LOG_ERROR, "illegal MV code at %d %d\n", s->mb_x, s->mb_y);
  1060. return -1;
  1061. }
  1062. if (code == mv->n) {
  1063. mx = get_bits(&s->gb, 6);
  1064. my = get_bits(&s->gb, 6);
  1065. } else {
  1066. mx = mv->table_mvx[code];
  1067. my = mv->table_mvy[code];
  1068. }
  1069. mx += *mx_ptr - 32;
  1070. my += *my_ptr - 32;
  1071. /* WARNING : they do not do exactly modulo encoding */
  1072. if (mx <= -64)
  1073. mx += 64;
  1074. else if (mx >= 64)
  1075. mx -= 64;
  1076. if (my <= -64)
  1077. my += 64;
  1078. else if (my >= 64)
  1079. my -= 64;
  1080. *mx_ptr = mx;
  1081. *my_ptr = my;
  1082. return 0;
  1083. }
  1084. AVCodec ff_msmpeg4v1_decoder = {
  1085. .name = "msmpeg4v1",
  1086. .type = AVMEDIA_TYPE_VIDEO,
  1087. .id = AV_CODEC_ID_MSMPEG4V1,
  1088. .priv_data_size = sizeof(MpegEncContext),
  1089. .init = ff_msmpeg4_decode_init,
  1090. .close = ff_h263_decode_end,
  1091. .decode = ff_h263_decode_frame,
  1092. .capabilities = CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
  1093. .max_lowres = 3,
  1094. .long_name = NULL_IF_CONFIG_SMALL("MPEG-4 part 2 Microsoft variant version 1"),
  1095. .pix_fmts = ff_pixfmt_list_420,
  1096. };
  1097. AVCodec ff_msmpeg4v2_decoder = {
  1098. .name = "msmpeg4v2",
  1099. .type = AVMEDIA_TYPE_VIDEO,
  1100. .id = AV_CODEC_ID_MSMPEG4V2,
  1101. .priv_data_size = sizeof(MpegEncContext),
  1102. .init = ff_msmpeg4_decode_init,
  1103. .close = ff_h263_decode_end,
  1104. .decode = ff_h263_decode_frame,
  1105. .capabilities = CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
  1106. .max_lowres = 3,
  1107. .long_name = NULL_IF_CONFIG_SMALL("MPEG-4 part 2 Microsoft variant version 2"),
  1108. .pix_fmts = ff_pixfmt_list_420,
  1109. };
  1110. AVCodec ff_msmpeg4v3_decoder = {
  1111. .name = "msmpeg4",
  1112. .type = AVMEDIA_TYPE_VIDEO,
  1113. .id = AV_CODEC_ID_MSMPEG4V3,
  1114. .priv_data_size = sizeof(MpegEncContext),
  1115. .init = ff_msmpeg4_decode_init,
  1116. .close = ff_h263_decode_end,
  1117. .decode = ff_h263_decode_frame,
  1118. .capabilities = CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
  1119. .max_lowres = 3,
  1120. .long_name = NULL_IF_CONFIG_SMALL("MPEG-4 part 2 Microsoft variant version 3"),
  1121. .pix_fmts = ff_pixfmt_list_420,
  1122. };
  1123. AVCodec ff_wmv1_decoder = {
  1124. .name = "wmv1",
  1125. .type = AVMEDIA_TYPE_VIDEO,
  1126. .id = AV_CODEC_ID_WMV1,
  1127. .priv_data_size = sizeof(MpegEncContext),
  1128. .init = ff_msmpeg4_decode_init,
  1129. .close = ff_h263_decode_end,
  1130. .decode = ff_h263_decode_frame,
  1131. .capabilities = CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
  1132. .max_lowres = 3,
  1133. .long_name = NULL_IF_CONFIG_SMALL("Windows Media Video 7"),
  1134. .pix_fmts = ff_pixfmt_list_420,
  1135. };