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.

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