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.

4693 lines
156KB

  1. /*
  2. * H263/MPEG4 backend for ffmpeg encoder and decoder
  3. * Copyright (c) 2000,2001 Fabrice Bellard.
  4. * H263+ support.
  5. * Copyright (c) 2001 Juan J. Sierralta P.
  6. *
  7. * This library is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU Lesser General Public
  9. * License as published by the Free Software Foundation; either
  10. * version 2 of the License, or (at your option) any later version.
  11. *
  12. * This library is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * Lesser General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Lesser General Public
  18. * License along with this library; if not, write to the Free Software
  19. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  20. *
  21. * ac prediction encoding, b-frame support, error resilience, optimizations,
  22. * qpel decoding, gmc decoding, interlaced decoding,
  23. * by Michael Niedermayer <michaelni@gmx.at>
  24. */
  25. //#define DEBUG
  26. #include "common.h"
  27. #include "dsputil.h"
  28. #include "avcodec.h"
  29. #include "mpegvideo.h"
  30. #include "h263data.h"
  31. #include "mpeg4data.h"
  32. //#undef NDEBUG
  33. //#include <assert.h>
  34. #if 1
  35. #define PRINT_MB_TYPE(a) {}
  36. #else
  37. #define PRINT_MB_TYPE(a) printf(a)
  38. #endif
  39. #define INTRA_MCBPC_VLC_BITS 6
  40. #define INTER_MCBPC_VLC_BITS 6
  41. #define CBPY_VLC_BITS 6
  42. #define MV_VLC_BITS 9
  43. #define DC_VLC_BITS 9
  44. #define SPRITE_TRAJ_VLC_BITS 6
  45. #define MB_TYPE_B_VLC_BITS 4
  46. #define TEX_VLC_BITS 9
  47. #ifdef CONFIG_ENCODERS
  48. static void h263_encode_block(MpegEncContext * s, DCTELEM * block,
  49. int n);
  50. static void h263_encode_motion(MpegEncContext * s, int val, int fcode);
  51. static void h263p_encode_umotion(MpegEncContext * s, int val);
  52. static inline void mpeg4_encode_block(MpegEncContext * s, DCTELEM * block,
  53. int n, int dc, UINT8 *scan_table,
  54. PutBitContext *dc_pb, PutBitContext *ac_pb);
  55. #endif
  56. static int h263_decode_motion(MpegEncContext * s, int pred, int fcode);
  57. static int h263p_decode_umotion(MpegEncContext * s, int pred);
  58. static int h263_decode_block(MpegEncContext * s, DCTELEM * block,
  59. int n, int coded);
  60. static inline int mpeg4_decode_dc(MpegEncContext * s, int n, int *dir_ptr);
  61. static inline int mpeg4_decode_block(MpegEncContext * s, DCTELEM * block,
  62. int n, int coded, int intra);
  63. static int h263_pred_dc(MpegEncContext * s, int n, UINT16 **dc_val_ptr);
  64. static void mpeg4_inv_pred_ac(MpegEncContext * s, INT16 *block, int n,
  65. int dir);
  66. static void mpeg4_decode_sprite_trajectory(MpegEncContext * s);
  67. static inline int ff_mpeg4_pred_dc(MpegEncContext * s, int n, UINT16 **dc_val_ptr, int *dir_ptr);
  68. extern UINT32 inverse[256];
  69. static UINT16 uni_DCtab_lum [512][2];
  70. static UINT16 uni_DCtab_chrom[512][2];
  71. #ifdef CONFIG_ENCODERS
  72. static UINT16 (*mv_penalty)[MAX_MV*2+1]= NULL;
  73. static UINT8 fcode_tab[MAX_MV*2+1];
  74. static UINT8 umv_fcode_tab[MAX_MV*2+1];
  75. static UINT32 uni_mpeg4_intra_rl_bits[64*64*2*2];
  76. static UINT8 uni_mpeg4_intra_rl_len [64*64*2*2];
  77. static UINT32 uni_mpeg4_inter_rl_bits[64*64*2*2];
  78. static UINT8 uni_mpeg4_inter_rl_len [64*64*2*2];
  79. #define UNI_MPEG4_ENC_INDEX(last,run,level) ((last)*128 + (run)*256 + (level))
  80. //#define UNI_MPEG4_ENC_INDEX(last,run,level) ((last)*128*64 + (run) + (level)*64)
  81. /* mpeg4
  82. inter
  83. max level: 24/6
  84. max run: 53/63
  85. intra
  86. max level: 53/16
  87. max run: 29/41
  88. */
  89. #endif
  90. int h263_get_picture_format(int width, int height)
  91. {
  92. int format;
  93. if (width == 128 && height == 96)
  94. format = 1;
  95. else if (width == 176 && height == 144)
  96. format = 2;
  97. else if (width == 352 && height == 288)
  98. format = 3;
  99. else if (width == 704 && height == 576)
  100. format = 4;
  101. else if (width == 1408 && height == 1152)
  102. format = 5;
  103. else
  104. format = 7;
  105. return format;
  106. }
  107. static void float_aspect_to_info(MpegEncContext * s, float aspect){
  108. int i;
  109. aspect*= s->height/(double)s->width;
  110. //printf("%f\n", aspect);
  111. if(aspect==0) aspect= 1.0;
  112. ff_float2fraction(&s->aspected_width, &s->aspected_height, aspect, 255);
  113. //printf("%d %d\n", s->aspected_width, s->aspected_height);
  114. for(i=1; i<6; i++){
  115. if(s->aspected_width == pixel_aspect[i][0] && s->aspected_height== pixel_aspect[i][1]){
  116. s->aspect_ratio_info=i;
  117. return;
  118. }
  119. }
  120. s->aspect_ratio_info= FF_ASPECT_EXTENDED;
  121. }
  122. void h263_encode_picture_header(MpegEncContext * s, int picture_number)
  123. {
  124. int format;
  125. align_put_bits(&s->pb);
  126. /* Update the pointer to last GOB */
  127. s->ptr_lastgob = pbBufPtr(&s->pb);
  128. s->gob_number = 0;
  129. put_bits(&s->pb, 22, 0x20); /* PSC */
  130. put_bits(&s->pb, 8, (((INT64)s->picture_number * 30 * FRAME_RATE_BASE) /
  131. s->frame_rate) & 0xff);
  132. put_bits(&s->pb, 1, 1); /* marker */
  133. put_bits(&s->pb, 1, 0); /* h263 id */
  134. put_bits(&s->pb, 1, 0); /* split screen off */
  135. put_bits(&s->pb, 1, 0); /* camera off */
  136. put_bits(&s->pb, 1, 0); /* freeze picture release off */
  137. format = h263_get_picture_format(s->width, s->height);
  138. if (!s->h263_plus) {
  139. /* H.263v1 */
  140. put_bits(&s->pb, 3, format);
  141. put_bits(&s->pb, 1, (s->pict_type == P_TYPE));
  142. /* By now UMV IS DISABLED ON H.263v1, since the restrictions
  143. of H.263v1 UMV implies to check the predicted MV after
  144. calculation of the current MB to see if we're on the limits */
  145. put_bits(&s->pb, 1, 0); /* unrestricted motion vector: off */
  146. put_bits(&s->pb, 1, 0); /* SAC: off */
  147. put_bits(&s->pb, 1, 0); /* advanced prediction mode: off */
  148. put_bits(&s->pb, 1, 0); /* not PB frame */
  149. put_bits(&s->pb, 5, s->qscale);
  150. put_bits(&s->pb, 1, 0); /* Continuous Presence Multipoint mode: off */
  151. } else {
  152. /* H.263v2 */
  153. /* H.263 Plus PTYPE */
  154. put_bits(&s->pb, 3, 7);
  155. put_bits(&s->pb,3,1); /* Update Full Extended PTYPE */
  156. if (format == 7)
  157. put_bits(&s->pb,3,6); /* Custom Source Format */
  158. else
  159. put_bits(&s->pb, 3, format);
  160. put_bits(&s->pb,1,0); /* Custom PCF: off */
  161. s->umvplus = (s->pict_type == P_TYPE) && s->unrestricted_mv;
  162. put_bits(&s->pb, 1, s->umvplus); /* Unrestricted Motion Vector */
  163. put_bits(&s->pb,1,0); /* SAC: off */
  164. put_bits(&s->pb,1,0); /* Advanced Prediction Mode: off */
  165. put_bits(&s->pb,1,s->h263_aic); /* Advanced Intra Coding */
  166. put_bits(&s->pb,1,0); /* Deblocking Filter: off */
  167. put_bits(&s->pb,1,0); /* Slice Structured: off */
  168. put_bits(&s->pb,1,0); /* Reference Picture Selection: off */
  169. put_bits(&s->pb,1,0); /* Independent Segment Decoding: off */
  170. put_bits(&s->pb,1,0); /* Alternative Inter VLC: off */
  171. put_bits(&s->pb,1,0); /* Modified Quantization: off */
  172. put_bits(&s->pb,1,1); /* "1" to prevent start code emulation */
  173. put_bits(&s->pb,3,0); /* Reserved */
  174. put_bits(&s->pb, 3, s->pict_type == P_TYPE);
  175. put_bits(&s->pb,1,0); /* Reference Picture Resampling: off */
  176. put_bits(&s->pb,1,0); /* Reduced-Resolution Update: off */
  177. if (s->pict_type == I_TYPE)
  178. s->no_rounding = 0;
  179. else
  180. s->no_rounding ^= 1;
  181. put_bits(&s->pb,1,s->no_rounding); /* Rounding Type */
  182. put_bits(&s->pb,2,0); /* Reserved */
  183. put_bits(&s->pb,1,1); /* "1" to prevent start code emulation */
  184. /* This should be here if PLUSPTYPE */
  185. put_bits(&s->pb, 1, 0); /* Continuous Presence Multipoint mode: off */
  186. if (format == 7) {
  187. /* Custom Picture Format (CPFMT) */
  188. float_aspect_to_info(s, s->avctx->aspect_ratio);
  189. put_bits(&s->pb,4,s->aspect_ratio_info);
  190. put_bits(&s->pb,9,(s->width >> 2) - 1);
  191. put_bits(&s->pb,1,1); /* "1" to prevent start code emulation */
  192. put_bits(&s->pb,9,(s->height >> 2));
  193. if (s->aspect_ratio_info == FF_ASPECT_EXTENDED)
  194. {
  195. put_bits(&s->pb, 8, s->aspected_width);
  196. put_bits(&s->pb, 8, s->aspected_height);
  197. }
  198. }
  199. /* Unlimited Unrestricted Motion Vectors Indicator (UUI) */
  200. if (s->umvplus)
  201. put_bits(&s->pb,1,1); /* Limited according tables of Annex D */
  202. put_bits(&s->pb, 5, s->qscale);
  203. }
  204. put_bits(&s->pb, 1, 0); /* no PEI */
  205. if(s->h263_aic){
  206. s->y_dc_scale_table=
  207. s->c_dc_scale_table= h263_aic_dc_scale_table;
  208. }else{
  209. s->y_dc_scale_table=
  210. s->c_dc_scale_table= ff_mpeg1_dc_scale_table;
  211. }
  212. }
  213. /**
  214. * Encodes a group of blocks header.
  215. */
  216. int h263_encode_gob_header(MpegEncContext * s, int mb_line)
  217. {
  218. align_put_bits(&s->pb);
  219. flush_put_bits(&s->pb);
  220. /* Call the RTP callback to send the last GOB */
  221. if (s->rtp_callback) {
  222. int pdif = pbBufPtr(&s->pb) - s->ptr_lastgob;
  223. s->rtp_callback(s->ptr_lastgob, pdif, s->gob_number);
  224. }
  225. put_bits(&s->pb, 17, 1); /* GBSC */
  226. s->gob_number = mb_line / s->gob_index;
  227. put_bits(&s->pb, 5, s->gob_number); /* GN */
  228. put_bits(&s->pb, 2, s->pict_type == I_TYPE); /* GFID */
  229. put_bits(&s->pb, 5, s->qscale); /* GQUANT */
  230. //fprintf(stderr,"\nGOB: %2d size: %d", s->gob_number - 1, pdif);
  231. return 0;
  232. }
  233. static inline int decide_ac_pred(MpegEncContext * s, DCTELEM block[6][64], int dir[6])
  234. {
  235. int score0=0, score1=0;
  236. int i, n;
  237. for(n=0; n<6; n++){
  238. INT16 *ac_val, *ac_val1;
  239. ac_val = s->ac_val[0][0] + s->block_index[n] * 16;
  240. ac_val1= ac_val;
  241. if(dir[n]){
  242. const int xy= s->mb_x + s->mb_y*s->mb_width - s->mb_width;
  243. /* top prediction */
  244. ac_val-= s->block_wrap[n]*16;
  245. if(s->mb_y==0 || s->qscale == s->qscale_table[xy] || n==2 || n==3){
  246. /* same qscale */
  247. for(i=1; i<8; i++){
  248. const int level= block[n][s->idct_permutation[i ]];
  249. score0+= ABS(level);
  250. score1+= ABS(level - ac_val[i+8]);
  251. ac_val1[i ]= block[n][s->idct_permutation[i<<3]];
  252. ac_val1[i+8]= level;
  253. }
  254. }else{
  255. /* different qscale, we must rescale */
  256. for(i=1; i<8; i++){
  257. const int level= block[n][s->idct_permutation[i ]];
  258. score0+= ABS(level);
  259. score1+= ABS(level - ROUNDED_DIV(ac_val[i + 8]*s->qscale_table[xy], s->qscale));
  260. ac_val1[i ]= block[n][s->idct_permutation[i<<3]];
  261. ac_val1[i+8]= level;
  262. }
  263. }
  264. }else{
  265. const int xy= s->mb_x-1 + s->mb_y*s->mb_width;
  266. /* left prediction */
  267. ac_val-= 16;
  268. if(s->mb_x==0 || s->qscale == s->qscale_table[xy] || n==1 || n==3){
  269. /* same qscale */
  270. for(i=1; i<8; i++){
  271. const int level= block[n][s->idct_permutation[i<<3]];
  272. score0+= ABS(level);
  273. score1+= ABS(level - ac_val[i]);
  274. ac_val1[i ]= level;
  275. ac_val1[i+8]= block[n][s->idct_permutation[i ]];
  276. }
  277. }else{
  278. /* different qscale, we must rescale */
  279. for(i=1; i<8; i++){
  280. const int level= block[n][s->idct_permutation[i<<3]];
  281. score0+= ABS(level);
  282. score1+= ABS(level - ROUNDED_DIV(ac_val[i]*s->qscale_table[xy], s->qscale));
  283. ac_val1[i ]= level;
  284. ac_val1[i+8]= block[n][s->idct_permutation[i ]];
  285. }
  286. }
  287. }
  288. }
  289. return score0 > score1 ? 1 : 0;
  290. }
  291. /**
  292. * modify qscale so that encoding is acually possible in h263 (limit difference to -2..2)
  293. */
  294. void ff_clean_h263_qscales(MpegEncContext *s){
  295. int i;
  296. for(i=1; i<s->mb_num; i++){
  297. if(s->qscale_table[i] - s->qscale_table[i-1] >2)
  298. s->qscale_table[i]= s->qscale_table[i-1]+2;
  299. }
  300. for(i=s->mb_num-2; i>=0; i--){
  301. if(s->qscale_table[i] - s->qscale_table[i+1] >2)
  302. s->qscale_table[i]= s->qscale_table[i+1]+2;
  303. }
  304. }
  305. /**
  306. * modify mb_type & qscale so that encoding is acually possible in mpeg4
  307. */
  308. void ff_clean_mpeg4_qscales(MpegEncContext *s){
  309. int i;
  310. ff_clean_h263_qscales(s);
  311. for(i=1; i<s->mb_num; i++){
  312. if(s->qscale_table[i] != s->qscale_table[i-1] && (s->mb_type[i]&MB_TYPE_INTER4V)){
  313. s->mb_type[i]&= ~MB_TYPE_INTER4V;
  314. s->mb_type[i]|= MB_TYPE_INTER;
  315. }
  316. }
  317. if(s->pict_type== B_TYPE){
  318. int odd=0;
  319. /* ok, come on, this isnt funny anymore, theres more code for handling this mpeg4 mess than
  320. for the actual adaptive quantization */
  321. for(i=0; i<s->mb_num; i++){
  322. odd += s->qscale_table[i]&1;
  323. }
  324. if(2*odd > s->mb_num) odd=1;
  325. else odd=0;
  326. for(i=0; i<s->mb_num; i++){
  327. if((s->qscale_table[i]&1) != odd)
  328. s->qscale_table[i]++;
  329. if(s->qscale_table[i] > 31)
  330. s->qscale_table[i]= 31;
  331. }
  332. for(i=1; i<s->mb_num; i++){
  333. if(s->qscale_table[i] != s->qscale_table[i-1] && (s->mb_type[i]&MB_TYPE_DIRECT)){
  334. s->mb_type[i]&= ~MB_TYPE_DIRECT;
  335. s->mb_type[i]|= MB_TYPE_BIDIR;
  336. }
  337. }
  338. }
  339. }
  340. #ifdef CONFIG_ENCODERS
  341. void mpeg4_encode_mb(MpegEncContext * s,
  342. DCTELEM block[6][64],
  343. int motion_x, int motion_y)
  344. {
  345. int cbpc, cbpy, i, pred_x, pred_y;
  346. int bits;
  347. PutBitContext * const pb2 = s->data_partitioning ? &s->pb2 : &s->pb;
  348. PutBitContext * const tex_pb = s->data_partitioning && s->pict_type!=B_TYPE ? &s->tex_pb : &s->pb;
  349. PutBitContext * const dc_pb = s->data_partitioning && s->pict_type!=I_TYPE ? &s->pb2 : &s->pb;
  350. const int interleaved_stats= (s->flags&CODEC_FLAG_PASS1) && !s->data_partitioning ? 1 : 0;
  351. const int dquant_code[5]= {1,0,9,2,3};
  352. // printf("**mb x=%d y=%d\n", s->mb_x, s->mb_y);
  353. if (!s->mb_intra) {
  354. /* compute cbp */
  355. int cbp = 0;
  356. for (i = 0; i < 6; i++) {
  357. if (s->block_last_index[i] >= 0)
  358. cbp |= 1 << (5 - i);
  359. }
  360. if(s->pict_type==B_TYPE){
  361. static const int mb_type_table[8]= {-1, 2, 3, 1,-1,-1,-1, 0}; /* convert from mv_dir to type */
  362. int mb_type= mb_type_table[s->mv_dir];
  363. if(s->mb_x==0){
  364. s->last_mv[0][0][0]=
  365. s->last_mv[0][0][1]=
  366. s->last_mv[1][0][0]=
  367. s->last_mv[1][0][1]= 0;
  368. }
  369. assert(s->dquant>=-2 && s->dquant<=2);
  370. assert((s->dquant&1)==0);
  371. assert(mb_type>=0);
  372. /* nothing to do if this MB was skiped in the next P Frame */
  373. if(s->mbskip_table[s->mb_y * s->mb_width + s->mb_x]){ //FIXME avoid DCT & ...
  374. s->skip_count++;
  375. s->mv[0][0][0]=
  376. s->mv[0][0][1]=
  377. s->mv[1][0][0]=
  378. s->mv[1][0][1]= 0;
  379. s->mv_dir= MV_DIR_FORWARD; //doesnt matter
  380. s->qscale -= s->dquant;
  381. return;
  382. }
  383. if ((cbp | motion_x | motion_y | mb_type) ==0) {
  384. /* direct MB with MV={0,0} */
  385. assert(s->dquant==0);
  386. put_bits(&s->pb, 1, 1); /* mb not coded modb1=1 */
  387. if(interleaved_stats){
  388. s->misc_bits++;
  389. s->last_bits++;
  390. }
  391. s->skip_count++;
  392. return;
  393. }
  394. put_bits(&s->pb, 1, 0); /* mb coded modb1=0 */
  395. put_bits(&s->pb, 1, cbp ? 0 : 1); /* modb2 */ //FIXME merge
  396. put_bits(&s->pb, mb_type+1, 1); // this table is so simple that we dont need it :)
  397. if(cbp) put_bits(&s->pb, 6, cbp);
  398. if(cbp && mb_type){
  399. if(s->dquant)
  400. put_bits(&s->pb, 2, (s->dquant>>2)+3);
  401. else
  402. put_bits(&s->pb, 1, 0);
  403. }else
  404. s->qscale -= s->dquant;
  405. if(!s->progressive_sequence){
  406. if(cbp)
  407. put_bits(&s->pb, 1, s->interlaced_dct);
  408. if(mb_type) // not diect mode
  409. put_bits(&s->pb, 1, 0); // no interlaced ME yet
  410. }
  411. if(interleaved_stats){
  412. bits= get_bit_count(&s->pb);
  413. s->misc_bits+= bits - s->last_bits;
  414. s->last_bits=bits;
  415. }
  416. switch(mb_type)
  417. {
  418. case 0: /* direct */
  419. h263_encode_motion(s, motion_x, 1);
  420. h263_encode_motion(s, motion_y, 1);
  421. s->b_count++;
  422. s->f_count++;
  423. break;
  424. case 1: /* bidir */
  425. h263_encode_motion(s, s->mv[0][0][0] - s->last_mv[0][0][0], s->f_code);
  426. h263_encode_motion(s, s->mv[0][0][1] - s->last_mv[0][0][1], s->f_code);
  427. h263_encode_motion(s, s->mv[1][0][0] - s->last_mv[1][0][0], s->b_code);
  428. h263_encode_motion(s, s->mv[1][0][1] - s->last_mv[1][0][1], s->b_code);
  429. s->last_mv[0][0][0]= s->mv[0][0][0];
  430. s->last_mv[0][0][1]= s->mv[0][0][1];
  431. s->last_mv[1][0][0]= s->mv[1][0][0];
  432. s->last_mv[1][0][1]= s->mv[1][0][1];
  433. s->b_count++;
  434. s->f_count++;
  435. break;
  436. case 2: /* backward */
  437. h263_encode_motion(s, motion_x - s->last_mv[1][0][0], s->b_code);
  438. h263_encode_motion(s, motion_y - s->last_mv[1][0][1], s->b_code);
  439. s->last_mv[1][0][0]= motion_x;
  440. s->last_mv[1][0][1]= motion_y;
  441. s->b_count++;
  442. break;
  443. case 3: /* forward */
  444. h263_encode_motion(s, motion_x - s->last_mv[0][0][0], s->f_code);
  445. h263_encode_motion(s, motion_y - s->last_mv[0][0][1], s->f_code);
  446. s->last_mv[0][0][0]= motion_x;
  447. s->last_mv[0][0][1]= motion_y;
  448. s->f_count++;
  449. break;
  450. default:
  451. printf("unknown mb type\n");
  452. return;
  453. }
  454. if(interleaved_stats){
  455. bits= get_bit_count(&s->pb);
  456. s->mv_bits+= bits - s->last_bits;
  457. s->last_bits=bits;
  458. }
  459. /* encode each block */
  460. for (i = 0; i < 6; i++) {
  461. mpeg4_encode_block(s, block[i], i, 0, s->intra_scantable.permutated, NULL, &s->pb);
  462. }
  463. if(interleaved_stats){
  464. bits= get_bit_count(&s->pb);
  465. s->p_tex_bits+= bits - s->last_bits;
  466. s->last_bits=bits;
  467. }
  468. }else{ /* s->pict_type==B_TYPE */
  469. if ((cbp | motion_x | motion_y | s->dquant) == 0 && s->mv_type==MV_TYPE_16X16) {
  470. /* check if the B frames can skip it too, as we must skip it if we skip here
  471. why didnt they just compress the skip-mb bits instead of reusing them ?! */
  472. if(s->max_b_frames>0){
  473. int i;
  474. int x,y, offset;
  475. uint8_t *p_pic;
  476. x= s->mb_x*16;
  477. y= s->mb_y*16;
  478. if(x+16 > s->width) x= s->width-16;
  479. if(y+16 > s->height) y= s->height-16;
  480. offset= x + y*s->linesize;
  481. p_pic= s->new_picture[0] + offset;
  482. s->mb_skiped=1;
  483. for(i=0; i<s->max_b_frames; i++){
  484. uint8_t *b_pic;
  485. int diff;
  486. if(s->coded_order[i+1].pict_type!=B_TYPE) break;
  487. b_pic= s->coded_order[i+1].picture[0] + offset;
  488. diff= s->dsp.pix_abs16x16(p_pic, b_pic, s->linesize);
  489. if(diff>s->qscale*70){ //FIXME check that 70 is optimal
  490. s->mb_skiped=0;
  491. break;
  492. }
  493. }
  494. }else
  495. s->mb_skiped=1;
  496. if(s->mb_skiped==1){
  497. /* skip macroblock */
  498. put_bits(&s->pb, 1, 1);
  499. if(interleaved_stats){
  500. s->misc_bits++;
  501. s->last_bits++;
  502. }
  503. s->skip_count++;
  504. return;
  505. }
  506. }
  507. put_bits(&s->pb, 1, 0); /* mb coded */
  508. if(s->mv_type==MV_TYPE_16X16){
  509. cbpc = cbp & 3;
  510. if(s->dquant) cbpc+= 8;
  511. put_bits(&s->pb,
  512. inter_MCBPC_bits[cbpc],
  513. inter_MCBPC_code[cbpc]);
  514. cbpy = cbp >> 2;
  515. cbpy ^= 0xf;
  516. put_bits(pb2, cbpy_tab[cbpy][1], cbpy_tab[cbpy][0]);
  517. if(s->dquant)
  518. put_bits(pb2, 2, dquant_code[s->dquant+2]);
  519. if(!s->progressive_sequence){
  520. if(cbp)
  521. put_bits(pb2, 1, s->interlaced_dct);
  522. put_bits(pb2, 1, 0); // no interlaced ME yet
  523. }
  524. if(interleaved_stats){
  525. bits= get_bit_count(&s->pb);
  526. s->misc_bits+= bits - s->last_bits;
  527. s->last_bits=bits;
  528. }
  529. /* motion vectors: 16x16 mode */
  530. h263_pred_motion(s, 0, &pred_x, &pred_y);
  531. h263_encode_motion(s, motion_x - pred_x, s->f_code);
  532. h263_encode_motion(s, motion_y - pred_y, s->f_code);
  533. }else{
  534. cbpc = (cbp & 3)+16;
  535. put_bits(&s->pb,
  536. inter_MCBPC_bits[cbpc],
  537. inter_MCBPC_code[cbpc]);
  538. cbpy = cbp >> 2;
  539. cbpy ^= 0xf;
  540. put_bits(pb2, cbpy_tab[cbpy][1], cbpy_tab[cbpy][0]);
  541. if(!s->progressive_sequence){
  542. if(cbp)
  543. put_bits(pb2, 1, s->interlaced_dct);
  544. }
  545. if(interleaved_stats){
  546. bits= get_bit_count(&s->pb);
  547. s->misc_bits+= bits - s->last_bits;
  548. s->last_bits=bits;
  549. }
  550. for(i=0; i<4; i++){
  551. /* motion vectors: 8x8 mode*/
  552. h263_pred_motion(s, i, &pred_x, &pred_y);
  553. h263_encode_motion(s, s->motion_val[ s->block_index[i] ][0] - pred_x, s->f_code);
  554. h263_encode_motion(s, s->motion_val[ s->block_index[i] ][1] - pred_y, s->f_code);
  555. }
  556. }
  557. if(interleaved_stats){
  558. bits= get_bit_count(&s->pb);
  559. s->mv_bits+= bits - s->last_bits;
  560. s->last_bits=bits;
  561. }
  562. /* encode each block */
  563. for (i = 0; i < 6; i++) {
  564. mpeg4_encode_block(s, block[i], i, 0, s->intra_scantable.permutated, NULL, tex_pb);
  565. }
  566. if(interleaved_stats){
  567. bits= get_bit_count(&s->pb);
  568. s->p_tex_bits+= bits - s->last_bits;
  569. s->last_bits=bits;
  570. }
  571. s->f_count++;
  572. }
  573. } else {
  574. int cbp;
  575. int dc_diff[6]; //dc values with the dc prediction subtracted
  576. int dir[6]; //prediction direction
  577. int zigzag_last_index[6];
  578. UINT8 *scan_table[6];
  579. for(i=0; i<6; i++){
  580. const int level= block[i][0];
  581. UINT16 *dc_ptr;
  582. dc_diff[i]= level - ff_mpeg4_pred_dc(s, i, &dc_ptr, &dir[i]);
  583. if (i < 4) {
  584. *dc_ptr = level * s->y_dc_scale;
  585. } else {
  586. *dc_ptr = level * s->c_dc_scale;
  587. }
  588. }
  589. s->ac_pred= decide_ac_pred(s, block, dir);
  590. if(s->ac_pred){
  591. for(i=0; i<6; i++){
  592. UINT8 *st;
  593. int last_index;
  594. mpeg4_inv_pred_ac(s, block[i], i, dir[i]);
  595. if (dir[i]==0) st = s->intra_v_scantable.permutated; /* left */
  596. else st = s->intra_h_scantable.permutated; /* top */
  597. for(last_index=63; last_index>=0; last_index--) //FIXME optimize
  598. if(block[i][st[last_index]]) break;
  599. zigzag_last_index[i]= s->block_last_index[i];
  600. s->block_last_index[i]= last_index;
  601. scan_table[i]= st;
  602. }
  603. }else{
  604. for(i=0; i<6; i++)
  605. scan_table[i]= s->intra_scantable.permutated;
  606. }
  607. /* compute cbp */
  608. cbp = 0;
  609. for (i = 0; i < 6; i++) {
  610. if (s->block_last_index[i] >= 1)
  611. cbp |= 1 << (5 - i);
  612. }
  613. cbpc = cbp & 3;
  614. if (s->pict_type == I_TYPE) {
  615. if(s->dquant) cbpc+=4;
  616. put_bits(&s->pb,
  617. intra_MCBPC_bits[cbpc],
  618. intra_MCBPC_code[cbpc]);
  619. } else {
  620. if(s->dquant) cbpc+=8;
  621. put_bits(&s->pb, 1, 0); /* mb coded */
  622. put_bits(&s->pb,
  623. inter_MCBPC_bits[cbpc + 4],
  624. inter_MCBPC_code[cbpc + 4]);
  625. }
  626. put_bits(pb2, 1, s->ac_pred);
  627. cbpy = cbp >> 2;
  628. put_bits(pb2, cbpy_tab[cbpy][1], cbpy_tab[cbpy][0]);
  629. if(s->dquant)
  630. put_bits(dc_pb, 2, dquant_code[s->dquant+2]);
  631. if(!s->progressive_sequence){
  632. put_bits(dc_pb, 1, s->interlaced_dct);
  633. }
  634. if(interleaved_stats){
  635. bits= get_bit_count(&s->pb);
  636. s->misc_bits+= bits - s->last_bits;
  637. s->last_bits=bits;
  638. }
  639. /* encode each block */
  640. for (i = 0; i < 6; i++) {
  641. mpeg4_encode_block(s, block[i], i, dc_diff[i], scan_table[i], dc_pb, tex_pb);
  642. }
  643. if(interleaved_stats){
  644. bits= get_bit_count(&s->pb);
  645. s->i_tex_bits+= bits - s->last_bits;
  646. s->last_bits=bits;
  647. }
  648. s->i_count++;
  649. /* restore ac coeffs & last_index stuff if we messed them up with the prediction */
  650. if(s->ac_pred){
  651. for(i=0; i<6; i++){
  652. int j;
  653. INT16 *ac_val;
  654. ac_val = s->ac_val[0][0] + s->block_index[i] * 16;
  655. if(dir[i]){
  656. for(j=1; j<8; j++)
  657. block[i][s->idct_permutation[j ]]= ac_val[j+8];
  658. }else{
  659. for(j=1; j<8; j++)
  660. block[i][s->idct_permutation[j<<3]]= ac_val[j ];
  661. }
  662. s->block_last_index[i]= zigzag_last_index[i];
  663. }
  664. }
  665. }
  666. }
  667. void h263_encode_mb(MpegEncContext * s,
  668. DCTELEM block[6][64],
  669. int motion_x, int motion_y)
  670. {
  671. int cbpc, cbpy, i, cbp, pred_x, pred_y;
  672. INT16 pred_dc;
  673. INT16 rec_intradc[6];
  674. UINT16 *dc_ptr[6];
  675. const int dquant_code[5]= {1,0,9,2,3};
  676. //printf("**mb x=%d y=%d\n", s->mb_x, s->mb_y);
  677. if (!s->mb_intra) {
  678. /* compute cbp */
  679. cbp = 0;
  680. for (i = 0; i < 6; i++) {
  681. if (s->block_last_index[i] >= 0)
  682. cbp |= 1 << (5 - i);
  683. }
  684. if ((cbp | motion_x | motion_y | s->dquant) == 0) {
  685. /* skip macroblock */
  686. put_bits(&s->pb, 1, 1);
  687. return;
  688. }
  689. put_bits(&s->pb, 1, 0); /* mb coded */
  690. cbpc = cbp & 3;
  691. if(s->dquant) cbpc+= 8;
  692. put_bits(&s->pb,
  693. inter_MCBPC_bits[cbpc],
  694. inter_MCBPC_code[cbpc]);
  695. cbpy = cbp >> 2;
  696. cbpy ^= 0xf;
  697. put_bits(&s->pb, cbpy_tab[cbpy][1], cbpy_tab[cbpy][0]);
  698. if(s->dquant)
  699. put_bits(&s->pb, 2, dquant_code[s->dquant+2]);
  700. /* motion vectors: 16x16 mode only now */
  701. h263_pred_motion(s, 0, &pred_x, &pred_y);
  702. if (!s->umvplus) {
  703. h263_encode_motion(s, motion_x - pred_x, s->f_code);
  704. h263_encode_motion(s, motion_y - pred_y, s->f_code);
  705. }
  706. else {
  707. h263p_encode_umotion(s, motion_x - pred_x);
  708. h263p_encode_umotion(s, motion_y - pred_y);
  709. if (((motion_x - pred_x) == 1) && ((motion_y - pred_y) == 1))
  710. /* To prevent Start Code emulation */
  711. put_bits(&s->pb,1,1);
  712. }
  713. } else {
  714. int li = s->h263_aic ? 0 : 1;
  715. cbp = 0;
  716. for(i=0; i<6; i++) {
  717. /* Predict DC */
  718. if (s->h263_aic && s->mb_intra) {
  719. INT16 level = block[i][0];
  720. pred_dc = h263_pred_dc(s, i, &dc_ptr[i]);
  721. level -= pred_dc;
  722. /* Quant */
  723. if (level < 0)
  724. level = (level + (s->qscale >> 1))/(s->y_dc_scale);
  725. else
  726. level = (level - (s->qscale >> 1))/(s->y_dc_scale);
  727. /* AIC can change CBP */
  728. if (level == 0 && s->block_last_index[i] == 0)
  729. s->block_last_index[i] = -1;
  730. else if (level < -127)
  731. level = -127;
  732. else if (level > 127)
  733. level = 127;
  734. block[i][0] = level;
  735. /* Reconstruction */
  736. rec_intradc[i] = (s->y_dc_scale*level) + pred_dc;
  737. /* Oddify */
  738. rec_intradc[i] |= 1;
  739. //if ((rec_intradc[i] % 2) == 0)
  740. // rec_intradc[i]++;
  741. /* Clipping */
  742. if (rec_intradc[i] < 0)
  743. rec_intradc[i] = 0;
  744. else if (rec_intradc[i] > 2047)
  745. rec_intradc[i] = 2047;
  746. /* Update AC/DC tables */
  747. *dc_ptr[i] = rec_intradc[i];
  748. }
  749. /* compute cbp */
  750. if (s->block_last_index[i] >= li)
  751. cbp |= 1 << (5 - i);
  752. }
  753. cbpc = cbp & 3;
  754. if (s->pict_type == I_TYPE) {
  755. if(s->dquant) cbpc+=4;
  756. put_bits(&s->pb,
  757. intra_MCBPC_bits[cbpc],
  758. intra_MCBPC_code[cbpc]);
  759. } else {
  760. if(s->dquant) cbpc+=8;
  761. put_bits(&s->pb, 1, 0); /* mb coded */
  762. put_bits(&s->pb,
  763. inter_MCBPC_bits[cbpc + 4],
  764. inter_MCBPC_code[cbpc + 4]);
  765. }
  766. if (s->h263_aic) {
  767. /* XXX: currently, we do not try to use ac prediction */
  768. put_bits(&s->pb, 1, 0); /* no AC prediction */
  769. }
  770. cbpy = cbp >> 2;
  771. put_bits(&s->pb, cbpy_tab[cbpy][1], cbpy_tab[cbpy][0]);
  772. if(s->dquant)
  773. put_bits(&s->pb, 2, dquant_code[s->dquant+2]);
  774. }
  775. for(i=0; i<6; i++) {
  776. /* encode each block */
  777. h263_encode_block(s, block[i], i);
  778. /* Update INTRADC for decoding */
  779. if (s->h263_aic && s->mb_intra) {
  780. block[i][0] = rec_intradc[i];
  781. }
  782. }
  783. }
  784. #endif
  785. static int h263_pred_dc(MpegEncContext * s, int n, UINT16 **dc_val_ptr)
  786. {
  787. int x, y, wrap, a, c, pred_dc, scale;
  788. INT16 *dc_val, *ac_val;
  789. /* find prediction */
  790. if (n < 4) {
  791. x = 2 * s->mb_x + 1 + (n & 1);
  792. y = 2 * s->mb_y + 1 + ((n & 2) >> 1);
  793. wrap = s->mb_width * 2 + 2;
  794. dc_val = s->dc_val[0];
  795. ac_val = s->ac_val[0][0];
  796. scale = s->y_dc_scale;
  797. } else {
  798. x = s->mb_x + 1;
  799. y = s->mb_y + 1;
  800. wrap = s->mb_width + 2;
  801. dc_val = s->dc_val[n - 4 + 1];
  802. ac_val = s->ac_val[n - 4 + 1][0];
  803. scale = s->c_dc_scale;
  804. }
  805. /* B C
  806. * A X
  807. */
  808. a = dc_val[(x - 1) + (y) * wrap];
  809. c = dc_val[(x) + (y - 1) * wrap];
  810. /* No prediction outside GOB boundary */
  811. if (s->first_slice_line && ((n < 2) || (n > 3)))
  812. c = 1024;
  813. pred_dc = 1024;
  814. /* just DC prediction */
  815. if (a != 1024 && c != 1024)
  816. pred_dc = (a + c) >> 1;
  817. else if (a != 1024)
  818. pred_dc = a;
  819. else
  820. pred_dc = c;
  821. /* we assume pred is positive */
  822. //pred_dc = (pred_dc + (scale >> 1)) / scale;
  823. *dc_val_ptr = &dc_val[x + y * wrap];
  824. return pred_dc;
  825. }
  826. void h263_pred_acdc(MpegEncContext * s, INT16 *block, int n)
  827. {
  828. int x, y, wrap, a, c, pred_dc, scale, i;
  829. INT16 *dc_val, *ac_val, *ac_val1;
  830. /* find prediction */
  831. if (n < 4) {
  832. x = 2 * s->mb_x + 1 + (n & 1);
  833. y = 2 * s->mb_y + 1 + ((n & 2) >> 1);
  834. wrap = s->mb_width * 2 + 2;
  835. dc_val = s->dc_val[0];
  836. ac_val = s->ac_val[0][0];
  837. scale = s->y_dc_scale;
  838. } else {
  839. x = s->mb_x + 1;
  840. y = s->mb_y + 1;
  841. wrap = s->mb_width + 2;
  842. dc_val = s->dc_val[n - 4 + 1];
  843. ac_val = s->ac_val[n - 4 + 1][0];
  844. scale = s->c_dc_scale;
  845. }
  846. ac_val += ((y) * wrap + (x)) * 16;
  847. ac_val1 = ac_val;
  848. /* B C
  849. * A X
  850. */
  851. a = dc_val[(x - 1) + (y) * wrap];
  852. c = dc_val[(x) + (y - 1) * wrap];
  853. /* No prediction outside GOB boundary */
  854. if (s->first_slice_line && ((n < 2) || (n > 3)))
  855. c = 1024;
  856. pred_dc = 1024;
  857. if (s->ac_pred) {
  858. if (s->h263_aic_dir) {
  859. /* left prediction */
  860. if (a != 1024) {
  861. ac_val -= 16;
  862. for(i=1;i<8;i++) {
  863. block[s->idct_permutation[i<<3]] += ac_val[i];
  864. }
  865. pred_dc = a;
  866. }
  867. } else {
  868. /* top prediction */
  869. if (c != 1024) {
  870. ac_val -= 16 * wrap;
  871. for(i=1;i<8;i++) {
  872. block[s->idct_permutation[i ]] += ac_val[i + 8];
  873. }
  874. pred_dc = c;
  875. }
  876. }
  877. } else {
  878. /* just DC prediction */
  879. if (a != 1024 && c != 1024)
  880. pred_dc = (a + c) >> 1;
  881. else if (a != 1024)
  882. pred_dc = a;
  883. else
  884. pred_dc = c;
  885. }
  886. /* we assume pred is positive */
  887. block[0]=block[0]*scale + pred_dc;
  888. if (block[0] < 0)
  889. block[0] = 0;
  890. else if (!(block[0] & 1))
  891. block[0]++;
  892. /* Update AC/DC tables */
  893. dc_val[(x) + (y) * wrap] = block[0];
  894. /* left copy */
  895. for(i=1;i<8;i++)
  896. ac_val1[i ] = block[s->idct_permutation[i<<3]];
  897. /* top copy */
  898. for(i=1;i<8;i++)
  899. ac_val1[8 + i] = block[s->idct_permutation[i ]];
  900. }
  901. INT16 *h263_pred_motion(MpegEncContext * s, int block,
  902. int *px, int *py)
  903. {
  904. int xy, wrap;
  905. INT16 *A, *B, *C, *mot_val;
  906. static const int off[4]= {2, 1, 1, -1};
  907. wrap = s->block_wrap[0];
  908. xy = s->block_index[block];
  909. mot_val = s->motion_val[xy];
  910. A = s->motion_val[xy - 1];
  911. /* special case for first (slice) line */
  912. if (s->first_slice_line && block<3) {
  913. // we cant just change some MVs to simulate that as we need them for the B frames (and ME)
  914. // and if we ever support non rectangular objects than we need to do a few ifs here anyway :(
  915. if(block==0){ //most common case
  916. if(s->mb_x == s->resync_mb_x){ //rare
  917. *px= *py = 0;
  918. }else if(s->mb_x + 1 == s->resync_mb_x){ //rare
  919. C = s->motion_val[xy + off[block] - wrap];
  920. if(s->mb_x==0){
  921. *px = C[0];
  922. *py = C[1];
  923. }else{
  924. *px = mid_pred(A[0], 0, C[0]);
  925. *py = mid_pred(A[1], 0, C[1]);
  926. }
  927. }else{
  928. *px = A[0];
  929. *py = A[1];
  930. }
  931. }else if(block==1){
  932. if(s->mb_x + 1 == s->resync_mb_x){ //rare
  933. C = s->motion_val[xy + off[block] - wrap];
  934. *px = mid_pred(A[0], 0, C[0]);
  935. *py = mid_pred(A[1], 0, C[1]);
  936. }else{
  937. *px = A[0];
  938. *py = A[1];
  939. }
  940. }else{ /* block==2*/
  941. B = s->motion_val[xy - wrap];
  942. C = s->motion_val[xy + off[block] - wrap];
  943. if(s->mb_x == s->resync_mb_x) //rare
  944. A[0]=A[1]=0;
  945. *px = mid_pred(A[0], B[0], C[0]);
  946. *py = mid_pred(A[1], B[1], C[1]);
  947. }
  948. } else {
  949. B = s->motion_val[xy - wrap];
  950. C = s->motion_val[xy + off[block] - wrap];
  951. *px = mid_pred(A[0], B[0], C[0]);
  952. *py = mid_pred(A[1], B[1], C[1]);
  953. }
  954. return mot_val;
  955. }
  956. #ifdef CONFIG_ENCODERS
  957. static void h263_encode_motion(MpegEncContext * s, int val, int f_code)
  958. {
  959. int range, l, bit_size, sign, code, bits;
  960. if (val == 0) {
  961. /* zero vector */
  962. code = 0;
  963. put_bits(&s->pb, mvtab[code][1], mvtab[code][0]);
  964. } else {
  965. bit_size = f_code - 1;
  966. range = 1 << bit_size;
  967. /* modulo encoding */
  968. l = range * 32;
  969. #if 1
  970. val+= l;
  971. val&= 2*l-1;
  972. val-= l;
  973. sign = val>>31;
  974. val= (val^sign)-sign;
  975. sign&=1;
  976. #else
  977. if (val < -l) {
  978. val += 2*l;
  979. } else if (val >= l) {
  980. val -= 2*l;
  981. }
  982. assert(val>=-l && val<l);
  983. if (val >= 0) {
  984. sign = 0;
  985. } else {
  986. val = -val;
  987. sign = 1;
  988. }
  989. #endif
  990. val--;
  991. code = (val >> bit_size) + 1;
  992. bits = val & (range - 1);
  993. put_bits(&s->pb, mvtab[code][1] + 1, (mvtab[code][0] << 1) | sign);
  994. if (bit_size > 0) {
  995. put_bits(&s->pb, bit_size, bits);
  996. }
  997. }
  998. }
  999. /* Encode MV differences on H.263+ with Unrestricted MV mode */
  1000. static void h263p_encode_umotion(MpegEncContext * s, int val)
  1001. {
  1002. short sval = 0;
  1003. short i = 0;
  1004. short n_bits = 0;
  1005. short temp_val;
  1006. int code = 0;
  1007. int tcode;
  1008. if ( val == 0)
  1009. put_bits(&s->pb, 1, 1);
  1010. else if (val == 1)
  1011. put_bits(&s->pb, 3, 0);
  1012. else if (val == -1)
  1013. put_bits(&s->pb, 3, 2);
  1014. else {
  1015. sval = ((val < 0) ? (short)(-val):(short)val);
  1016. temp_val = sval;
  1017. while (temp_val != 0) {
  1018. temp_val = temp_val >> 1;
  1019. n_bits++;
  1020. }
  1021. i = n_bits - 1;
  1022. while (i > 0) {
  1023. tcode = (sval & (1 << (i-1))) >> (i-1);
  1024. tcode = (tcode << 1) | 1;
  1025. code = (code << 2) | tcode;
  1026. i--;
  1027. }
  1028. code = ((code << 1) | (val < 0)) << 1;
  1029. put_bits(&s->pb, (2*n_bits)+1, code);
  1030. //printf("\nVal = %d\tCode = %d", sval, code);
  1031. }
  1032. }
  1033. static void init_mv_penalty_and_fcode(MpegEncContext *s)
  1034. {
  1035. int f_code;
  1036. int mv;
  1037. if(mv_penalty==NULL)
  1038. mv_penalty= av_mallocz( sizeof(UINT16)*(MAX_FCODE+1)*(2*MAX_MV+1) );
  1039. for(f_code=1; f_code<=MAX_FCODE; f_code++){
  1040. for(mv=-MAX_MV; mv<=MAX_MV; mv++){
  1041. int len;
  1042. if(mv==0) len= mvtab[0][1];
  1043. else{
  1044. int val, bit_size, range, code;
  1045. bit_size = s->f_code - 1;
  1046. range = 1 << bit_size;
  1047. val=mv;
  1048. if (val < 0)
  1049. val = -val;
  1050. val--;
  1051. code = (val >> bit_size) + 1;
  1052. if(code<33){
  1053. len= mvtab[code][1] + 1 + bit_size;
  1054. }else{
  1055. len= mvtab[32][1] + 2 + bit_size;
  1056. }
  1057. }
  1058. mv_penalty[f_code][mv+MAX_MV]= len;
  1059. }
  1060. }
  1061. for(f_code=MAX_FCODE; f_code>0; f_code--){
  1062. for(mv=-(16<<f_code); mv<(16<<f_code); mv++){
  1063. fcode_tab[mv+MAX_MV]= f_code;
  1064. }
  1065. }
  1066. for(mv=0; mv<MAX_MV*2+1; mv++){
  1067. umv_fcode_tab[mv]= 1;
  1068. }
  1069. }
  1070. #endif
  1071. static void init_uni_dc_tab(void)
  1072. {
  1073. int level, uni_code, uni_len;
  1074. for(level=-256; level<256; level++){
  1075. int size, v, l;
  1076. /* find number of bits */
  1077. size = 0;
  1078. v = abs(level);
  1079. while (v) {
  1080. v >>= 1;
  1081. size++;
  1082. }
  1083. if (level < 0)
  1084. l= (-level) ^ ((1 << size) - 1);
  1085. else
  1086. l= level;
  1087. /* luminance */
  1088. uni_code= DCtab_lum[size][0];
  1089. uni_len = DCtab_lum[size][1];
  1090. if (size > 0) {
  1091. uni_code<<=size; uni_code|=l;
  1092. uni_len+=size;
  1093. if (size > 8){
  1094. uni_code<<=1; uni_code|=1;
  1095. uni_len++;
  1096. }
  1097. }
  1098. uni_DCtab_lum[level+256][0]= uni_code;
  1099. uni_DCtab_lum[level+256][1]= uni_len;
  1100. /* chrominance */
  1101. uni_code= DCtab_chrom[size][0];
  1102. uni_len = DCtab_chrom[size][1];
  1103. if (size > 0) {
  1104. uni_code<<=size; uni_code|=l;
  1105. uni_len+=size;
  1106. if (size > 8){
  1107. uni_code<<=1; uni_code|=1;
  1108. uni_len++;
  1109. }
  1110. }
  1111. uni_DCtab_chrom[level+256][0]= uni_code;
  1112. uni_DCtab_chrom[level+256][1]= uni_len;
  1113. }
  1114. }
  1115. #ifdef CONFIG_ENCODERS
  1116. static void init_uni_mpeg4_rl_tab(RLTable *rl, UINT32 *bits_tab, UINT8 *len_tab){
  1117. int slevel, run, last;
  1118. assert(MAX_LEVEL >= 64);
  1119. assert(MAX_RUN >= 63);
  1120. for(slevel=-64; slevel<64; slevel++){
  1121. if(slevel==0) continue;
  1122. for(run=0; run<64; run++){
  1123. for(last=0; last<=1; last++){
  1124. const int index= UNI_MPEG4_ENC_INDEX(last, run, slevel+64);
  1125. int level= slevel < 0 ? -slevel : slevel;
  1126. int sign= slevel < 0 ? 1 : 0;
  1127. int bits, len, code;
  1128. int level1, run1;
  1129. len_tab[index]= 100;
  1130. /* ESC0 */
  1131. code= get_rl_index(rl, last, run, level);
  1132. bits= rl->table_vlc[code][0];
  1133. len= rl->table_vlc[code][1];
  1134. bits=bits*2+sign; len++;
  1135. if(code!=rl->n && len < len_tab[index]){
  1136. bits_tab[index]= bits;
  1137. len_tab [index]= len;
  1138. }
  1139. #if 1
  1140. /* ESC1 */
  1141. bits= rl->table_vlc[rl->n][0];
  1142. len= rl->table_vlc[rl->n][1];
  1143. bits=bits*2; len++; //esc1
  1144. level1= level - rl->max_level[last][run];
  1145. if(level1>0){
  1146. code= get_rl_index(rl, last, run, level1);
  1147. bits<<= rl->table_vlc[code][1];
  1148. len += rl->table_vlc[code][1];
  1149. bits += rl->table_vlc[code][0];
  1150. bits=bits*2+sign; len++;
  1151. if(code!=rl->n && len < len_tab[index]){
  1152. bits_tab[index]= bits;
  1153. len_tab [index]= len;
  1154. }
  1155. }
  1156. #endif
  1157. #if 1
  1158. /* ESC2 */
  1159. bits= rl->table_vlc[rl->n][0];
  1160. len= rl->table_vlc[rl->n][1];
  1161. bits=bits*4+2; len+=2; //esc2
  1162. run1 = run - rl->max_run[last][level] - 1;
  1163. if(run1>=0){
  1164. code= get_rl_index(rl, last, run1, level);
  1165. bits<<= rl->table_vlc[code][1];
  1166. len += rl->table_vlc[code][1];
  1167. bits += rl->table_vlc[code][0];
  1168. bits=bits*2+sign; len++;
  1169. if(code!=rl->n && len < len_tab[index]){
  1170. bits_tab[index]= bits;
  1171. len_tab [index]= len;
  1172. }
  1173. }
  1174. #endif
  1175. /* ESC3 */
  1176. bits= rl->table_vlc[rl->n][0];
  1177. len = rl->table_vlc[rl->n][1];
  1178. bits=bits*4+3; len+=2; //esc3
  1179. bits=bits*2+last; len++;
  1180. bits=bits*64+run; len+=6;
  1181. bits=bits*2+1; len++; //marker
  1182. bits=bits*4096+(slevel&0xfff); len+=12;
  1183. bits=bits*2+1; len++; //marker
  1184. if(len < len_tab[index]){
  1185. bits_tab[index]= bits;
  1186. len_tab [index]= len;
  1187. }
  1188. }
  1189. }
  1190. }
  1191. }
  1192. void h263_encode_init(MpegEncContext *s)
  1193. {
  1194. static int done = 0;
  1195. if (!done) {
  1196. done = 1;
  1197. init_uni_dc_tab();
  1198. init_rl(&rl_inter);
  1199. init_rl(&rl_intra);
  1200. init_rl(&rl_intra_aic);
  1201. init_uni_mpeg4_rl_tab(&rl_intra, uni_mpeg4_intra_rl_bits, uni_mpeg4_intra_rl_len);
  1202. init_uni_mpeg4_rl_tab(&rl_inter, uni_mpeg4_inter_rl_bits, uni_mpeg4_inter_rl_len);
  1203. init_mv_penalty_and_fcode(s);
  1204. }
  1205. s->mv_penalty= mv_penalty; //FIXME exact table for msmpeg4 & h263p
  1206. // use fcodes >1 only for mpeg4 & h263 & h263p FIXME
  1207. switch(s->codec_id){
  1208. case CODEC_ID_MPEG4:
  1209. s->fcode_tab= fcode_tab;
  1210. s->min_qcoeff= -2048;
  1211. s->max_qcoeff= 2047;
  1212. break;
  1213. case CODEC_ID_H263P:
  1214. s->fcode_tab= umv_fcode_tab;
  1215. s->min_qcoeff= -128;
  1216. s->max_qcoeff= 127;
  1217. break;
  1218. //Note for mpeg4 & h263 the dc-scale table will be set per frame as needed later
  1219. default: //nothing needed default table allready set in mpegvideo.c
  1220. s->min_qcoeff= -128;
  1221. s->max_qcoeff= 127;
  1222. s->y_dc_scale_table=
  1223. s->c_dc_scale_table= ff_mpeg1_dc_scale_table;
  1224. }
  1225. if(s->mpeg_quant){
  1226. s->intra_quant_bias= 3<<(QUANT_BIAS_SHIFT-3); //(a + x*3/8)/x
  1227. s->inter_quant_bias= 0;
  1228. }else{
  1229. s->intra_quant_bias=0;
  1230. s->inter_quant_bias=-(1<<(QUANT_BIAS_SHIFT-2)); //(a - x/4)/x
  1231. }
  1232. }
  1233. static void h263_encode_block(MpegEncContext * s, DCTELEM * block, int n)
  1234. {
  1235. int level, run, last, i, j, last_index, last_non_zero, sign, slevel, code;
  1236. RLTable *rl;
  1237. rl = &rl_inter;
  1238. if (s->mb_intra && !s->h263_aic) {
  1239. /* DC coef */
  1240. level = block[0];
  1241. /* 255 cannot be represented, so we clamp */
  1242. if (level > 254) {
  1243. level = 254;
  1244. block[0] = 254;
  1245. }
  1246. /* 0 cannot be represented also */
  1247. else if (!level) {
  1248. level = 1;
  1249. block[0] = 1;
  1250. }
  1251. if (level == 128)
  1252. put_bits(&s->pb, 8, 0xff);
  1253. else
  1254. put_bits(&s->pb, 8, level & 0xff);
  1255. i = 1;
  1256. } else {
  1257. i = 0;
  1258. if (s->h263_aic && s->mb_intra)
  1259. rl = &rl_intra_aic;
  1260. }
  1261. /* AC coefs */
  1262. last_index = s->block_last_index[n];
  1263. last_non_zero = i - 1;
  1264. for (; i <= last_index; i++) {
  1265. j = s->intra_scantable.permutated[i];
  1266. level = block[j];
  1267. if (level) {
  1268. run = i - last_non_zero - 1;
  1269. last = (i == last_index);
  1270. sign = 0;
  1271. slevel = level;
  1272. if (level < 0) {
  1273. sign = 1;
  1274. level = -level;
  1275. }
  1276. code = get_rl_index(rl, last, run, level);
  1277. put_bits(&s->pb, rl->table_vlc[code][1], rl->table_vlc[code][0]);
  1278. if (code == rl->n) {
  1279. put_bits(&s->pb, 1, last);
  1280. put_bits(&s->pb, 6, run);
  1281. put_bits(&s->pb, 8, slevel & 0xff);
  1282. } else {
  1283. put_bits(&s->pb, 1, sign);
  1284. }
  1285. last_non_zero = i;
  1286. }
  1287. }
  1288. }
  1289. #endif
  1290. /***************************************************/
  1291. /**
  1292. * add mpeg4 stuffing bits (01...1)
  1293. */
  1294. void ff_mpeg4_stuffing(PutBitContext * pbc)
  1295. {
  1296. int length;
  1297. put_bits(pbc, 1, 0);
  1298. length= (-get_bit_count(pbc))&7;
  1299. if(length) put_bits(pbc, length, (1<<length)-1);
  1300. }
  1301. /* must be called before writing the header */
  1302. void ff_set_mpeg4_time(MpegEncContext * s, int picture_number){
  1303. int time_div, time_mod;
  1304. if(s->pict_type==I_TYPE){ //we will encode a vol header
  1305. s->time_increment_resolution= s->frame_rate/ff_gcd(s->frame_rate, FRAME_RATE_BASE);
  1306. if(s->time_increment_resolution>=256*256) s->time_increment_resolution= 256*128;
  1307. s->time_increment_bits = av_log2(s->time_increment_resolution - 1) + 1;
  1308. }
  1309. if(s->avctx->pts)
  1310. s->time= (s->avctx->pts*s->time_increment_resolution + 500*1000)/(1000*1000);
  1311. else
  1312. s->time= picture_number*(INT64)FRAME_RATE_BASE*s->time_increment_resolution/s->frame_rate;
  1313. time_div= s->time/s->time_increment_resolution;
  1314. time_mod= s->time%s->time_increment_resolution;
  1315. if(s->pict_type==B_TYPE){
  1316. s->pb_time= s->pp_time - (s->last_non_b_time - s->time);
  1317. }else{
  1318. s->last_time_base= s->time_base;
  1319. s->time_base= time_div;
  1320. s->pp_time= s->time - s->last_non_b_time;
  1321. s->last_non_b_time= s->time;
  1322. }
  1323. }
  1324. static void mpeg4_encode_vol_header(MpegEncContext * s)
  1325. {
  1326. int vo_ver_id=1; //must be 2 if we want GMC or q-pel
  1327. char buf[255];
  1328. s->vo_type= s->has_b_frames ? CORE_VO_TYPE : SIMPLE_VO_TYPE;
  1329. put_bits(&s->pb, 16, 0);
  1330. put_bits(&s->pb, 16, 0x100); /* video obj */
  1331. put_bits(&s->pb, 16, 0);
  1332. put_bits(&s->pb, 16, 0x120); /* video obj layer */
  1333. put_bits(&s->pb, 1, 0); /* random access vol */
  1334. put_bits(&s->pb, 8, s->vo_type); /* video obj type indication */
  1335. put_bits(&s->pb, 1, 1); /* is obj layer id= yes */
  1336. put_bits(&s->pb, 4, vo_ver_id); /* is obj layer ver id */
  1337. put_bits(&s->pb, 3, 1); /* is obj layer priority */
  1338. float_aspect_to_info(s, s->avctx->aspect_ratio);
  1339. put_bits(&s->pb, 4, s->aspect_ratio_info);/* aspect ratio info */
  1340. if (s->aspect_ratio_info == FF_ASPECT_EXTENDED)
  1341. {
  1342. put_bits(&s->pb, 8, s->aspected_width);
  1343. put_bits(&s->pb, 8, s->aspected_height);
  1344. }
  1345. if(s->low_delay){
  1346. put_bits(&s->pb, 1, 1); /* vol control parameters= yes */
  1347. put_bits(&s->pb, 2, 1); /* chroma format YUV 420/YV12 */
  1348. put_bits(&s->pb, 1, s->low_delay);
  1349. put_bits(&s->pb, 1, 0); /* vbv parameters= no */
  1350. }else{
  1351. put_bits(&s->pb, 1, 0); /* vol control parameters= no */
  1352. }
  1353. put_bits(&s->pb, 2, RECT_SHAPE); /* vol shape= rectangle */
  1354. put_bits(&s->pb, 1, 1); /* marker bit */
  1355. put_bits(&s->pb, 16, s->time_increment_resolution);
  1356. if (s->time_increment_bits < 1)
  1357. s->time_increment_bits = 1;
  1358. put_bits(&s->pb, 1, 1); /* marker bit */
  1359. put_bits(&s->pb, 1, 0); /* fixed vop rate=no */
  1360. put_bits(&s->pb, 1, 1); /* marker bit */
  1361. put_bits(&s->pb, 13, s->width); /* vol width */
  1362. put_bits(&s->pb, 1, 1); /* marker bit */
  1363. put_bits(&s->pb, 13, s->height); /* vol height */
  1364. put_bits(&s->pb, 1, 1); /* marker bit */
  1365. put_bits(&s->pb, 1, s->progressive_sequence ? 0 : 1);
  1366. put_bits(&s->pb, 1, 1); /* obmc disable */
  1367. if (vo_ver_id == 1) {
  1368. put_bits(&s->pb, 1, s->vol_sprite_usage=0); /* sprite enable */
  1369. }else{ /* vo_ver_id == 2 */
  1370. put_bits(&s->pb, 2, s->vol_sprite_usage=0); /* sprite enable */
  1371. }
  1372. s->quant_precision=5;
  1373. put_bits(&s->pb, 1, 0); /* not 8 bit == false */
  1374. put_bits(&s->pb, 1, s->mpeg_quant); /* quant type= (0=h263 style)*/
  1375. if(s->mpeg_quant) put_bits(&s->pb, 2, 0); /* no custom matrixes */
  1376. if (vo_ver_id != 1)
  1377. put_bits(&s->pb, 1, s->quarter_sample=0);
  1378. put_bits(&s->pb, 1, 1); /* complexity estimation disable */
  1379. s->resync_marker= s->rtp_mode;
  1380. put_bits(&s->pb, 1, s->resync_marker ? 0 : 1);/* resync marker disable */
  1381. put_bits(&s->pb, 1, s->data_partitioning ? 1 : 0);
  1382. if(s->data_partitioning){
  1383. put_bits(&s->pb, 1, 0); /* no rvlc */
  1384. }
  1385. if (vo_ver_id != 1){
  1386. put_bits(&s->pb, 1, 0); /* newpred */
  1387. put_bits(&s->pb, 1, 0); /* reduced res vop */
  1388. }
  1389. put_bits(&s->pb, 1, 0); /* scalability */
  1390. ff_mpeg4_stuffing(&s->pb);
  1391. /* user data */
  1392. if(!ff_bit_exact){
  1393. put_bits(&s->pb, 16, 0);
  1394. put_bits(&s->pb, 16, 0x1B2); /* user_data */
  1395. sprintf(buf, "FFmpeg%sb%s", FFMPEG_VERSION, LIBAVCODEC_BUILD_STR);
  1396. put_string(&s->pb, buf);
  1397. ff_mpeg4_stuffing(&s->pb);
  1398. }
  1399. }
  1400. /* write mpeg4 VOP header */
  1401. void mpeg4_encode_picture_header(MpegEncContext * s, int picture_number)
  1402. {
  1403. int time_incr;
  1404. int time_div, time_mod;
  1405. if(s->pict_type==I_TYPE){
  1406. s->no_rounding=0;
  1407. if(picture_number==0 || !s->strict_std_compliance)
  1408. mpeg4_encode_vol_header(s);
  1409. }
  1410. s->partitioned_frame= s->data_partitioning && s->pict_type!=B_TYPE;
  1411. //printf("num:%d rate:%d base:%d\n", s->picture_number, s->frame_rate, FRAME_RATE_BASE);
  1412. put_bits(&s->pb, 16, 0); /* vop header */
  1413. put_bits(&s->pb, 16, 0x1B6); /* vop header */
  1414. put_bits(&s->pb, 2, s->pict_type - 1); /* pict type: I = 0 , P = 1 */
  1415. time_div= s->time/s->time_increment_resolution;
  1416. time_mod= s->time%s->time_increment_resolution;
  1417. time_incr= time_div - s->last_time_base;
  1418. while(time_incr--)
  1419. put_bits(&s->pb, 1, 1);
  1420. put_bits(&s->pb, 1, 0);
  1421. put_bits(&s->pb, 1, 1); /* marker */
  1422. put_bits(&s->pb, s->time_increment_bits, time_mod); /* time increment */
  1423. put_bits(&s->pb, 1, 1); /* marker */
  1424. put_bits(&s->pb, 1, 1); /* vop coded */
  1425. if ( s->pict_type == P_TYPE
  1426. || (s->pict_type == S_TYPE && s->vol_sprite_usage==GMC_SPRITE)) {
  1427. s->no_rounding ^= 1;
  1428. put_bits(&s->pb, 1, s->no_rounding); /* rounding type */
  1429. }
  1430. put_bits(&s->pb, 3, 0); /* intra dc VLC threshold */
  1431. if(!s->progressive_sequence){
  1432. put_bits(&s->pb, 1, s->top_field_first);
  1433. put_bits(&s->pb, 1, s->alternate_scan);
  1434. }
  1435. //FIXME sprite stuff
  1436. put_bits(&s->pb, 5, s->qscale);
  1437. if (s->pict_type != I_TYPE)
  1438. put_bits(&s->pb, 3, s->f_code); /* fcode_for */
  1439. if (s->pict_type == B_TYPE)
  1440. put_bits(&s->pb, 3, s->b_code); /* fcode_back */
  1441. // printf("****frame %d\n", picture_number);
  1442. s->y_dc_scale_table= ff_mpeg4_y_dc_scale_table; //FIXME add short header support
  1443. s->c_dc_scale_table= ff_mpeg4_c_dc_scale_table;
  1444. s->h_edge_pos= s->width;
  1445. s->v_edge_pos= s->height;
  1446. }
  1447. /**
  1448. * change qscale by given dquant and update qscale dependant variables.
  1449. */
  1450. static void change_qscale(MpegEncContext * s, int dquant)
  1451. {
  1452. s->qscale += dquant;
  1453. if (s->qscale < 1)
  1454. s->qscale = 1;
  1455. else if (s->qscale > 31)
  1456. s->qscale = 31;
  1457. s->y_dc_scale= s->y_dc_scale_table[ s->qscale ];
  1458. s->c_dc_scale= s->c_dc_scale_table[ s->qscale ];
  1459. }
  1460. static inline int ff_mpeg4_pred_dc(MpegEncContext * s, int n, UINT16 **dc_val_ptr, int *dir_ptr)
  1461. {
  1462. int a, b, c, wrap, pred, scale;
  1463. UINT16 *dc_val;
  1464. int dummy;
  1465. /* find prediction */
  1466. if (n < 4) {
  1467. scale = s->y_dc_scale;
  1468. } else {
  1469. scale = s->c_dc_scale;
  1470. }
  1471. wrap= s->block_wrap[n];
  1472. dc_val = s->dc_val[0] + s->block_index[n];
  1473. /* B C
  1474. * A X
  1475. */
  1476. a = dc_val[ - 1];
  1477. b = dc_val[ - 1 - wrap];
  1478. c = dc_val[ - wrap];
  1479. /* outside slice handling (we cant do that by memset as we need the dc for error resilience) */
  1480. if(s->first_slice_line && n!=3){
  1481. if(n!=2) b=c= 1024;
  1482. if(n!=1 && s->mb_x == s->resync_mb_x) b=a= 1024;
  1483. }
  1484. if(s->mb_x == s->resync_mb_x && s->mb_y == s->resync_mb_y+1){
  1485. if(n==0 || n==4 || n==5)
  1486. b=1024;
  1487. }
  1488. if (abs(a - b) < abs(b - c)) {
  1489. pred = c;
  1490. *dir_ptr = 1; /* top */
  1491. } else {
  1492. pred = a;
  1493. *dir_ptr = 0; /* left */
  1494. }
  1495. /* we assume pred is positive */
  1496. #ifdef ARCH_X86
  1497. asm volatile (
  1498. "xorl %%edx, %%edx \n\t"
  1499. "mul %%ecx \n\t"
  1500. : "=d" (pred), "=a"(dummy)
  1501. : "a" (pred + (scale >> 1)), "c" (inverse[scale])
  1502. );
  1503. #else
  1504. pred = (pred + (scale >> 1)) / scale;
  1505. #endif
  1506. /* prepare address for prediction update */
  1507. *dc_val_ptr = &dc_val[0];
  1508. return pred;
  1509. }
  1510. void mpeg4_pred_ac(MpegEncContext * s, INT16 *block, int n,
  1511. int dir)
  1512. {
  1513. int i;
  1514. INT16 *ac_val, *ac_val1;
  1515. /* find prediction */
  1516. ac_val = s->ac_val[0][0] + s->block_index[n] * 16;
  1517. ac_val1 = ac_val;
  1518. if (s->ac_pred) {
  1519. if (dir == 0) {
  1520. const int xy= s->mb_x-1 + s->mb_y*s->mb_width;
  1521. /* left prediction */
  1522. ac_val -= 16;
  1523. if(s->mb_x==0 || s->qscale == s->qscale_table[xy] || n==1 || n==3){
  1524. /* same qscale */
  1525. for(i=1;i<8;i++) {
  1526. block[s->idct_permutation[i<<3]] += ac_val[i];
  1527. }
  1528. }else{
  1529. /* different qscale, we must rescale */
  1530. for(i=1;i<8;i++) {
  1531. block[s->idct_permutation[i<<3]] += ROUNDED_DIV(ac_val[i]*s->qscale_table[xy], s->qscale);
  1532. }
  1533. }
  1534. } else {
  1535. const int xy= s->mb_x + s->mb_y*s->mb_width - s->mb_width;
  1536. /* top prediction */
  1537. ac_val -= 16 * s->block_wrap[n];
  1538. if(s->mb_y==0 || s->qscale == s->qscale_table[xy] || n==2 || n==3){
  1539. /* same qscale */
  1540. for(i=1;i<8;i++) {
  1541. block[s->idct_permutation[i]] += ac_val[i + 8];
  1542. }
  1543. }else{
  1544. /* different qscale, we must rescale */
  1545. for(i=1;i<8;i++) {
  1546. block[s->idct_permutation[i]] += ROUNDED_DIV(ac_val[i + 8]*s->qscale_table[xy], s->qscale);
  1547. }
  1548. }
  1549. }
  1550. }
  1551. /* left copy */
  1552. for(i=1;i<8;i++)
  1553. ac_val1[i ] = block[s->idct_permutation[i<<3]];
  1554. /* top copy */
  1555. for(i=1;i<8;i++)
  1556. ac_val1[8 + i] = block[s->idct_permutation[i ]];
  1557. }
  1558. static void mpeg4_inv_pred_ac(MpegEncContext * s, INT16 *block, int n,
  1559. int dir)
  1560. {
  1561. int i;
  1562. INT16 *ac_val;
  1563. /* find prediction */
  1564. ac_val = s->ac_val[0][0] + s->block_index[n] * 16;
  1565. if (dir == 0) {
  1566. const int xy= s->mb_x-1 + s->mb_y*s->mb_width;
  1567. /* left prediction */
  1568. ac_val -= 16;
  1569. if(s->mb_x==0 || s->qscale == s->qscale_table[xy] || n==1 || n==3){
  1570. /* same qscale */
  1571. for(i=1;i<8;i++) {
  1572. block[s->idct_permutation[i<<3]] -= ac_val[i];
  1573. }
  1574. }else{
  1575. /* different qscale, we must rescale */
  1576. for(i=1;i<8;i++) {
  1577. block[s->idct_permutation[i<<3]] -= ROUNDED_DIV(ac_val[i]*s->qscale_table[xy], s->qscale);
  1578. }
  1579. }
  1580. } else {
  1581. const int xy= s->mb_x + s->mb_y*s->mb_width - s->mb_width;
  1582. /* top prediction */
  1583. ac_val -= 16 * s->block_wrap[n];
  1584. if(s->mb_y==0 || s->qscale == s->qscale_table[xy] || n==2 || n==3){
  1585. /* same qscale */
  1586. for(i=1;i<8;i++) {
  1587. block[s->idct_permutation[i]] -= ac_val[i + 8];
  1588. }
  1589. }else{
  1590. /* different qscale, we must rescale */
  1591. for(i=1;i<8;i++) {
  1592. block[s->idct_permutation[i]] -= ROUNDED_DIV(ac_val[i + 8]*s->qscale_table[xy], s->qscale);
  1593. }
  1594. }
  1595. }
  1596. }
  1597. static inline void mpeg4_encode_dc(PutBitContext * s, int level, int n)
  1598. {
  1599. #if 1
  1600. // if(level<-255 || level>255) printf("dc overflow\n");
  1601. level+=256;
  1602. if (n < 4) {
  1603. /* luminance */
  1604. put_bits(s, uni_DCtab_lum[level][1], uni_DCtab_lum[level][0]);
  1605. } else {
  1606. /* chrominance */
  1607. put_bits(s, uni_DCtab_chrom[level][1], uni_DCtab_chrom[level][0]);
  1608. }
  1609. #else
  1610. int size, v;
  1611. /* find number of bits */
  1612. size = 0;
  1613. v = abs(level);
  1614. while (v) {
  1615. v >>= 1;
  1616. size++;
  1617. }
  1618. if (n < 4) {
  1619. /* luminance */
  1620. put_bits(&s->pb, DCtab_lum[size][1], DCtab_lum[size][0]);
  1621. } else {
  1622. /* chrominance */
  1623. put_bits(&s->pb, DCtab_chrom[size][1], DCtab_chrom[size][0]);
  1624. }
  1625. /* encode remaining bits */
  1626. if (size > 0) {
  1627. if (level < 0)
  1628. level = (-level) ^ ((1 << size) - 1);
  1629. put_bits(&s->pb, size, level);
  1630. if (size > 8)
  1631. put_bits(&s->pb, 1, 1);
  1632. }
  1633. #endif
  1634. }
  1635. #ifdef CONFIG_ENCODERS
  1636. static inline void mpeg4_encode_block(MpegEncContext * s, DCTELEM * block, int n, int intra_dc,
  1637. UINT8 *scan_table, PutBitContext *dc_pb, PutBitContext *ac_pb)
  1638. {
  1639. int i, last_non_zero;
  1640. #if 0 //variables for the outcommented version
  1641. int code, sign, last;
  1642. #endif
  1643. const RLTable *rl;
  1644. UINT32 *bits_tab;
  1645. UINT8 *len_tab;
  1646. const int last_index = s->block_last_index[n];
  1647. if (s->mb_intra) { //Note gcc (3.2.1 at least) will optimize this away
  1648. /* mpeg4 based DC predictor */
  1649. mpeg4_encode_dc(dc_pb, intra_dc, n);
  1650. if(last_index<1) return;
  1651. i = 1;
  1652. rl = &rl_intra;
  1653. bits_tab= uni_mpeg4_intra_rl_bits;
  1654. len_tab = uni_mpeg4_intra_rl_len;
  1655. } else {
  1656. if(last_index<0) return;
  1657. i = 0;
  1658. rl = &rl_inter;
  1659. bits_tab= uni_mpeg4_inter_rl_bits;
  1660. len_tab = uni_mpeg4_inter_rl_len;
  1661. }
  1662. /* AC coefs */
  1663. last_non_zero = i - 1;
  1664. #if 1
  1665. for (; i < last_index; i++) {
  1666. int level = block[ scan_table[i] ];
  1667. if (level) {
  1668. int run = i - last_non_zero - 1;
  1669. level+=64;
  1670. if((level&(~127)) == 0){
  1671. const int index= UNI_MPEG4_ENC_INDEX(0, run, level);
  1672. put_bits(ac_pb, len_tab[index], bits_tab[index]);
  1673. }else{ //ESC3
  1674. put_bits(ac_pb, 7+2+1+6+1+12+1, (3<<23)+(3<<21)+(0<<20)+(run<<14)+(1<<13)+(((level-64)&0xfff)<<1)+1);
  1675. }
  1676. last_non_zero = i;
  1677. }
  1678. }
  1679. /*if(i<=last_index)*/{
  1680. int level = block[ scan_table[i] ];
  1681. int run = i - last_non_zero - 1;
  1682. level+=64;
  1683. if((level&(~127)) == 0){
  1684. const int index= UNI_MPEG4_ENC_INDEX(1, run, level);
  1685. put_bits(ac_pb, len_tab[index], bits_tab[index]);
  1686. }else{ //ESC3
  1687. put_bits(ac_pb, 7+2+1+6+1+12+1, (3<<23)+(3<<21)+(1<<20)+(run<<14)+(1<<13)+(((level-64)&0xfff)<<1)+1);
  1688. }
  1689. }
  1690. #else
  1691. for (; i <= last_index; i++) {
  1692. const int slevel = block[ scan_table[i] ];
  1693. if (slevel) {
  1694. int level;
  1695. int run = i - last_non_zero - 1;
  1696. last = (i == last_index);
  1697. sign = 0;
  1698. level = slevel;
  1699. if (level < 0) {
  1700. sign = 1;
  1701. level = -level;
  1702. }
  1703. code = get_rl_index(rl, last, run, level);
  1704. put_bits(ac_pb, rl->table_vlc[code][1], rl->table_vlc[code][0]);
  1705. if (code == rl->n) {
  1706. int level1, run1;
  1707. level1 = level - rl->max_level[last][run];
  1708. if (level1 < 1)
  1709. goto esc2;
  1710. code = get_rl_index(rl, last, run, level1);
  1711. if (code == rl->n) {
  1712. esc2:
  1713. put_bits(ac_pb, 1, 1);
  1714. if (level > MAX_LEVEL)
  1715. goto esc3;
  1716. run1 = run - rl->max_run[last][level] - 1;
  1717. if (run1 < 0)
  1718. goto esc3;
  1719. code = get_rl_index(rl, last, run1, level);
  1720. if (code == rl->n) {
  1721. esc3:
  1722. /* third escape */
  1723. put_bits(ac_pb, 1, 1);
  1724. put_bits(ac_pb, 1, last);
  1725. put_bits(ac_pb, 6, run);
  1726. put_bits(ac_pb, 1, 1);
  1727. put_bits(ac_pb, 12, slevel & 0xfff);
  1728. put_bits(ac_pb, 1, 1);
  1729. } else {
  1730. /* second escape */
  1731. put_bits(ac_pb, 1, 0);
  1732. put_bits(ac_pb, rl->table_vlc[code][1], rl->table_vlc[code][0]);
  1733. put_bits(ac_pb, 1, sign);
  1734. }
  1735. } else {
  1736. /* first escape */
  1737. put_bits(ac_pb, 1, 0);
  1738. put_bits(ac_pb, rl->table_vlc[code][1], rl->table_vlc[code][0]);
  1739. put_bits(ac_pb, 1, sign);
  1740. }
  1741. } else {
  1742. put_bits(ac_pb, 1, sign);
  1743. }
  1744. last_non_zero = i;
  1745. }
  1746. }
  1747. #endif
  1748. }
  1749. #endif
  1750. /***********************************************/
  1751. /* decoding */
  1752. static VLC intra_MCBPC_vlc;
  1753. static VLC inter_MCBPC_vlc;
  1754. static VLC cbpy_vlc;
  1755. static VLC mv_vlc;
  1756. static VLC dc_lum, dc_chrom;
  1757. static VLC sprite_trajectory;
  1758. static VLC mb_type_b_vlc;
  1759. void init_rl(RLTable *rl)
  1760. {
  1761. INT8 max_level[MAX_RUN+1], max_run[MAX_LEVEL+1];
  1762. UINT8 index_run[MAX_RUN+1];
  1763. int last, run, level, start, end, i;
  1764. /* compute max_level[], max_run[] and index_run[] */
  1765. for(last=0;last<2;last++) {
  1766. if (last == 0) {
  1767. start = 0;
  1768. end = rl->last;
  1769. } else {
  1770. start = rl->last;
  1771. end = rl->n;
  1772. }
  1773. memset(max_level, 0, MAX_RUN + 1);
  1774. memset(max_run, 0, MAX_LEVEL + 1);
  1775. memset(index_run, rl->n, MAX_RUN + 1);
  1776. for(i=start;i<end;i++) {
  1777. run = rl->table_run[i];
  1778. level = rl->table_level[i];
  1779. if (index_run[run] == rl->n)
  1780. index_run[run] = i;
  1781. if (level > max_level[run])
  1782. max_level[run] = level;
  1783. if (run > max_run[level])
  1784. max_run[level] = run;
  1785. }
  1786. rl->max_level[last] = av_malloc(MAX_RUN + 1);
  1787. memcpy(rl->max_level[last], max_level, MAX_RUN + 1);
  1788. rl->max_run[last] = av_malloc(MAX_LEVEL + 1);
  1789. memcpy(rl->max_run[last], max_run, MAX_LEVEL + 1);
  1790. rl->index_run[last] = av_malloc(MAX_RUN + 1);
  1791. memcpy(rl->index_run[last], index_run, MAX_RUN + 1);
  1792. }
  1793. }
  1794. void init_vlc_rl(RLTable *rl)
  1795. {
  1796. int i, q;
  1797. init_vlc(&rl->vlc, 9, rl->n + 1,
  1798. &rl->table_vlc[0][1], 4, 2,
  1799. &rl->table_vlc[0][0], 4, 2);
  1800. for(q=0; q<32; q++){
  1801. int qmul= q*2;
  1802. int qadd= (q-1)|1;
  1803. if(q==0){
  1804. qmul=1;
  1805. qadd=0;
  1806. }
  1807. rl->rl_vlc[q]= av_malloc(rl->vlc.table_size*sizeof(RL_VLC_ELEM));
  1808. for(i=0; i<rl->vlc.table_size; i++){
  1809. int code= rl->vlc.table[i][0];
  1810. int len = rl->vlc.table[i][1];
  1811. int level, run;
  1812. if(len==0){ // illegal code
  1813. run= 66;
  1814. level= MAX_LEVEL;
  1815. }else if(len<0){ //more bits needed
  1816. run= 0;
  1817. level= code;
  1818. }else{
  1819. if(code==rl->n){ //esc
  1820. run= 66;
  1821. level= 0;
  1822. }else{
  1823. run= rl->table_run [code] + 1;
  1824. level= rl->table_level[code] * qmul + qadd;
  1825. if(code >= rl->last) run+=192;
  1826. }
  1827. }
  1828. rl->rl_vlc[q][i].len= len;
  1829. rl->rl_vlc[q][i].level= level;
  1830. rl->rl_vlc[q][i].run= run;
  1831. }
  1832. }
  1833. }
  1834. /* init vlcs */
  1835. /* XXX: find a better solution to handle static init */
  1836. void h263_decode_init_vlc(MpegEncContext *s)
  1837. {
  1838. static int done = 0;
  1839. if (!done) {
  1840. done = 1;
  1841. init_vlc(&intra_MCBPC_vlc, INTRA_MCBPC_VLC_BITS, 8,
  1842. intra_MCBPC_bits, 1, 1,
  1843. intra_MCBPC_code, 1, 1);
  1844. init_vlc(&inter_MCBPC_vlc, INTER_MCBPC_VLC_BITS, 25,
  1845. inter_MCBPC_bits, 1, 1,
  1846. inter_MCBPC_code, 1, 1);
  1847. init_vlc(&cbpy_vlc, CBPY_VLC_BITS, 16,
  1848. &cbpy_tab[0][1], 2, 1,
  1849. &cbpy_tab[0][0], 2, 1);
  1850. init_vlc(&mv_vlc, MV_VLC_BITS, 33,
  1851. &mvtab[0][1], 2, 1,
  1852. &mvtab[0][0], 2, 1);
  1853. init_rl(&rl_inter);
  1854. init_rl(&rl_intra);
  1855. init_rl(&rl_intra_aic);
  1856. init_vlc_rl(&rl_inter);
  1857. init_vlc_rl(&rl_intra);
  1858. init_vlc_rl(&rl_intra_aic);
  1859. init_vlc(&dc_lum, DC_VLC_BITS, 10 /* 13 */,
  1860. &DCtab_lum[0][1], 2, 1,
  1861. &DCtab_lum[0][0], 2, 1);
  1862. init_vlc(&dc_chrom, DC_VLC_BITS, 10 /* 13 */,
  1863. &DCtab_chrom[0][1], 2, 1,
  1864. &DCtab_chrom[0][0], 2, 1);
  1865. init_vlc(&sprite_trajectory, SPRITE_TRAJ_VLC_BITS, 15,
  1866. &sprite_trajectory_tab[0][1], 4, 2,
  1867. &sprite_trajectory_tab[0][0], 4, 2);
  1868. init_vlc(&mb_type_b_vlc, MB_TYPE_B_VLC_BITS, 4,
  1869. &mb_type_b_tab[0][1], 2, 1,
  1870. &mb_type_b_tab[0][0], 2, 1);
  1871. }
  1872. }
  1873. /**
  1874. * Get the GOB height based on picture height.
  1875. */
  1876. int ff_h263_get_gob_height(MpegEncContext *s){
  1877. if (s->height <= 400)
  1878. return 1;
  1879. else if (s->height <= 800)
  1880. return 2;
  1881. else
  1882. return 4;
  1883. }
  1884. /**
  1885. * decodes the group of blocks header.
  1886. * @return <0 if an error occured
  1887. */
  1888. static int h263_decode_gob_header(MpegEncContext *s)
  1889. {
  1890. unsigned int val, gfid;
  1891. int left;
  1892. /* Check for GOB Start Code */
  1893. val = show_bits(&s->gb, 16);
  1894. if(val)
  1895. return -1;
  1896. /* We have a GBSC probably with GSTUFF */
  1897. skip_bits(&s->gb, 16); /* Drop the zeros */
  1898. left= s->gb.size*8 - get_bits_count(&s->gb);
  1899. //MN: we must check the bits left or we might end in a infinite loop (or segfault)
  1900. for(;left>13; left--){
  1901. if(get_bits1(&s->gb)) break; /* Seek the '1' bit */
  1902. }
  1903. if(left<=13)
  1904. return -1;
  1905. #ifdef DEBUG
  1906. fprintf(stderr,"\nGOB Start Code at MB %d\n", (s->mb_y * s->mb_width) + s->mb_x);
  1907. #endif
  1908. s->gob_number = get_bits(&s->gb, 5); /* GN */
  1909. gfid = get_bits(&s->gb, 2); /* GFID */
  1910. s->qscale = get_bits(&s->gb, 5); /* GQUANT */
  1911. if(s->qscale==0)
  1912. return -1;
  1913. s->mb_x= 0;
  1914. s->mb_y= s->gob_index* s->gob_number;
  1915. #ifdef DEBUG
  1916. fprintf(stderr, "\nGN: %u GFID: %u Quant: %u\n", s->gob_number, gfid, s->qscale);
  1917. #endif
  1918. return 0;
  1919. }
  1920. static inline void memsetw(short *tab, int val, int n)
  1921. {
  1922. int i;
  1923. for(i=0;i<n;i++)
  1924. tab[i] = val;
  1925. }
  1926. void ff_mpeg4_init_partitions(MpegEncContext *s)
  1927. {
  1928. init_put_bits(&s->tex_pb, s->tex_pb_buffer, PB_BUFFER_SIZE, NULL, NULL);
  1929. init_put_bits(&s->pb2 , s->pb2_buffer , PB_BUFFER_SIZE, NULL, NULL);
  1930. }
  1931. void ff_mpeg4_merge_partitions(MpegEncContext *s)
  1932. {
  1933. const int pb2_len = get_bit_count(&s->pb2 );
  1934. const int tex_pb_len= get_bit_count(&s->tex_pb);
  1935. const int bits= get_bit_count(&s->pb);
  1936. if(s->pict_type==I_TYPE){
  1937. put_bits(&s->pb, 19, DC_MARKER);
  1938. s->misc_bits+=19 + pb2_len + bits - s->last_bits;
  1939. s->i_tex_bits+= tex_pb_len;
  1940. }else{
  1941. put_bits(&s->pb, 17, MOTION_MARKER);
  1942. s->misc_bits+=17 + pb2_len;
  1943. s->mv_bits+= bits - s->last_bits;
  1944. s->p_tex_bits+= tex_pb_len;
  1945. }
  1946. flush_put_bits(&s->pb2);
  1947. flush_put_bits(&s->tex_pb);
  1948. ff_copy_bits(&s->pb, s->pb2_buffer , pb2_len);
  1949. ff_copy_bits(&s->pb, s->tex_pb_buffer, tex_pb_len);
  1950. s->last_bits= get_bit_count(&s->pb);
  1951. }
  1952. int ff_mpeg4_get_video_packet_prefix_length(MpegEncContext *s){
  1953. switch(s->pict_type){
  1954. case I_TYPE:
  1955. return 16;
  1956. case P_TYPE:
  1957. case S_TYPE:
  1958. return s->f_code+15;
  1959. case B_TYPE:
  1960. return FFMAX(FFMAX(s->f_code, s->b_code)+15, 17);
  1961. default:
  1962. return -1;
  1963. }
  1964. }
  1965. void ff_mpeg4_encode_video_packet_header(MpegEncContext *s)
  1966. {
  1967. int mb_num_bits= av_log2(s->mb_num - 1) + 1;
  1968. ff_mpeg4_stuffing(&s->pb);
  1969. put_bits(&s->pb, ff_mpeg4_get_video_packet_prefix_length(s), 0);
  1970. put_bits(&s->pb, 1, 1);
  1971. put_bits(&s->pb, mb_num_bits, s->mb_x + s->mb_y*s->mb_width);
  1972. put_bits(&s->pb, s->quant_precision, s->qscale);
  1973. put_bits(&s->pb, 1, 0); /* no HEC */
  1974. }
  1975. /**
  1976. * check if the next stuff is a resync marker or the end.
  1977. * @return 0 if not
  1978. */
  1979. static inline int mpeg4_is_resync(MpegEncContext *s){
  1980. const int bits_count= get_bits_count(&s->gb);
  1981. if(s->workaround_bugs&FF_BUG_NO_PADDING){
  1982. return 0;
  1983. }
  1984. if(bits_count + 8 >= s->gb.size*8){
  1985. int v= show_bits(&s->gb, 8);
  1986. v|= 0x7F >> (7-(bits_count&7));
  1987. if(v==0x7F)
  1988. return 1;
  1989. }else{
  1990. if(show_bits(&s->gb, 16) == ff_mpeg4_resync_prefix[bits_count&7]){
  1991. int len;
  1992. GetBitContext gb= s->gb;
  1993. skip_bits(&s->gb, 1);
  1994. align_get_bits(&s->gb);
  1995. for(len=0; len<32; len++){
  1996. if(get_bits1(&s->gb)) break;
  1997. }
  1998. s->gb= gb;
  1999. if(len>=ff_mpeg4_get_video_packet_prefix_length(s))
  2000. return 1;
  2001. }
  2002. }
  2003. return 0;
  2004. }
  2005. /**
  2006. * decodes the next video packet.
  2007. * @return <0 if something went wrong
  2008. */
  2009. static int mpeg4_decode_video_packet_header(MpegEncContext *s)
  2010. {
  2011. int mb_num_bits= av_log2(s->mb_num - 1) + 1;
  2012. int header_extension=0, mb_num, len;
  2013. /* is there enough space left for a video packet + header */
  2014. if( get_bits_count(&s->gb) > s->gb.size*8-20) return -1;
  2015. for(len=0; len<32; len++){
  2016. if(get_bits1(&s->gb)) break;
  2017. }
  2018. if(len!=ff_mpeg4_get_video_packet_prefix_length(s)){
  2019. printf("marker does not match f_code\n");
  2020. return -1;
  2021. }
  2022. if(s->shape != RECT_SHAPE){
  2023. header_extension= get_bits1(&s->gb);
  2024. //FIXME more stuff here
  2025. }
  2026. mb_num= get_bits(&s->gb, mb_num_bits);
  2027. if(mb_num>=s->mb_num){
  2028. fprintf(stderr, "illegal mb_num in video packet (%d %d) \n", mb_num, s->mb_num);
  2029. return -1;
  2030. }
  2031. s->mb_x= mb_num % s->mb_width;
  2032. s->mb_y= mb_num / s->mb_width;
  2033. if(s->shape != BIN_ONLY_SHAPE){
  2034. int qscale= get_bits(&s->gb, s->quant_precision);
  2035. if(qscale)
  2036. s->qscale= qscale;
  2037. }
  2038. if(s->shape == RECT_SHAPE){
  2039. header_extension= get_bits1(&s->gb);
  2040. }
  2041. if(header_extension){
  2042. int time_increment;
  2043. int time_incr=0;
  2044. while (get_bits1(&s->gb) != 0)
  2045. time_incr++;
  2046. check_marker(&s->gb, "before time_increment in video packed header");
  2047. time_increment= get_bits(&s->gb, s->time_increment_bits);
  2048. check_marker(&s->gb, "before vop_coding_type in video packed header");
  2049. skip_bits(&s->gb, 2); /* vop coding type */
  2050. //FIXME not rect stuff here
  2051. if(s->shape != BIN_ONLY_SHAPE){
  2052. skip_bits(&s->gb, 3); /* intra dc vlc threshold */
  2053. //FIXME dont just ignore everything
  2054. if(s->pict_type == S_TYPE && s->vol_sprite_usage==GMC_SPRITE){
  2055. mpeg4_decode_sprite_trajectory(s);
  2056. fprintf(stderr, "untested\n");
  2057. }
  2058. //FIXME reduced res stuff here
  2059. if (s->pict_type != I_TYPE) {
  2060. int f_code = get_bits(&s->gb, 3); /* fcode_for */
  2061. if(f_code==0){
  2062. printf("Error, video packet header damaged (f_code=0)\n");
  2063. }
  2064. }
  2065. if (s->pict_type == B_TYPE) {
  2066. int b_code = get_bits(&s->gb, 3);
  2067. if(b_code==0){
  2068. printf("Error, video packet header damaged (b_code=0)\n");
  2069. }
  2070. }
  2071. }
  2072. }
  2073. //FIXME new-pred stuff
  2074. //printf("parse ok %d %d %d %d\n", mb_num, s->mb_x + s->mb_y*s->mb_width, get_bits_count(gb), get_bits_count(&s->gb));
  2075. return 0;
  2076. }
  2077. void ff_mpeg4_clean_buffers(MpegEncContext *s)
  2078. {
  2079. int c_wrap, c_xy, l_wrap, l_xy;
  2080. l_wrap= s->block_wrap[0];
  2081. l_xy= s->mb_y*l_wrap*2 + s->mb_x*2;
  2082. c_wrap= s->block_wrap[4];
  2083. c_xy= s->mb_y*c_wrap + s->mb_x;
  2084. #if 0
  2085. /* clean DC */
  2086. memsetw(s->dc_val[0] + l_xy, 1024, l_wrap*2+1);
  2087. memsetw(s->dc_val[1] + c_xy, 1024, c_wrap+1);
  2088. memsetw(s->dc_val[2] + c_xy, 1024, c_wrap+1);
  2089. #endif
  2090. /* clean AC */
  2091. memset(s->ac_val[0] + l_xy, 0, (l_wrap*2+1)*16*sizeof(INT16));
  2092. memset(s->ac_val[1] + c_xy, 0, (c_wrap +1)*16*sizeof(INT16));
  2093. memset(s->ac_val[2] + c_xy, 0, (c_wrap +1)*16*sizeof(INT16));
  2094. /* clean MV */
  2095. // we cant clear the MVs as they might be needed by a b frame
  2096. // memset(s->motion_val + l_xy, 0, (l_wrap*2+1)*2*sizeof(INT16));
  2097. // memset(s->motion_val, 0, 2*sizeof(INT16)*(2 + s->mb_width*2)*(2 + s->mb_height*2));
  2098. s->last_mv[0][0][0]=
  2099. s->last_mv[0][0][1]=
  2100. s->last_mv[1][0][0]=
  2101. s->last_mv[1][0][1]= 0;
  2102. }
  2103. /**
  2104. * decodes the group of blocks / video packet header.
  2105. * @return <0 if no resync found
  2106. */
  2107. int ff_h263_resync(MpegEncContext *s){
  2108. int left, ret;
  2109. if(s->codec_id==CODEC_ID_MPEG4)
  2110. skip_bits1(&s->gb);
  2111. align_get_bits(&s->gb);
  2112. if(show_bits(&s->gb, 16)==0){
  2113. if(s->codec_id==CODEC_ID_MPEG4)
  2114. ret= mpeg4_decode_video_packet_header(s);
  2115. else
  2116. ret= h263_decode_gob_header(s);
  2117. if(ret>=0)
  2118. return 0;
  2119. }
  2120. //ok, its not where its supposed to be ...
  2121. s->gb= s->last_resync_gb;
  2122. align_get_bits(&s->gb);
  2123. left= s->gb.size*8 - get_bits_count(&s->gb);
  2124. for(;left>16+1+5+5; left-=8){
  2125. if(show_bits(&s->gb, 16)==0){
  2126. GetBitContext bak= s->gb;
  2127. if(s->codec_id==CODEC_ID_MPEG4)
  2128. ret= mpeg4_decode_video_packet_header(s);
  2129. else
  2130. ret= h263_decode_gob_header(s);
  2131. if(ret>=0)
  2132. return 0;
  2133. s->gb= bak;
  2134. }
  2135. skip_bits(&s->gb, 8);
  2136. }
  2137. return -1;
  2138. }
  2139. /**
  2140. * @param n either 0 for the x component or 1 for y
  2141. * @returns the average MV for a GMC MB
  2142. */
  2143. static inline int get_amv(MpegEncContext *s, int n){
  2144. int x, y, mb_v, sum, dx, dy, shift;
  2145. int len = 1 << (s->f_code + 4);
  2146. const int a= s->sprite_warping_accuracy;
  2147. if(s->real_sprite_warping_points==1){
  2148. if(s->divx_version==500 && s->divx_build==413)
  2149. sum= s->sprite_offset[0][n] / (1<<(a - s->quarter_sample));
  2150. else
  2151. sum= RSHIFT(s->sprite_offset[0][n]<<s->quarter_sample, a);
  2152. }else{
  2153. dx= s->sprite_delta[n][0];
  2154. dy= s->sprite_delta[n][1];
  2155. shift= s->sprite_shift[0];
  2156. if(n) dy -= 1<<(shift + a + 1);
  2157. else dx -= 1<<(shift + a + 1);
  2158. mb_v= s->sprite_offset[0][n] + dx*s->mb_x*16 + dy*s->mb_y*16;
  2159. sum=0;
  2160. for(y=0; y<16; y++){
  2161. int v;
  2162. v= mb_v + dy*y;
  2163. //XXX FIXME optimize
  2164. for(x=0; x<16; x++){
  2165. sum+= v>>shift;
  2166. v+= dx;
  2167. }
  2168. }
  2169. sum /= 256;
  2170. sum= RSHIFT(sum<<s->quarter_sample, a);
  2171. }
  2172. if (sum < -len) sum= -len;
  2173. else if (sum >= len) sum= len-1;
  2174. return sum;
  2175. }
  2176. /**
  2177. * decodes first partition.
  2178. * @return number of MBs decoded or <0 if an error occured
  2179. */
  2180. static int mpeg4_decode_partition_a(MpegEncContext *s){
  2181. int mb_num;
  2182. static const INT8 quant_tab[4] = { -1, -2, 1, 2 };
  2183. /* decode first partition */
  2184. mb_num=0;
  2185. s->first_slice_line=1;
  2186. for(; s->mb_y<s->mb_height; s->mb_y++){
  2187. ff_init_block_index(s);
  2188. for(; s->mb_x<s->mb_width; s->mb_x++){
  2189. const int xy= s->mb_x + s->mb_y*s->mb_width;
  2190. int cbpc;
  2191. int dir=0;
  2192. mb_num++;
  2193. ff_update_block_index(s);
  2194. if(s->mb_x == s->resync_mb_x && s->mb_y == s->resync_mb_y+1)
  2195. s->first_slice_line=0;
  2196. if(s->mb_x==0) PRINT_MB_TYPE("\n");
  2197. if(s->pict_type==I_TYPE){
  2198. int i;
  2199. if(show_bits(&s->gb, 19)==DC_MARKER){
  2200. return mb_num-1;
  2201. }
  2202. PRINT_MB_TYPE("I");
  2203. cbpc = get_vlc2(&s->gb, intra_MCBPC_vlc.table, INTRA_MCBPC_VLC_BITS, 1);
  2204. if (cbpc < 0){
  2205. fprintf(stderr, "cbpc corrupted at %d %d\n", s->mb_x, s->mb_y);
  2206. return -1;
  2207. }
  2208. s->cbp_table[xy]= cbpc & 3;
  2209. s->mb_type[xy]= MB_TYPE_INTRA;
  2210. s->mb_intra = 1;
  2211. if(cbpc & 4) {
  2212. change_qscale(s, quant_tab[get_bits(&s->gb, 2)]);
  2213. }
  2214. s->qscale_table[xy]= s->qscale;
  2215. s->mbintra_table[xy]= 1;
  2216. for(i=0; i<6; i++){
  2217. int dc_pred_dir;
  2218. int dc= mpeg4_decode_dc(s, i, &dc_pred_dir);
  2219. if(dc < 0){
  2220. fprintf(stderr, "DC corrupted at %d %d\n", s->mb_x, s->mb_y);
  2221. return -1;
  2222. }
  2223. dir<<=1;
  2224. if(dc_pred_dir) dir|=1;
  2225. }
  2226. s->pred_dir_table[xy]= dir;
  2227. s->error_status_table[xy]= AC_ERROR;
  2228. }else{ /* P/S_TYPE */
  2229. int mx, my, pred_x, pred_y, bits;
  2230. INT16 * const mot_val= s->motion_val[s->block_index[0]];
  2231. const int stride= s->block_wrap[0]*2;
  2232. bits= show_bits(&s->gb, 17);
  2233. if(bits==MOTION_MARKER){
  2234. return mb_num-1;
  2235. }
  2236. skip_bits1(&s->gb);
  2237. if(bits&0x10000){
  2238. /* skip mb */
  2239. s->mb_type[xy]= MB_TYPE_SKIPED;
  2240. if(s->pict_type==S_TYPE && s->vol_sprite_usage==GMC_SPRITE){
  2241. PRINT_MB_TYPE("G");
  2242. mx= get_amv(s, 0);
  2243. my= get_amv(s, 1);
  2244. }else{
  2245. PRINT_MB_TYPE("S");
  2246. mx=my=0;
  2247. }
  2248. mot_val[0 ]= mot_val[2 ]=
  2249. mot_val[0+stride]= mot_val[2+stride]= mx;
  2250. mot_val[1 ]= mot_val[3 ]=
  2251. mot_val[1+stride]= mot_val[3+stride]= my;
  2252. if(s->mbintra_table[xy])
  2253. ff_clean_intra_table_entries(s);
  2254. s->error_status_table[xy]= AC_ERROR;
  2255. continue;
  2256. }
  2257. cbpc = get_vlc2(&s->gb, inter_MCBPC_vlc.table, INTER_MCBPC_VLC_BITS, 2);
  2258. if (cbpc < 0){
  2259. fprintf(stderr, "cbpc corrupted at %d %d\n", s->mb_x, s->mb_y);
  2260. return -1;
  2261. }
  2262. if (cbpc > 20)
  2263. cbpc+=3;
  2264. else if (cbpc == 20)
  2265. fprintf(stderr, "Stuffing !");
  2266. s->cbp_table[xy]= cbpc&(8+3); //8 is dquant
  2267. s->mb_intra = ((cbpc & 4) != 0);
  2268. if(s->mb_intra){
  2269. PRINT_MB_TYPE("I");
  2270. s->mbintra_table[xy]= 1;
  2271. s->mb_type[xy]= MB_TYPE_INTRA;
  2272. mot_val[0 ]= mot_val[2 ]=
  2273. mot_val[0+stride]= mot_val[2+stride]= 0;
  2274. mot_val[1 ]= mot_val[3 ]=
  2275. mot_val[1+stride]= mot_val[3+stride]= 0;
  2276. s->error_status_table[xy]= DC_ERROR|AC_ERROR;
  2277. }else{
  2278. if(s->mbintra_table[xy])
  2279. ff_clean_intra_table_entries(s);
  2280. if(s->pict_type==S_TYPE && s->vol_sprite_usage==GMC_SPRITE && (cbpc & 16) == 0)
  2281. s->mcsel= get_bits1(&s->gb);
  2282. else s->mcsel= 0;
  2283. if ((cbpc & 16) == 0) {
  2284. PRINT_MB_TYPE("P");
  2285. /* 16x16 motion prediction */
  2286. s->mb_type[xy]= MB_TYPE_INTER;
  2287. h263_pred_motion(s, 0, &pred_x, &pred_y);
  2288. if(!s->mcsel){
  2289. mx = h263_decode_motion(s, pred_x, s->f_code);
  2290. if (mx >= 0xffff)
  2291. return -1;
  2292. my = h263_decode_motion(s, pred_y, s->f_code);
  2293. if (my >= 0xffff)
  2294. return -1;
  2295. } else {
  2296. mx = get_amv(s, 0);
  2297. my = get_amv(s, 1);
  2298. }
  2299. mot_val[0 ]= mot_val[2 ] =
  2300. mot_val[0+stride]= mot_val[2+stride]= mx;
  2301. mot_val[1 ]= mot_val[3 ]=
  2302. mot_val[1+stride]= mot_val[3+stride]= my;
  2303. } else {
  2304. int i;
  2305. PRINT_MB_TYPE("4");
  2306. s->mb_type[xy]= MB_TYPE_INTER4V;
  2307. for(i=0;i<4;i++) {
  2308. INT16 *mot_val= h263_pred_motion(s, i, &pred_x, &pred_y);
  2309. mx = h263_decode_motion(s, pred_x, s->f_code);
  2310. if (mx >= 0xffff)
  2311. return -1;
  2312. my = h263_decode_motion(s, pred_y, s->f_code);
  2313. if (my >= 0xffff)
  2314. return -1;
  2315. mot_val[0] = mx;
  2316. mot_val[1] = my;
  2317. }
  2318. }
  2319. s->error_status_table[xy]= AC_ERROR;
  2320. }
  2321. }
  2322. }
  2323. s->mb_x= 0;
  2324. }
  2325. return mb_num;
  2326. }
  2327. /**
  2328. * decode second partition.
  2329. * @return <0 if an error occured
  2330. */
  2331. static int mpeg4_decode_partition_b(MpegEncContext *s, int mb_count){
  2332. int mb_num=0;
  2333. static const INT8 quant_tab[4] = { -1, -2, 1, 2 };
  2334. s->mb_x= s->resync_mb_x;
  2335. s->first_slice_line=1;
  2336. for(s->mb_y= s->resync_mb_y; mb_num < mb_count; s->mb_y++){
  2337. ff_init_block_index(s);
  2338. for(; mb_num < mb_count && s->mb_x<s->mb_width; s->mb_x++){
  2339. const int xy= s->mb_x + s->mb_y*s->mb_width;
  2340. mb_num++;
  2341. ff_update_block_index(s);
  2342. if(s->mb_x == s->resync_mb_x && s->mb_y == s->resync_mb_y+1)
  2343. s->first_slice_line=0;
  2344. if(s->pict_type==I_TYPE){
  2345. int ac_pred= get_bits1(&s->gb);
  2346. int cbpy = get_vlc2(&s->gb, cbpy_vlc.table, CBPY_VLC_BITS, 1);
  2347. if(cbpy<0){
  2348. fprintf(stderr, "cbpy corrupted at %d %d\n", s->mb_x, s->mb_y);
  2349. return -1;
  2350. }
  2351. s->cbp_table[xy]|= cbpy<<2;
  2352. s->pred_dir_table[xy]|= ac_pred<<7;
  2353. }else{ /* P || S_TYPE */
  2354. if(s->mb_type[xy]&MB_TYPE_INTRA){
  2355. int dir=0,i;
  2356. int ac_pred = get_bits1(&s->gb);
  2357. int cbpy = get_vlc2(&s->gb, cbpy_vlc.table, CBPY_VLC_BITS, 1);
  2358. if(cbpy<0){
  2359. fprintf(stderr, "I cbpy corrupted at %d %d\n", s->mb_x, s->mb_y);
  2360. return -1;
  2361. }
  2362. if(s->cbp_table[xy] & 8) {
  2363. change_qscale(s, quant_tab[get_bits(&s->gb, 2)]);
  2364. }
  2365. s->qscale_table[xy]= s->qscale;
  2366. for(i=0; i<6; i++){
  2367. int dc_pred_dir;
  2368. int dc= mpeg4_decode_dc(s, i, &dc_pred_dir);
  2369. if(dc < 0){
  2370. fprintf(stderr, "DC corrupted at %d %d\n", s->mb_x, s->mb_y);
  2371. return -1;
  2372. }
  2373. dir<<=1;
  2374. if(dc_pred_dir) dir|=1;
  2375. }
  2376. s->cbp_table[xy]&= 3; //remove dquant
  2377. s->cbp_table[xy]|= cbpy<<2;
  2378. s->pred_dir_table[xy]= dir | (ac_pred<<7);
  2379. s->error_status_table[xy]&= ~DC_ERROR;
  2380. }else if(s->mb_type[xy]&MB_TYPE_SKIPED){
  2381. s->qscale_table[xy]= s->qscale;
  2382. s->cbp_table[xy]= 0;
  2383. }else{
  2384. int cbpy = get_vlc2(&s->gb, cbpy_vlc.table, CBPY_VLC_BITS, 1);
  2385. if(cbpy<0){
  2386. fprintf(stderr, "P cbpy corrupted at %d %d\n", s->mb_x, s->mb_y);
  2387. return -1;
  2388. }
  2389. if(s->cbp_table[xy] & 8) {
  2390. change_qscale(s, quant_tab[get_bits(&s->gb, 2)]);
  2391. }
  2392. s->qscale_table[xy]= s->qscale;
  2393. s->cbp_table[xy]&= 3; //remove dquant
  2394. s->cbp_table[xy]|= (cbpy^0xf)<<2;
  2395. }
  2396. }
  2397. }
  2398. if(mb_num >= mb_count) return 0;
  2399. s->mb_x= 0;
  2400. }
  2401. return 0;
  2402. }
  2403. /**
  2404. * decodes the first & second partition
  2405. * @return <0 if error (and sets error type in the error_status_table)
  2406. */
  2407. int ff_mpeg4_decode_partitions(MpegEncContext *s)
  2408. {
  2409. int mb_num;
  2410. mb_num= mpeg4_decode_partition_a(s);
  2411. if(mb_num<0)
  2412. return -1;
  2413. if(s->resync_mb_x + s->resync_mb_y*s->mb_width + mb_num > s->mb_num){
  2414. fprintf(stderr, "slice below monitor ...\n");
  2415. return -1;
  2416. }
  2417. s->mb_num_left= mb_num;
  2418. if(s->pict_type==I_TYPE){
  2419. if(get_bits(&s->gb, 19)!=DC_MARKER){
  2420. fprintf(stderr, "marker missing after first I partition at %d %d\n", s->mb_x, s->mb_y);
  2421. return -1;
  2422. }else
  2423. s->error_status_table[s->mb_x + s->mb_y*s->mb_width-1]|= MV_END|DC_END;
  2424. }else{
  2425. if(get_bits(&s->gb, 17)!=MOTION_MARKER){
  2426. fprintf(stderr, "marker missing after first P partition at %d %d\n", s->mb_x, s->mb_y);
  2427. return -1;
  2428. }else
  2429. s->error_status_table[s->mb_x + s->mb_y*s->mb_width-1]|= MV_END;
  2430. }
  2431. if( mpeg4_decode_partition_b(s, mb_num) < 0){
  2432. return -1;
  2433. }
  2434. s->error_status_table[s->mb_x + s->mb_y*s->mb_width-1]|= DC_END;
  2435. return 0;
  2436. }
  2437. /**
  2438. * decode partition C of one MB.
  2439. * @return <0 if an error occured
  2440. */
  2441. static int mpeg4_decode_partitioned_mb(MpegEncContext *s, DCTELEM block[6][64])
  2442. {
  2443. int cbp, mb_type;
  2444. const int xy= s->mb_x + s->mb_y*s->mb_width;
  2445. mb_type= s->mb_type[xy];
  2446. cbp = s->cbp_table[xy];
  2447. if(s->qscale_table[xy] != s->qscale){
  2448. s->qscale= s->qscale_table[xy];
  2449. s->y_dc_scale= s->y_dc_scale_table[ s->qscale ];
  2450. s->c_dc_scale= s->c_dc_scale_table[ s->qscale ];
  2451. }
  2452. if (s->pict_type == P_TYPE || s->pict_type==S_TYPE) {
  2453. int i;
  2454. for(i=0; i<4; i++){
  2455. s->mv[0][i][0] = s->motion_val[ s->block_index[i] ][0];
  2456. s->mv[0][i][1] = s->motion_val[ s->block_index[i] ][1];
  2457. }
  2458. s->mb_intra = mb_type&MB_TYPE_INTRA;
  2459. if (mb_type&MB_TYPE_SKIPED) {
  2460. /* skip mb */
  2461. for(i=0;i<6;i++)
  2462. s->block_last_index[i] = -1;
  2463. s->mv_dir = MV_DIR_FORWARD;
  2464. s->mv_type = MV_TYPE_16X16;
  2465. if(s->pict_type==S_TYPE && s->vol_sprite_usage==GMC_SPRITE){
  2466. s->mcsel=1;
  2467. s->mb_skiped = 0;
  2468. }else{
  2469. s->mcsel=0;
  2470. s->mb_skiped = 1;
  2471. }
  2472. }else if(s->mb_intra){
  2473. s->ac_pred = s->pred_dir_table[xy]>>7;
  2474. /* decode each block */
  2475. for (i = 0; i < 6; i++) {
  2476. if(mpeg4_decode_block(s, block[i], i, cbp&32, 1) < 0){
  2477. fprintf(stderr, "texture corrupted at %d %d\n", s->mb_x, s->mb_y);
  2478. return -1;
  2479. }
  2480. cbp+=cbp;
  2481. }
  2482. }else if(!s->mb_intra){
  2483. // s->mcsel= 0; //FIXME do we need to init that
  2484. s->mv_dir = MV_DIR_FORWARD;
  2485. if (mb_type&MB_TYPE_INTER4V) {
  2486. s->mv_type = MV_TYPE_8X8;
  2487. } else {
  2488. s->mv_type = MV_TYPE_16X16;
  2489. }
  2490. /* decode each block */
  2491. for (i = 0; i < 6; i++) {
  2492. if(mpeg4_decode_block(s, block[i], i, cbp&32, 0) < 0){
  2493. fprintf(stderr, "texture corrupted at %d %d (trying to continue with mc/dc only)\n", s->mb_x, s->mb_y);
  2494. return -1;
  2495. }
  2496. cbp+=cbp;
  2497. }
  2498. }
  2499. } else { /* I-Frame */
  2500. int i;
  2501. s->mb_intra = 1;
  2502. s->ac_pred = s->pred_dir_table[xy]>>7;
  2503. /* decode each block */
  2504. for (i = 0; i < 6; i++) {
  2505. if(mpeg4_decode_block(s, block[i], i, cbp&32, 1) < 0){
  2506. fprintf(stderr, "texture corrupted at %d %d (trying to continue with dc only)\n", s->mb_x, s->mb_y);
  2507. return -1;
  2508. }
  2509. cbp+=cbp;
  2510. }
  2511. }
  2512. s->error_status_table[xy]&= ~AC_ERROR;
  2513. /* per-MB end of slice check */
  2514. if(--s->mb_num_left <= 0){
  2515. //printf("%06X %d\n", show_bits(&s->gb, 24), s->gb.size*8 - get_bits_count(&s->gb));
  2516. if(mpeg4_is_resync(s))
  2517. return SLICE_END;
  2518. else
  2519. return SLICE_NOEND;
  2520. }else{
  2521. if(s->cbp_table[xy+1] && mpeg4_is_resync(s))
  2522. return SLICE_END;
  2523. else
  2524. return SLICE_OK;
  2525. }
  2526. }
  2527. int ff_h263_decode_mb(MpegEncContext *s,
  2528. DCTELEM block[6][64])
  2529. {
  2530. int cbpc, cbpy, i, cbp, pred_x, pred_y, mx, my, dquant;
  2531. INT16 *mot_val;
  2532. static INT8 quant_tab[4] = { -1, -2, 1, 2 };
  2533. s->error_status_table[s->mb_x + s->mb_y*s->mb_width]= 0;
  2534. if(s->mb_x==0) PRINT_MB_TYPE("\n");
  2535. if (s->pict_type == P_TYPE || s->pict_type==S_TYPE) {
  2536. if (get_bits1(&s->gb)) {
  2537. /* skip mb */
  2538. s->mb_intra = 0;
  2539. for(i=0;i<6;i++)
  2540. s->block_last_index[i] = -1;
  2541. s->mv_dir = MV_DIR_FORWARD;
  2542. s->mv_type = MV_TYPE_16X16;
  2543. if(s->pict_type==S_TYPE && s->vol_sprite_usage==GMC_SPRITE){
  2544. PRINT_MB_TYPE("G");
  2545. s->mcsel=1;
  2546. s->mv[0][0][0]= get_amv(s, 0);
  2547. s->mv[0][0][1]= get_amv(s, 1);
  2548. s->mb_skiped = 0;
  2549. }else{
  2550. PRINT_MB_TYPE("S");
  2551. s->mcsel=0;
  2552. s->mv[0][0][0] = 0;
  2553. s->mv[0][0][1] = 0;
  2554. s->mb_skiped = 1;
  2555. }
  2556. goto end;
  2557. }
  2558. cbpc = get_vlc2(&s->gb, inter_MCBPC_vlc.table, INTER_MCBPC_VLC_BITS, 2);
  2559. //fprintf(stderr, "\tCBPC: %d", cbpc);
  2560. if (cbpc < 0)
  2561. return -1;
  2562. if (cbpc > 20)
  2563. cbpc+=3;
  2564. else if (cbpc == 20)
  2565. fprintf(stderr, "Stuffing !");
  2566. dquant = cbpc & 8;
  2567. s->mb_intra = ((cbpc & 4) != 0);
  2568. if (s->mb_intra) goto intra;
  2569. if(s->pict_type==S_TYPE && s->vol_sprite_usage==GMC_SPRITE && (cbpc & 16) == 0)
  2570. s->mcsel= get_bits1(&s->gb);
  2571. else s->mcsel= 0;
  2572. cbpy = get_vlc2(&s->gb, cbpy_vlc.table, CBPY_VLC_BITS, 1);
  2573. cbp = (cbpc & 3) | ((cbpy ^ 0xf) << 2);
  2574. if (dquant) {
  2575. change_qscale(s, quant_tab[get_bits(&s->gb, 2)]);
  2576. }
  2577. if((!s->progressive_sequence) && (cbp || (s->workaround_bugs&FF_BUG_XVID_ILACE)))
  2578. s->interlaced_dct= get_bits1(&s->gb);
  2579. s->mv_dir = MV_DIR_FORWARD;
  2580. if ((cbpc & 16) == 0) {
  2581. if(s->mcsel){
  2582. PRINT_MB_TYPE("G");
  2583. /* 16x16 global motion prediction */
  2584. s->mv_type = MV_TYPE_16X16;
  2585. mx= get_amv(s, 0);
  2586. my= get_amv(s, 1);
  2587. s->mv[0][0][0] = mx;
  2588. s->mv[0][0][1] = my;
  2589. }else if((!s->progressive_sequence) && get_bits1(&s->gb)){
  2590. PRINT_MB_TYPE("f");
  2591. /* 16x8 field motion prediction */
  2592. s->mv_type= MV_TYPE_FIELD;
  2593. s->field_select[0][0]= get_bits1(&s->gb);
  2594. s->field_select[0][1]= get_bits1(&s->gb);
  2595. h263_pred_motion(s, 0, &pred_x, &pred_y);
  2596. for(i=0; i<2; i++){
  2597. mx = h263_decode_motion(s, pred_x, s->f_code);
  2598. if (mx >= 0xffff)
  2599. return -1;
  2600. my = h263_decode_motion(s, pred_y/2, s->f_code);
  2601. if (my >= 0xffff)
  2602. return -1;
  2603. s->mv[0][i][0] = mx;
  2604. s->mv[0][i][1] = my;
  2605. }
  2606. }else{
  2607. PRINT_MB_TYPE("P");
  2608. /* 16x16 motion prediction */
  2609. s->mv_type = MV_TYPE_16X16;
  2610. h263_pred_motion(s, 0, &pred_x, &pred_y);
  2611. if (s->umvplus_dec)
  2612. mx = h263p_decode_umotion(s, pred_x);
  2613. else
  2614. mx = h263_decode_motion(s, pred_x, s->f_code);
  2615. if (mx >= 0xffff)
  2616. return -1;
  2617. if (s->umvplus_dec)
  2618. my = h263p_decode_umotion(s, pred_y);
  2619. else
  2620. my = h263_decode_motion(s, pred_y, s->f_code);
  2621. if (my >= 0xffff)
  2622. return -1;
  2623. s->mv[0][0][0] = mx;
  2624. s->mv[0][0][1] = my;
  2625. if (s->umvplus_dec && (mx - pred_x) == 1 && (my - pred_y) == 1)
  2626. skip_bits1(&s->gb); /* Bit stuffing to prevent PSC */
  2627. }
  2628. } else {
  2629. PRINT_MB_TYPE("4");
  2630. s->mv_type = MV_TYPE_8X8;
  2631. for(i=0;i<4;i++) {
  2632. mot_val = h263_pred_motion(s, i, &pred_x, &pred_y);
  2633. if (s->umvplus_dec)
  2634. mx = h263p_decode_umotion(s, pred_x);
  2635. else
  2636. mx = h263_decode_motion(s, pred_x, s->f_code);
  2637. if (mx >= 0xffff)
  2638. return -1;
  2639. if (s->umvplus_dec)
  2640. my = h263p_decode_umotion(s, pred_y);
  2641. else
  2642. my = h263_decode_motion(s, pred_y, s->f_code);
  2643. if (my >= 0xffff)
  2644. return -1;
  2645. s->mv[0][i][0] = mx;
  2646. s->mv[0][i][1] = my;
  2647. if (s->umvplus_dec && (mx - pred_x) == 1 && (my - pred_y) == 1)
  2648. skip_bits1(&s->gb); /* Bit stuffing to prevent PSC */
  2649. mot_val[0] = mx;
  2650. mot_val[1] = my;
  2651. }
  2652. }
  2653. } else if(s->pict_type==B_TYPE) {
  2654. int modb1; // first bit of modb
  2655. int modb2; // second bit of modb
  2656. int mb_type;
  2657. uint16_t time_pp;
  2658. uint16_t time_pb;
  2659. int xy;
  2660. s->mb_intra = 0; //B-frames never contain intra blocks
  2661. s->mcsel=0; // ... true gmc blocks
  2662. if(s->mb_x==0){
  2663. for(i=0; i<2; i++){
  2664. s->last_mv[i][0][0]=
  2665. s->last_mv[i][0][1]=
  2666. s->last_mv[i][1][0]=
  2667. s->last_mv[i][1][1]= 0;
  2668. }
  2669. }
  2670. /* if we skipped it in the future P Frame than skip it now too */
  2671. s->mb_skiped= s->mbskip_table[s->mb_y * s->mb_width + s->mb_x]; // Note, skiptab=0 if last was GMC
  2672. if(s->mb_skiped){
  2673. /* skip mb */
  2674. for(i=0;i<6;i++)
  2675. s->block_last_index[i] = -1;
  2676. s->mv_dir = MV_DIR_FORWARD;
  2677. s->mv_type = MV_TYPE_16X16;
  2678. s->mv[0][0][0] = 0;
  2679. s->mv[0][0][1] = 0;
  2680. s->mv[1][0][0] = 0;
  2681. s->mv[1][0][1] = 0;
  2682. PRINT_MB_TYPE("s");
  2683. goto end;
  2684. }
  2685. modb1= get_bits1(&s->gb);
  2686. if(modb1){
  2687. mb_type=4; //like MB_TYPE_B_DIRECT but no vectors coded
  2688. cbp=0;
  2689. }else{
  2690. int field_mv;
  2691. modb2= get_bits1(&s->gb);
  2692. mb_type= get_vlc2(&s->gb, mb_type_b_vlc.table, MB_TYPE_B_VLC_BITS, 1);
  2693. if(modb2) cbp= 0;
  2694. else cbp= get_bits(&s->gb, 6);
  2695. if (mb_type!=MB_TYPE_B_DIRECT && cbp) {
  2696. if(get_bits1(&s->gb)){
  2697. change_qscale(s, get_bits1(&s->gb)*4 - 2);
  2698. }
  2699. }
  2700. field_mv=0;
  2701. if(!s->progressive_sequence){
  2702. if(cbp)
  2703. s->interlaced_dct= get_bits1(&s->gb);
  2704. if(mb_type!=MB_TYPE_B_DIRECT && get_bits1(&s->gb)){
  2705. field_mv=1;
  2706. if(mb_type!=MB_TYPE_B_BACKW){
  2707. s->field_select[0][0]= get_bits1(&s->gb);
  2708. s->field_select[0][1]= get_bits1(&s->gb);
  2709. }
  2710. if(mb_type!=MB_TYPE_B_FORW){
  2711. s->field_select[1][0]= get_bits1(&s->gb);
  2712. s->field_select[1][1]= get_bits1(&s->gb);
  2713. }
  2714. }
  2715. }
  2716. s->mv_dir = 0;
  2717. if(mb_type!=MB_TYPE_B_DIRECT && !field_mv){
  2718. s->mv_type= MV_TYPE_16X16;
  2719. if(mb_type!=MB_TYPE_B_BACKW){
  2720. s->mv_dir = MV_DIR_FORWARD;
  2721. mx = h263_decode_motion(s, s->last_mv[0][0][0], s->f_code);
  2722. my = h263_decode_motion(s, s->last_mv[0][0][1], s->f_code);
  2723. s->last_mv[0][1][0]= s->last_mv[0][0][0]= s->mv[0][0][0] = mx;
  2724. s->last_mv[0][1][1]= s->last_mv[0][0][1]= s->mv[0][0][1] = my;
  2725. }
  2726. if(mb_type!=MB_TYPE_B_FORW){
  2727. s->mv_dir |= MV_DIR_BACKWARD;
  2728. mx = h263_decode_motion(s, s->last_mv[1][0][0], s->b_code);
  2729. my = h263_decode_motion(s, s->last_mv[1][0][1], s->b_code);
  2730. s->last_mv[1][1][0]= s->last_mv[1][0][0]= s->mv[1][0][0] = mx;
  2731. s->last_mv[1][1][1]= s->last_mv[1][0][1]= s->mv[1][0][1] = my;
  2732. }
  2733. if(mb_type!=MB_TYPE_B_DIRECT)
  2734. PRINT_MB_TYPE(mb_type==MB_TYPE_B_FORW ? "F" : (mb_type==MB_TYPE_B_BACKW ? "B" : "T"));
  2735. }else if(mb_type!=MB_TYPE_B_DIRECT){
  2736. s->mv_type= MV_TYPE_FIELD;
  2737. if(mb_type!=MB_TYPE_B_BACKW){
  2738. s->mv_dir = MV_DIR_FORWARD;
  2739. for(i=0; i<2; i++){
  2740. mx = h263_decode_motion(s, s->last_mv[0][i][0] , s->f_code);
  2741. my = h263_decode_motion(s, s->last_mv[0][i][1]/2, s->f_code);
  2742. s->last_mv[0][i][0]= s->mv[0][i][0] = mx;
  2743. s->last_mv[0][i][1]= (s->mv[0][i][1] = my)*2;
  2744. }
  2745. }
  2746. if(mb_type!=MB_TYPE_B_FORW){
  2747. s->mv_dir |= MV_DIR_BACKWARD;
  2748. for(i=0; i<2; i++){
  2749. mx = h263_decode_motion(s, s->last_mv[1][i][0] , s->b_code);
  2750. my = h263_decode_motion(s, s->last_mv[1][i][1]/2, s->b_code);
  2751. s->last_mv[1][i][0]= s->mv[1][i][0] = mx;
  2752. s->last_mv[1][i][1]= (s->mv[1][i][1] = my)*2;
  2753. }
  2754. }
  2755. if(mb_type!=MB_TYPE_B_DIRECT)
  2756. PRINT_MB_TYPE(mb_type==MB_TYPE_B_FORW ? "f" : (mb_type==MB_TYPE_B_BACKW ? "b" : "t"));
  2757. }
  2758. }
  2759. if(mb_type==4 || mb_type==MB_TYPE_B_DIRECT){
  2760. int mb_index= s->mb_x + s->mb_y*s->mb_width;
  2761. int i;
  2762. if(mb_type==4)
  2763. mx=my=0;
  2764. else{
  2765. mx = h263_decode_motion(s, 0, 1);
  2766. my = h263_decode_motion(s, 0, 1);
  2767. }
  2768. s->mv_dir = MV_DIR_FORWARD | MV_DIR_BACKWARD | MV_DIRECT;
  2769. xy= s->block_index[0];
  2770. time_pp= s->pp_time;
  2771. time_pb= s->pb_time;
  2772. //FIXME avoid divides
  2773. switch(s->co_located_type_table[mb_index]){
  2774. case 0:
  2775. s->mv_type= MV_TYPE_16X16;
  2776. s->mv[0][0][0] = s->motion_val[xy][0]*time_pb/time_pp + mx;
  2777. s->mv[0][0][1] = s->motion_val[xy][1]*time_pb/time_pp + my;
  2778. s->mv[1][0][0] = mx ? s->mv[0][0][0] - s->motion_val[xy][0]
  2779. : s->motion_val[xy][0]*(time_pb - time_pp)/time_pp;
  2780. s->mv[1][0][1] = my ? s->mv[0][0][1] - s->motion_val[xy][1]
  2781. : s->motion_val[xy][1]*(time_pb - time_pp)/time_pp;
  2782. PRINT_MB_TYPE(mb_type==4 ? "D" : "S");
  2783. break;
  2784. case CO_LOCATED_TYPE_4MV:
  2785. s->mv_type = MV_TYPE_8X8;
  2786. for(i=0; i<4; i++){
  2787. xy= s->block_index[i];
  2788. s->mv[0][i][0] = s->motion_val[xy][0]*time_pb/time_pp + mx;
  2789. s->mv[0][i][1] = s->motion_val[xy][1]*time_pb/time_pp + my;
  2790. s->mv[1][i][0] = mx ? s->mv[0][i][0] - s->motion_val[xy][0]
  2791. : s->motion_val[xy][0]*(time_pb - time_pp)/time_pp;
  2792. s->mv[1][i][1] = my ? s->mv[0][i][1] - s->motion_val[xy][1]
  2793. : s->motion_val[xy][1]*(time_pb - time_pp)/time_pp;
  2794. }
  2795. PRINT_MB_TYPE("4");
  2796. break;
  2797. case CO_LOCATED_TYPE_FIELDMV:
  2798. s->mv_type = MV_TYPE_FIELD;
  2799. for(i=0; i<2; i++){
  2800. if(s->top_field_first){
  2801. time_pp= s->pp_field_time - s->field_select_table[mb_index][i] + i;
  2802. time_pb= s->pb_field_time - s->field_select_table[mb_index][i] + i;
  2803. }else{
  2804. time_pp= s->pp_field_time + s->field_select_table[mb_index][i] - i;
  2805. time_pb= s->pb_field_time + s->field_select_table[mb_index][i] - i;
  2806. }
  2807. s->mv[0][i][0] = s->field_mv_table[mb_index][i][0]*time_pb/time_pp + mx;
  2808. s->mv[0][i][1] = s->field_mv_table[mb_index][i][1]*time_pb/time_pp + my;
  2809. s->mv[1][i][0] = mx ? s->mv[0][i][0] - s->field_mv_table[mb_index][i][0]
  2810. : s->field_mv_table[mb_index][i][0]*(time_pb - time_pp)/time_pp;
  2811. s->mv[1][i][1] = my ? s->mv[0][i][1] - s->field_mv_table[mb_index][i][1]
  2812. : s->field_mv_table[mb_index][i][1]*(time_pb - time_pp)/time_pp;
  2813. }
  2814. PRINT_MB_TYPE("=");
  2815. break;
  2816. }
  2817. }
  2818. if(mb_type<0 || mb_type>4){
  2819. printf("illegal MB_type\n");
  2820. return -1;
  2821. }
  2822. } else { /* I-Frame */
  2823. cbpc = get_vlc2(&s->gb, intra_MCBPC_vlc.table, INTRA_MCBPC_VLC_BITS, 1);
  2824. if (cbpc < 0)
  2825. return -1;
  2826. dquant = cbpc & 4;
  2827. s->mb_intra = 1;
  2828. intra:
  2829. s->ac_pred = 0;
  2830. if (s->h263_pred || s->h263_aic) {
  2831. s->ac_pred = get_bits1(&s->gb);
  2832. if (s->ac_pred && s->h263_aic)
  2833. s->h263_aic_dir = get_bits1(&s->gb);
  2834. }
  2835. PRINT_MB_TYPE(s->ac_pred ? "A" : "I");
  2836. cbpy = get_vlc2(&s->gb, cbpy_vlc.table, CBPY_VLC_BITS, 1);
  2837. if(cbpy<0) return -1;
  2838. cbp = (cbpc & 3) | (cbpy << 2);
  2839. if (dquant) {
  2840. change_qscale(s, quant_tab[get_bits(&s->gb, 2)]);
  2841. }
  2842. if(!s->progressive_sequence)
  2843. s->interlaced_dct= get_bits1(&s->gb);
  2844. /* decode each block */
  2845. if (s->h263_pred) {
  2846. for (i = 0; i < 6; i++) {
  2847. if (mpeg4_decode_block(s, block[i], i, cbp&32, 1) < 0)
  2848. return -1;
  2849. cbp+=cbp;
  2850. }
  2851. } else {
  2852. for (i = 0; i < 6; i++) {
  2853. if (h263_decode_block(s, block[i], i, cbp&32) < 0)
  2854. return -1;
  2855. cbp+=cbp;
  2856. }
  2857. }
  2858. goto end;
  2859. }
  2860. /* decode each block */
  2861. if (s->h263_pred) {
  2862. for (i = 0; i < 6; i++) {
  2863. if (mpeg4_decode_block(s, block[i], i, cbp&32, 0) < 0)
  2864. return -1;
  2865. cbp+=cbp;
  2866. }
  2867. } else {
  2868. for (i = 0; i < 6; i++) {
  2869. if (h263_decode_block(s, block[i], i, cbp&32) < 0)
  2870. return -1;
  2871. cbp+=cbp;
  2872. }
  2873. }
  2874. end:
  2875. /* per-MB end of slice check */
  2876. if(s->codec_id==CODEC_ID_MPEG4){
  2877. if(mpeg4_is_resync(s)){
  2878. if(s->pict_type==B_TYPE && s->mbskip_table[s->mb_y * s->mb_width + s->mb_x+1])
  2879. return SLICE_OK;
  2880. return SLICE_END;
  2881. }
  2882. }else{
  2883. if(get_bits_count(&s->gb) + 7 >= s->gb.size*8){
  2884. int v= show_bits(&s->gb, 8) >> (((get_bits_count(&s->gb)-1)&7)+1);
  2885. if(v==0)
  2886. return SLICE_END;
  2887. }else{
  2888. if(show_bits(&s->gb, 16)==0)
  2889. return SLICE_END;
  2890. }
  2891. }
  2892. return SLICE_OK;
  2893. }
  2894. static int h263_decode_motion(MpegEncContext * s, int pred, int f_code)
  2895. {
  2896. int code, val, sign, shift, l;
  2897. code = get_vlc2(&s->gb, mv_vlc.table, MV_VLC_BITS, 2);
  2898. if (code < 0)
  2899. return 0xffff;
  2900. if (code == 0)
  2901. return pred;
  2902. sign = get_bits1(&s->gb);
  2903. shift = f_code - 1;
  2904. val = (code - 1) << shift;
  2905. if (shift > 0)
  2906. val |= get_bits(&s->gb, shift);
  2907. val++;
  2908. if (sign)
  2909. val = -val;
  2910. val += pred;
  2911. /* modulo decoding */
  2912. if (!s->h263_long_vectors) {
  2913. l = 1 << (f_code + 4);
  2914. if (val < -l) {
  2915. val += l<<1;
  2916. } else if (val >= l) {
  2917. val -= l<<1;
  2918. }
  2919. } else {
  2920. /* horrible h263 long vector mode */
  2921. if (pred < -31 && val < -63)
  2922. val += 64;
  2923. if (pred > 32 && val > 63)
  2924. val -= 64;
  2925. }
  2926. return val;
  2927. }
  2928. /* Decodes RVLC of H.263+ UMV */
  2929. static int h263p_decode_umotion(MpegEncContext * s, int pred)
  2930. {
  2931. int code = 0, sign;
  2932. if (get_bits1(&s->gb)) /* Motion difference = 0 */
  2933. return pred;
  2934. code = 2 + get_bits1(&s->gb);
  2935. while (get_bits1(&s->gb))
  2936. {
  2937. code <<= 1;
  2938. code += get_bits1(&s->gb);
  2939. }
  2940. sign = code & 1;
  2941. code >>= 1;
  2942. code = (sign) ? (pred - code) : (pred + code);
  2943. #ifdef DEBUG
  2944. fprintf(stderr,"H.263+ UMV Motion = %d\n", code);
  2945. #endif
  2946. return code;
  2947. }
  2948. static int h263_decode_block(MpegEncContext * s, DCTELEM * block,
  2949. int n, int coded)
  2950. {
  2951. int code, level, i, j, last, run;
  2952. RLTable *rl = &rl_inter;
  2953. const UINT8 *scan_table;
  2954. scan_table = s->intra_scantable.permutated;
  2955. if (s->h263_aic && s->mb_intra) {
  2956. rl = &rl_intra_aic;
  2957. i = 0;
  2958. if (s->ac_pred) {
  2959. if (s->h263_aic_dir)
  2960. scan_table = s->intra_v_scantable.permutated; /* left */
  2961. else
  2962. scan_table = s->intra_h_scantable.permutated; /* top */
  2963. }
  2964. } else if (s->mb_intra) {
  2965. /* DC coef */
  2966. if (s->h263_rv10 && s->rv10_version == 3 && s->pict_type == I_TYPE) {
  2967. int component, diff;
  2968. component = (n <= 3 ? 0 : n - 4 + 1);
  2969. level = s->last_dc[component];
  2970. if (s->rv10_first_dc_coded[component]) {
  2971. diff = rv_decode_dc(s, n);
  2972. if (diff == 0xffff)
  2973. return -1;
  2974. level += diff;
  2975. level = level & 0xff; /* handle wrap round */
  2976. s->last_dc[component] = level;
  2977. } else {
  2978. s->rv10_first_dc_coded[component] = 1;
  2979. }
  2980. } else {
  2981. level = get_bits(&s->gb, 8);
  2982. if (level == 255)
  2983. level = 128;
  2984. }
  2985. block[0] = level;
  2986. i = 1;
  2987. } else {
  2988. i = 0;
  2989. }
  2990. if (!coded) {
  2991. if (s->mb_intra && s->h263_aic)
  2992. goto not_coded;
  2993. s->block_last_index[n] = i - 1;
  2994. return 0;
  2995. }
  2996. for(;;) {
  2997. code = get_vlc2(&s->gb, rl->vlc.table, TEX_VLC_BITS, 2);
  2998. if (code < 0){
  2999. fprintf(stderr, "illegal ac vlc code at %dx%d\n", s->mb_x, s->mb_y);
  3000. return -1;
  3001. }
  3002. if (code == rl->n) {
  3003. /* escape */
  3004. last = get_bits1(&s->gb);
  3005. run = get_bits(&s->gb, 6);
  3006. level = (INT8)get_bits(&s->gb, 8);
  3007. if (s->h263_rv10 && level == -128) {
  3008. /* XXX: should patch encoder too */
  3009. level = get_bits(&s->gb, 12);
  3010. level= (level + ((-1)<<11)) ^ ((-1)<<11); //sign extension
  3011. }
  3012. } else {
  3013. run = rl->table_run[code];
  3014. level = rl->table_level[code];
  3015. last = code >= rl->last;
  3016. if (get_bits1(&s->gb))
  3017. level = -level;
  3018. }
  3019. i += run;
  3020. if (i >= 64){
  3021. fprintf(stderr, "run overflow at %dx%d\n", s->mb_x, s->mb_y);
  3022. return -1;
  3023. }
  3024. j = scan_table[i];
  3025. block[j] = level;
  3026. if (last)
  3027. break;
  3028. i++;
  3029. }
  3030. not_coded:
  3031. if (s->mb_intra && s->h263_aic) {
  3032. h263_pred_acdc(s, block, n);
  3033. i = 63;
  3034. }
  3035. s->block_last_index[n] = i;
  3036. return 0;
  3037. }
  3038. static inline int mpeg4_decode_dc(MpegEncContext * s, int n, int *dir_ptr)
  3039. {
  3040. int level, pred, code;
  3041. UINT16 *dc_val;
  3042. if (n < 4)
  3043. code = get_vlc2(&s->gb, dc_lum.table, DC_VLC_BITS, 1);
  3044. else
  3045. code = get_vlc2(&s->gb, dc_chrom.table, DC_VLC_BITS, 1);
  3046. if (code < 0 || code > 9 /* && s->nbit<9 */){
  3047. fprintf(stderr, "illegal dc vlc\n");
  3048. return -1;
  3049. }
  3050. if (code == 0) {
  3051. level = 0;
  3052. } else {
  3053. level = get_bits(&s->gb, code);
  3054. if ((level >> (code - 1)) == 0) /* if MSB not set it is negative*/
  3055. level = - (level ^ ((1 << code) - 1));
  3056. if (code > 8){
  3057. if(get_bits1(&s->gb)==0){ /* marker */
  3058. if(s->error_resilience>=2){
  3059. fprintf(stderr, "dc marker bit missing\n");
  3060. return -1;
  3061. }
  3062. }
  3063. }
  3064. }
  3065. pred = ff_mpeg4_pred_dc(s, n, &dc_val, dir_ptr);
  3066. level += pred;
  3067. if (level < 0){
  3068. if(s->error_resilience>=3){
  3069. fprintf(stderr, "dc<0 at %dx%d\n", s->mb_x, s->mb_y);
  3070. return -1;
  3071. }
  3072. level = 0;
  3073. }
  3074. if (n < 4) {
  3075. *dc_val = level * s->y_dc_scale;
  3076. } else {
  3077. *dc_val = level * s->c_dc_scale;
  3078. }
  3079. if(s->error_resilience>=3){
  3080. if(*dc_val > 2048 + s->y_dc_scale + s->c_dc_scale){
  3081. fprintf(stderr, "dc overflow at %dx%d\n", s->mb_x, s->mb_y);
  3082. return -1;
  3083. }
  3084. }
  3085. return level;
  3086. }
  3087. /**
  3088. * decodes a block.
  3089. * @return <0 if an error occured
  3090. */
  3091. static inline int mpeg4_decode_block(MpegEncContext * s, DCTELEM * block,
  3092. int n, int coded, int intra)
  3093. {
  3094. int level, i, last, run;
  3095. int dc_pred_dir;
  3096. RLTable * rl;
  3097. RL_VLC_ELEM * rl_vlc;
  3098. const UINT8 * scan_table;
  3099. int qmul, qadd;
  3100. if(intra) {
  3101. /* DC coef */
  3102. if(s->partitioned_frame){
  3103. level = s->dc_val[0][ s->block_index[n] ];
  3104. if(n<4) level= (level + (s->y_dc_scale>>1))/s->y_dc_scale; //FIXME optimizs
  3105. else level= (level + (s->c_dc_scale>>1))/s->c_dc_scale;
  3106. dc_pred_dir= (s->pred_dir_table[s->mb_x + s->mb_y*s->mb_width]<<n)&32;
  3107. }else{
  3108. level = mpeg4_decode_dc(s, n, &dc_pred_dir);
  3109. if (level < 0)
  3110. return -1;
  3111. }
  3112. block[0] = level;
  3113. i = 0;
  3114. if (!coded)
  3115. goto not_coded;
  3116. rl = &rl_intra;
  3117. rl_vlc = rl_intra.rl_vlc[0];
  3118. if (s->ac_pred) {
  3119. if (dc_pred_dir == 0)
  3120. scan_table = s->intra_v_scantable.permutated; /* left */
  3121. else
  3122. scan_table = s->intra_h_scantable.permutated; /* top */
  3123. } else {
  3124. scan_table = s->intra_scantable.permutated;
  3125. }
  3126. qmul=1;
  3127. qadd=0;
  3128. } else {
  3129. i = -1;
  3130. if (!coded) {
  3131. s->block_last_index[n] = i;
  3132. return 0;
  3133. }
  3134. rl = &rl_inter;
  3135. scan_table = s->intra_scantable.permutated;
  3136. if(s->mpeg_quant){
  3137. qmul=1;
  3138. qadd=0;
  3139. rl_vlc = rl_inter.rl_vlc[0];
  3140. }else{
  3141. qmul = s->qscale << 1;
  3142. qadd = (s->qscale - 1) | 1;
  3143. rl_vlc = rl_inter.rl_vlc[s->qscale];
  3144. }
  3145. }
  3146. {
  3147. OPEN_READER(re, &s->gb);
  3148. for(;;) {
  3149. UPDATE_CACHE(re, &s->gb);
  3150. GET_RL_VLC(level, run, re, &s->gb, rl_vlc, TEX_VLC_BITS, 2);
  3151. if (level==0) {
  3152. int cache;
  3153. cache= GET_CACHE(re, &s->gb);
  3154. /* escape */
  3155. if (cache&0x80000000) {
  3156. if (cache&0x40000000) {
  3157. /* third escape */
  3158. SKIP_CACHE(re, &s->gb, 2);
  3159. last= SHOW_UBITS(re, &s->gb, 1); SKIP_CACHE(re, &s->gb, 1);
  3160. run= SHOW_UBITS(re, &s->gb, 6); LAST_SKIP_CACHE(re, &s->gb, 6);
  3161. SKIP_COUNTER(re, &s->gb, 2+1+6);
  3162. UPDATE_CACHE(re, &s->gb);
  3163. if(SHOW_UBITS(re, &s->gb, 1)==0){
  3164. fprintf(stderr, "1. marker bit missing in 3. esc\n");
  3165. return -1;
  3166. }; SKIP_CACHE(re, &s->gb, 1);
  3167. level= SHOW_SBITS(re, &s->gb, 12); SKIP_CACHE(re, &s->gb, 12);
  3168. if(SHOW_UBITS(re, &s->gb, 1)==0){
  3169. fprintf(stderr, "2. marker bit missing in 3. esc\n");
  3170. return -1;
  3171. }; LAST_SKIP_CACHE(re, &s->gb, 1);
  3172. SKIP_COUNTER(re, &s->gb, 1+12+1);
  3173. if(level*s->qscale>1024 || level*s->qscale<-1024){
  3174. fprintf(stderr, "|level| overflow in 3. esc, qp=%d\n", s->qscale);
  3175. return -1;
  3176. }
  3177. #if 1
  3178. {
  3179. const int abs_level= ABS(level);
  3180. if(abs_level<=MAX_LEVEL && run<=MAX_RUN && ((s->workaround_bugs&FF_BUG_AC_VLC)==0)){
  3181. const int run1= run - rl->max_run[last][abs_level] - 1;
  3182. if(abs_level <= rl->max_level[last][run]){
  3183. fprintf(stderr, "illegal 3. esc, vlc encoding possible\n");
  3184. return -1;
  3185. }
  3186. if(abs_level <= rl->max_level[last][run]*2){
  3187. fprintf(stderr, "illegal 3. esc, esc 1 encoding possible\n");
  3188. return -1;
  3189. }
  3190. if(run1 >= 0 && abs_level <= rl->max_level[last][run1]){
  3191. fprintf(stderr, "illegal 3. esc, esc 2 encoding possible\n");
  3192. return -1;
  3193. }
  3194. }
  3195. }
  3196. #endif
  3197. if (level>0) level= level * qmul + qadd;
  3198. else level= level * qmul - qadd;
  3199. i+= run + 1;
  3200. if(last) i+=192;
  3201. } else {
  3202. /* second escape */
  3203. #if MIN_CACHE_BITS < 20
  3204. LAST_SKIP_BITS(re, &s->gb, 2);
  3205. UPDATE_CACHE(re, &s->gb);
  3206. #else
  3207. SKIP_BITS(re, &s->gb, 2);
  3208. #endif
  3209. GET_RL_VLC(level, run, re, &s->gb, rl_vlc, TEX_VLC_BITS, 2);
  3210. i+= run + rl->max_run[run>>7][level/qmul] +1; //FIXME opt indexing
  3211. level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
  3212. LAST_SKIP_BITS(re, &s->gb, 1);
  3213. }
  3214. } else {
  3215. /* first escape */
  3216. #if MIN_CACHE_BITS < 19
  3217. LAST_SKIP_BITS(re, &s->gb, 1);
  3218. UPDATE_CACHE(re, &s->gb);
  3219. #else
  3220. SKIP_BITS(re, &s->gb, 1);
  3221. #endif
  3222. GET_RL_VLC(level, run, re, &s->gb, rl_vlc, TEX_VLC_BITS, 2);
  3223. i+= run;
  3224. level = level + rl->max_level[run>>7][(run-1)&63] * qmul;//FIXME opt indexing
  3225. level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
  3226. LAST_SKIP_BITS(re, &s->gb, 1);
  3227. }
  3228. } else {
  3229. i+= run;
  3230. level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
  3231. LAST_SKIP_BITS(re, &s->gb, 1);
  3232. }
  3233. if (i > 62){
  3234. i-= 192;
  3235. if(i&(~63)){
  3236. fprintf(stderr, "ac-tex damaged at %d %d\n", s->mb_x, s->mb_y);
  3237. return -1;
  3238. }
  3239. block[scan_table[i]] = level;
  3240. break;
  3241. }
  3242. block[scan_table[i]] = level;
  3243. }
  3244. CLOSE_READER(re, &s->gb);
  3245. }
  3246. not_coded:
  3247. if (s->mb_intra) {
  3248. mpeg4_pred_ac(s, block, n, dc_pred_dir);
  3249. if (s->ac_pred) {
  3250. i = 63; /* XXX: not optimal */
  3251. }
  3252. }
  3253. s->block_last_index[n] = i;
  3254. return 0;
  3255. }
  3256. /* most is hardcoded. should extend to handle all h263 streams */
  3257. int h263_decode_picture_header(MpegEncContext *s)
  3258. {
  3259. int format, width, height;
  3260. /* picture start code */
  3261. if (get_bits(&s->gb, 22) != 0x20) {
  3262. fprintf(stderr, "Bad picture start code\n");
  3263. return -1;
  3264. }
  3265. /* temporal reference */
  3266. s->picture_number = get_bits(&s->gb, 8); /* picture timestamp */
  3267. /* PTYPE starts here */
  3268. if (get_bits1(&s->gb) != 1) {
  3269. /* marker */
  3270. fprintf(stderr, "Bad marker\n");
  3271. return -1;
  3272. }
  3273. if (get_bits1(&s->gb) != 0) {
  3274. fprintf(stderr, "Bad H263 id\n");
  3275. return -1; /* h263 id */
  3276. }
  3277. skip_bits1(&s->gb); /* split screen off */
  3278. skip_bits1(&s->gb); /* camera off */
  3279. skip_bits1(&s->gb); /* freeze picture release off */
  3280. /* Reset GOB number */
  3281. s->gob_number = 0;
  3282. format = get_bits(&s->gb, 3);
  3283. /*
  3284. 0 forbidden
  3285. 1 sub-QCIF
  3286. 10 QCIF
  3287. 7 extended PTYPE (PLUSPTYPE)
  3288. */
  3289. if (format != 7 && format != 6) {
  3290. s->h263_plus = 0;
  3291. /* H.263v1 */
  3292. width = h263_format[format][0];
  3293. height = h263_format[format][1];
  3294. if (!width)
  3295. return -1;
  3296. s->width = width;
  3297. s->height = height;
  3298. s->pict_type = I_TYPE + get_bits1(&s->gb);
  3299. s->unrestricted_mv = get_bits1(&s->gb);
  3300. s->h263_long_vectors = s->unrestricted_mv;
  3301. if (get_bits1(&s->gb) != 0) {
  3302. fprintf(stderr, "H263 SAC not supported\n");
  3303. return -1; /* SAC: off */
  3304. }
  3305. if (get_bits1(&s->gb) != 0) {
  3306. s->mv_type = MV_TYPE_8X8; /* Advanced prediction mode */
  3307. }
  3308. if (get_bits1(&s->gb) != 0) {
  3309. fprintf(stderr, "H263 PB frame not supported\n");
  3310. return -1; /* not PB frame */
  3311. }
  3312. s->qscale = get_bits(&s->gb, 5);
  3313. skip_bits1(&s->gb); /* Continuous Presence Multipoint mode: off */
  3314. } else {
  3315. int ufep;
  3316. /* H.263v2 */
  3317. s->h263_plus = 1;
  3318. ufep = get_bits(&s->gb, 3); /* Update Full Extended PTYPE */
  3319. /* ufep other than 0 and 1 are reserved */
  3320. if (ufep == 1) {
  3321. /* OPPTYPE */
  3322. format = get_bits(&s->gb, 3);
  3323. dprintf("ufep=1, format: %d\n", format);
  3324. skip_bits(&s->gb,1); /* Custom PCF */
  3325. s->umvplus_dec = get_bits(&s->gb, 1); /* Unrestricted Motion Vector */
  3326. skip_bits1(&s->gb); /* Syntax-based Arithmetic Coding (SAC) */
  3327. if (get_bits1(&s->gb) != 0) {
  3328. s->mv_type = MV_TYPE_8X8; /* Advanced prediction mode */
  3329. }
  3330. if (get_bits1(&s->gb) != 0) { /* Advanced Intra Coding (AIC) */
  3331. s->h263_aic = 1;
  3332. }
  3333. skip_bits(&s->gb, 7);
  3334. /* these are the 7 bits: (in order of appearence */
  3335. /* Deblocking Filter */
  3336. /* Slice Structured */
  3337. /* Reference Picture Selection */
  3338. /* Independent Segment Decoding */
  3339. /* Alternative Inter VLC */
  3340. /* Modified Quantization */
  3341. /* Prevent start code emulation */
  3342. skip_bits(&s->gb, 3); /* Reserved */
  3343. } else if (ufep != 0) {
  3344. fprintf(stderr, "Bad UFEP type (%d)\n", ufep);
  3345. return -1;
  3346. }
  3347. /* MPPTYPE */
  3348. s->pict_type = get_bits(&s->gb, 3) + I_TYPE;
  3349. dprintf("pict_type: %d\n", s->pict_type);
  3350. if (s->pict_type != I_TYPE &&
  3351. s->pict_type != P_TYPE)
  3352. return -1;
  3353. skip_bits(&s->gb, 2);
  3354. s->no_rounding = get_bits1(&s->gb);
  3355. dprintf("RTYPE: %d\n", s->no_rounding);
  3356. skip_bits(&s->gb, 4);
  3357. /* Get the picture dimensions */
  3358. if (ufep) {
  3359. if (format == 6) {
  3360. /* Custom Picture Format (CPFMT) */
  3361. s->aspect_ratio_info = get_bits(&s->gb, 4);
  3362. dprintf("aspect: %d\n", s->aspect_ratio_info);
  3363. /* aspect ratios:
  3364. 0 - forbidden
  3365. 1 - 1:1
  3366. 2 - 12:11 (CIF 4:3)
  3367. 3 - 10:11 (525-type 4:3)
  3368. 4 - 16:11 (CIF 16:9)
  3369. 5 - 40:33 (525-type 16:9)
  3370. 6-14 - reserved
  3371. */
  3372. width = (get_bits(&s->gb, 9) + 1) * 4;
  3373. skip_bits1(&s->gb);
  3374. height = get_bits(&s->gb, 9) * 4;
  3375. dprintf("\nH.263+ Custom picture: %dx%d\n",width,height);
  3376. if (s->aspect_ratio_info == FF_ASPECT_EXTENDED) {
  3377. /* aspected dimensions */
  3378. s->aspected_width = get_bits(&s->gb, 8);
  3379. s->aspected_height = get_bits(&s->gb, 8);
  3380. }else{
  3381. s->aspected_width = pixel_aspect[s->aspect_ratio_info][0];
  3382. s->aspected_height= pixel_aspect[s->aspect_ratio_info][1];
  3383. }
  3384. } else {
  3385. width = h263_format[format][0];
  3386. height = h263_format[format][1];
  3387. }
  3388. if ((width == 0) || (height == 0))
  3389. return -1;
  3390. s->width = width;
  3391. s->height = height;
  3392. if (s->umvplus_dec) {
  3393. skip_bits1(&s->gb); /* Unlimited Unrestricted Motion Vectors Indicator (UUI) */
  3394. }
  3395. }
  3396. s->qscale = get_bits(&s->gb, 5);
  3397. }
  3398. /* PEI */
  3399. while (get_bits1(&s->gb) != 0) {
  3400. skip_bits(&s->gb, 8);
  3401. }
  3402. s->f_code = 1;
  3403. if(s->h263_aic){
  3404. s->y_dc_scale_table=
  3405. s->c_dc_scale_table= h263_aic_dc_scale_table;
  3406. }else{
  3407. s->y_dc_scale_table=
  3408. s->c_dc_scale_table= ff_mpeg1_dc_scale_table;
  3409. }
  3410. return 0;
  3411. }
  3412. static void mpeg4_decode_sprite_trajectory(MpegEncContext * s)
  3413. {
  3414. int i;
  3415. int a= 2<<s->sprite_warping_accuracy;
  3416. int rho= 3-s->sprite_warping_accuracy;
  3417. int r=16/a;
  3418. const int vop_ref[4][2]= {{0,0}, {s->width,0}, {0, s->height}, {s->width, s->height}}; // only true for rectangle shapes
  3419. int d[4][2]={{0,0}, {0,0}, {0,0}, {0,0}};
  3420. int sprite_ref[4][2];
  3421. int virtual_ref[2][2];
  3422. int w2, h2, w3, h3;
  3423. int alpha=0, beta=0;
  3424. int w= s->width;
  3425. int h= s->height;
  3426. int min_ab;
  3427. for(i=0; i<s->num_sprite_warping_points; i++){
  3428. int length;
  3429. int x=0, y=0;
  3430. length= get_vlc(&s->gb, &sprite_trajectory);
  3431. if(length){
  3432. x= get_bits(&s->gb, length);
  3433. if ((x >> (length - 1)) == 0) /* if MSB not set it is negative*/
  3434. x = - (x ^ ((1 << length) - 1));
  3435. }
  3436. if(!(s->divx_version==500 && s->divx_build==413)) skip_bits1(&s->gb); /* marker bit */
  3437. length= get_vlc(&s->gb, &sprite_trajectory);
  3438. if(length){
  3439. y=get_bits(&s->gb, length);
  3440. if ((y >> (length - 1)) == 0) /* if MSB not set it is negative*/
  3441. y = - (y ^ ((1 << length) - 1));
  3442. }
  3443. skip_bits1(&s->gb); /* marker bit */
  3444. //printf("%d %d %d %d\n", x, y, i, s->sprite_warping_accuracy);
  3445. d[i][0]= x;
  3446. d[i][1]= y;
  3447. }
  3448. while((1<<alpha)<w) alpha++;
  3449. while((1<<beta )<h) beta++; // there seems to be a typo in the mpeg4 std for the definition of w' and h'
  3450. w2= 1<<alpha;
  3451. h2= 1<<beta;
  3452. // Note, the 4th point isnt used for GMC
  3453. if(s->divx_version==500 && s->divx_build==413){
  3454. sprite_ref[0][0]= a*vop_ref[0][0] + d[0][0];
  3455. sprite_ref[0][1]= a*vop_ref[0][1] + d[0][1];
  3456. sprite_ref[1][0]= a*vop_ref[1][0] + d[0][0] + d[1][0];
  3457. sprite_ref[1][1]= a*vop_ref[1][1] + d[0][1] + d[1][1];
  3458. sprite_ref[2][0]= a*vop_ref[2][0] + d[0][0] + d[2][0];
  3459. sprite_ref[2][1]= a*vop_ref[2][1] + d[0][1] + d[2][1];
  3460. } else {
  3461. sprite_ref[0][0]= (a>>1)*(2*vop_ref[0][0] + d[0][0]);
  3462. sprite_ref[0][1]= (a>>1)*(2*vop_ref[0][1] + d[0][1]);
  3463. sprite_ref[1][0]= (a>>1)*(2*vop_ref[1][0] + d[0][0] + d[1][0]);
  3464. sprite_ref[1][1]= (a>>1)*(2*vop_ref[1][1] + d[0][1] + d[1][1]);
  3465. sprite_ref[2][0]= (a>>1)*(2*vop_ref[2][0] + d[0][0] + d[2][0]);
  3466. sprite_ref[2][1]= (a>>1)*(2*vop_ref[2][1] + d[0][1] + d[2][1]);
  3467. }
  3468. /* sprite_ref[3][0]= (a>>1)*(2*vop_ref[3][0] + d[0][0] + d[1][0] + d[2][0] + d[3][0]);
  3469. sprite_ref[3][1]= (a>>1)*(2*vop_ref[3][1] + d[0][1] + d[1][1] + d[2][1] + d[3][1]); */
  3470. // this is mostly identical to the mpeg4 std (and is totally unreadable because of that ...)
  3471. // perhaps it should be reordered to be more readable ...
  3472. // the idea behind this virtual_ref mess is to be able to use shifts later per pixel instead of divides
  3473. // so the distance between points is converted from w&h based to w2&h2 based which are of the 2^x form
  3474. virtual_ref[0][0]= 16*(vop_ref[0][0] + w2)
  3475. + ROUNDED_DIV(((w - w2)*(r*sprite_ref[0][0] - 16*vop_ref[0][0]) + w2*(r*sprite_ref[1][0] - 16*vop_ref[1][0])),w);
  3476. virtual_ref[0][1]= 16*vop_ref[0][1]
  3477. + ROUNDED_DIV(((w - w2)*(r*sprite_ref[0][1] - 16*vop_ref[0][1]) + w2*(r*sprite_ref[1][1] - 16*vop_ref[1][1])),w);
  3478. virtual_ref[1][0]= 16*vop_ref[0][0]
  3479. + ROUNDED_DIV(((h - h2)*(r*sprite_ref[0][0] - 16*vop_ref[0][0]) + h2*(r*sprite_ref[2][0] - 16*vop_ref[2][0])),h);
  3480. virtual_ref[1][1]= 16*(vop_ref[0][1] + h2)
  3481. + ROUNDED_DIV(((h - h2)*(r*sprite_ref[0][1] - 16*vop_ref[0][1]) + h2*(r*sprite_ref[2][1] - 16*vop_ref[2][1])),h);
  3482. switch(s->num_sprite_warping_points)
  3483. {
  3484. case 0:
  3485. s->sprite_offset[0][0]= 0;
  3486. s->sprite_offset[0][1]= 0;
  3487. s->sprite_offset[1][0]= 0;
  3488. s->sprite_offset[1][1]= 0;
  3489. s->sprite_delta[0][0]= a;
  3490. s->sprite_delta[0][1]= 0;
  3491. s->sprite_delta[1][0]= 0;
  3492. s->sprite_delta[1][1]= a;
  3493. s->sprite_shift[0]= 0;
  3494. s->sprite_shift[1]= 0;
  3495. break;
  3496. case 1: //GMC only
  3497. s->sprite_offset[0][0]= sprite_ref[0][0] - a*vop_ref[0][0];
  3498. s->sprite_offset[0][1]= sprite_ref[0][1] - a*vop_ref[0][1];
  3499. s->sprite_offset[1][0]= ((sprite_ref[0][0]>>1)|(sprite_ref[0][0]&1)) - a*(vop_ref[0][0]/2);
  3500. s->sprite_offset[1][1]= ((sprite_ref[0][1]>>1)|(sprite_ref[0][1]&1)) - a*(vop_ref[0][1]/2);
  3501. s->sprite_delta[0][0]= a;
  3502. s->sprite_delta[0][1]= 0;
  3503. s->sprite_delta[1][0]= 0;
  3504. s->sprite_delta[1][1]= a;
  3505. s->sprite_shift[0]= 0;
  3506. s->sprite_shift[1]= 0;
  3507. break;
  3508. case 2:
  3509. s->sprite_offset[0][0]= (sprite_ref[0][0]<<(alpha+rho))
  3510. + (-r*sprite_ref[0][0] + virtual_ref[0][0])*(-vop_ref[0][0])
  3511. + ( r*sprite_ref[0][1] - virtual_ref[0][1])*(-vop_ref[0][1])
  3512. + (1<<(alpha+rho-1));
  3513. s->sprite_offset[0][1]= (sprite_ref[0][1]<<(alpha+rho))
  3514. + (-r*sprite_ref[0][1] + virtual_ref[0][1])*(-vop_ref[0][0])
  3515. + (-r*sprite_ref[0][0] + virtual_ref[0][0])*(-vop_ref[0][1])
  3516. + (1<<(alpha+rho-1));
  3517. s->sprite_offset[1][0]= ( (-r*sprite_ref[0][0] + virtual_ref[0][0])*(-2*vop_ref[0][0] + 1)
  3518. +( r*sprite_ref[0][1] - virtual_ref[0][1])*(-2*vop_ref[0][1] + 1)
  3519. +2*w2*r*sprite_ref[0][0]
  3520. - 16*w2
  3521. + (1<<(alpha+rho+1)));
  3522. s->sprite_offset[1][1]= ( (-r*sprite_ref[0][1] + virtual_ref[0][1])*(-2*vop_ref[0][0] + 1)
  3523. +(-r*sprite_ref[0][0] + virtual_ref[0][0])*(-2*vop_ref[0][1] + 1)
  3524. +2*w2*r*sprite_ref[0][1]
  3525. - 16*w2
  3526. + (1<<(alpha+rho+1)));
  3527. s->sprite_delta[0][0]= (-r*sprite_ref[0][0] + virtual_ref[0][0]);
  3528. s->sprite_delta[0][1]= (+r*sprite_ref[0][1] - virtual_ref[0][1]);
  3529. s->sprite_delta[1][0]= (-r*sprite_ref[0][1] + virtual_ref[0][1]);
  3530. s->sprite_delta[1][1]= (-r*sprite_ref[0][0] + virtual_ref[0][0]);
  3531. s->sprite_shift[0]= alpha+rho;
  3532. s->sprite_shift[1]= alpha+rho+2;
  3533. break;
  3534. case 3:
  3535. min_ab= FFMIN(alpha, beta);
  3536. w3= w2>>min_ab;
  3537. h3= h2>>min_ab;
  3538. s->sprite_offset[0][0]= (sprite_ref[0][0]<<(alpha+beta+rho-min_ab))
  3539. + (-r*sprite_ref[0][0] + virtual_ref[0][0])*h3*(-vop_ref[0][0])
  3540. + (-r*sprite_ref[0][0] + virtual_ref[1][0])*w3*(-vop_ref[0][1])
  3541. + (1<<(alpha+beta+rho-min_ab-1));
  3542. s->sprite_offset[0][1]= (sprite_ref[0][1]<<(alpha+beta+rho-min_ab))
  3543. + (-r*sprite_ref[0][1] + virtual_ref[0][1])*h3*(-vop_ref[0][0])
  3544. + (-r*sprite_ref[0][1] + virtual_ref[1][1])*w3*(-vop_ref[0][1])
  3545. + (1<<(alpha+beta+rho-min_ab-1));
  3546. s->sprite_offset[1][0]= (-r*sprite_ref[0][0] + virtual_ref[0][0])*h3*(-2*vop_ref[0][0] + 1)
  3547. + (-r*sprite_ref[0][0] + virtual_ref[1][0])*w3*(-2*vop_ref[0][1] + 1)
  3548. + 2*w2*h3*r*sprite_ref[0][0]
  3549. - 16*w2*h3
  3550. + (1<<(alpha+beta+rho-min_ab+1));
  3551. s->sprite_offset[1][1]= (-r*sprite_ref[0][1] + virtual_ref[0][1])*h3*(-2*vop_ref[0][0] + 1)
  3552. + (-r*sprite_ref[0][1] + virtual_ref[1][1])*w3*(-2*vop_ref[0][1] + 1)
  3553. + 2*w2*h3*r*sprite_ref[0][1]
  3554. - 16*w2*h3
  3555. + (1<<(alpha+beta+rho-min_ab+1));
  3556. s->sprite_delta[0][0]= (-r*sprite_ref[0][0] + virtual_ref[0][0])*h3;
  3557. s->sprite_delta[0][1]= (-r*sprite_ref[0][0] + virtual_ref[1][0])*w3;
  3558. s->sprite_delta[1][0]= (-r*sprite_ref[0][1] + virtual_ref[0][1])*h3;
  3559. s->sprite_delta[1][1]= (-r*sprite_ref[0][1] + virtual_ref[1][1])*w3;
  3560. s->sprite_shift[0]= alpha + beta + rho - min_ab;
  3561. s->sprite_shift[1]= alpha + beta + rho - min_ab + 2;
  3562. break;
  3563. }
  3564. /* try to simplify the situation */
  3565. if( s->sprite_delta[0][0] == a<<s->sprite_shift[0]
  3566. && s->sprite_delta[0][1] == 0
  3567. && s->sprite_delta[1][0] == 0
  3568. && s->sprite_delta[1][1] == a<<s->sprite_shift[0])
  3569. {
  3570. s->sprite_offset[0][0]>>=s->sprite_shift[0];
  3571. s->sprite_offset[0][1]>>=s->sprite_shift[0];
  3572. s->sprite_offset[1][0]>>=s->sprite_shift[1];
  3573. s->sprite_offset[1][1]>>=s->sprite_shift[1];
  3574. s->sprite_delta[0][0]= a;
  3575. s->sprite_delta[0][1]= 0;
  3576. s->sprite_delta[1][0]= 0;
  3577. s->sprite_delta[1][1]= a;
  3578. s->sprite_shift[0]= 0;
  3579. s->sprite_shift[1]= 0;
  3580. s->real_sprite_warping_points=1;
  3581. }
  3582. else{
  3583. int shift_y= 16 - s->sprite_shift[0];
  3584. int shift_c= 16 - s->sprite_shift[1];
  3585. //printf("shifts %d %d\n", shift_y, shift_c);
  3586. for(i=0; i<2; i++){
  3587. s->sprite_offset[0][i]<<= shift_y;
  3588. s->sprite_offset[1][i]<<= shift_c;
  3589. s->sprite_delta[0][i]<<= shift_y;
  3590. s->sprite_delta[1][i]<<= shift_y;
  3591. s->sprite_shift[i]= 16;
  3592. }
  3593. s->real_sprite_warping_points= s->num_sprite_warping_points;
  3594. }
  3595. #if 0
  3596. printf("vop:%d:%d %d:%d %d:%d, sprite:%d:%d %d:%d %d:%d, virtual: %d:%d %d:%d\n",
  3597. vop_ref[0][0], vop_ref[0][1],
  3598. vop_ref[1][0], vop_ref[1][1],
  3599. vop_ref[2][0], vop_ref[2][1],
  3600. sprite_ref[0][0], sprite_ref[0][1],
  3601. sprite_ref[1][0], sprite_ref[1][1],
  3602. sprite_ref[2][0], sprite_ref[2][1],
  3603. virtual_ref[0][0], virtual_ref[0][1],
  3604. virtual_ref[1][0], virtual_ref[1][1]
  3605. );
  3606. printf("offset: %d:%d , delta: %d %d %d %d, shift %d\n",
  3607. s->sprite_offset[0][0], s->sprite_offset[0][1],
  3608. s->sprite_delta[0][0], s->sprite_delta[0][1],
  3609. s->sprite_delta[1][0], s->sprite_delta[1][1],
  3610. s->sprite_shift[0]
  3611. );
  3612. #endif
  3613. }
  3614. static int decode_vol_header(MpegEncContext *s, GetBitContext *gb){
  3615. int width, height, vo_ver_id;
  3616. /* vol header */
  3617. skip_bits(gb, 1); /* random access */
  3618. s->vo_type= get_bits(gb, 8);
  3619. if (get_bits1(gb) != 0) { /* is_ol_id */
  3620. vo_ver_id = get_bits(gb, 4); /* vo_ver_id */
  3621. skip_bits(gb, 3); /* vo_priority */
  3622. } else {
  3623. vo_ver_id = 1;
  3624. }
  3625. //printf("vo type:%d\n",s->vo_type);
  3626. s->aspect_ratio_info= get_bits(gb, 4);
  3627. if(s->aspect_ratio_info == FF_ASPECT_EXTENDED){
  3628. s->aspected_width = get_bits(gb, 8); // par_width
  3629. s->aspected_height = get_bits(gb, 8); // par_height
  3630. }else{
  3631. s->aspected_width = pixel_aspect[s->aspect_ratio_info][0];
  3632. s->aspected_height= pixel_aspect[s->aspect_ratio_info][1];
  3633. }
  3634. if ((s->vol_control_parameters=get_bits1(gb))) { /* vol control parameter */
  3635. int chroma_format= get_bits(gb, 2);
  3636. if(chroma_format!=1){
  3637. printf("illegal chroma format\n");
  3638. }
  3639. s->low_delay= get_bits1(gb);
  3640. if(get_bits1(gb)){ /* vbv parameters */
  3641. get_bits(gb, 15); /* first_half_bitrate */
  3642. skip_bits1(gb); /* marker */
  3643. get_bits(gb, 15); /* latter_half_bitrate */
  3644. skip_bits1(gb); /* marker */
  3645. get_bits(gb, 15); /* first_half_vbv_buffer_size */
  3646. skip_bits1(gb); /* marker */
  3647. get_bits(gb, 3); /* latter_half_vbv_buffer_size */
  3648. get_bits(gb, 11); /* first_half_vbv_occupancy */
  3649. skip_bits1(gb); /* marker */
  3650. get_bits(gb, 15); /* latter_half_vbv_occupancy */
  3651. skip_bits1(gb); /* marker */
  3652. }
  3653. }else{
  3654. // set low delay flag only once so the smart? low delay detection wont be overriden
  3655. if(s->picture_number==0)
  3656. s->low_delay=0;
  3657. }
  3658. s->shape = get_bits(gb, 2); /* vol shape */
  3659. if(s->shape != RECT_SHAPE) printf("only rectangular vol supported\n");
  3660. if(s->shape == GRAY_SHAPE && vo_ver_id != 1){
  3661. printf("Gray shape not supported\n");
  3662. skip_bits(gb, 4); //video_object_layer_shape_extension
  3663. }
  3664. skip_bits1(gb); /* marker */
  3665. s->time_increment_resolution = get_bits(gb, 16);
  3666. s->time_increment_bits = av_log2(s->time_increment_resolution - 1) + 1;
  3667. if (s->time_increment_bits < 1)
  3668. s->time_increment_bits = 1;
  3669. skip_bits1(gb); /* marker */
  3670. if (get_bits1(gb) != 0) { /* fixed_vop_rate */
  3671. skip_bits(gb, s->time_increment_bits);
  3672. }
  3673. if (s->shape != BIN_ONLY_SHAPE) {
  3674. if (s->shape == RECT_SHAPE) {
  3675. skip_bits1(gb); /* marker */
  3676. width = get_bits(gb, 13);
  3677. skip_bits1(gb); /* marker */
  3678. height = get_bits(gb, 13);
  3679. skip_bits1(gb); /* marker */
  3680. if(width && height){ /* they should be non zero but who knows ... */
  3681. s->width = width;
  3682. s->height = height;
  3683. // printf("width/height: %d %d\n", width, height);
  3684. }
  3685. }
  3686. s->progressive_sequence= get_bits1(gb)^1;
  3687. if(!get_bits1(gb)) printf("OBMC not supported (very likely buggy encoder)\n"); /* OBMC Disable */
  3688. if (vo_ver_id == 1) {
  3689. s->vol_sprite_usage = get_bits1(gb); /* vol_sprite_usage */
  3690. } else {
  3691. s->vol_sprite_usage = get_bits(gb, 2); /* vol_sprite_usage */
  3692. }
  3693. if(s->vol_sprite_usage==STATIC_SPRITE) printf("Static Sprites not supported\n");
  3694. if(s->vol_sprite_usage==STATIC_SPRITE || s->vol_sprite_usage==GMC_SPRITE){
  3695. if(s->vol_sprite_usage==STATIC_SPRITE){
  3696. s->sprite_width = get_bits(gb, 13);
  3697. skip_bits1(gb); /* marker */
  3698. s->sprite_height= get_bits(gb, 13);
  3699. skip_bits1(gb); /* marker */
  3700. s->sprite_left = get_bits(gb, 13);
  3701. skip_bits1(gb); /* marker */
  3702. s->sprite_top = get_bits(gb, 13);
  3703. skip_bits1(gb); /* marker */
  3704. }
  3705. s->num_sprite_warping_points= get_bits(gb, 6);
  3706. s->sprite_warping_accuracy = get_bits(gb, 2);
  3707. s->sprite_brightness_change= get_bits1(gb);
  3708. if(s->vol_sprite_usage==STATIC_SPRITE)
  3709. s->low_latency_sprite= get_bits1(gb);
  3710. }
  3711. // FIXME sadct disable bit if verid!=1 && shape not rect
  3712. if (get_bits1(gb) == 1) { /* not_8_bit */
  3713. s->quant_precision = get_bits(gb, 4); /* quant_precision */
  3714. if(get_bits(gb, 4)!=8) printf("N-bit not supported\n"); /* bits_per_pixel */
  3715. if(s->quant_precision!=5) printf("quant precission %d\n", s->quant_precision);
  3716. } else {
  3717. s->quant_precision = 5;
  3718. }
  3719. // FIXME a bunch of grayscale shape things
  3720. if((s->mpeg_quant=get_bits1(gb))){ /* vol_quant_type */
  3721. int i, j, v;
  3722. /* load default matrixes */
  3723. for(i=0; i<64; i++){
  3724. int j= s->idct_permutation[i];
  3725. v= ff_mpeg4_default_intra_matrix[i];
  3726. s->intra_matrix[j]= v;
  3727. s->chroma_intra_matrix[j]= v;
  3728. v= ff_mpeg4_default_non_intra_matrix[i];
  3729. s->inter_matrix[j]= v;
  3730. s->chroma_inter_matrix[j]= v;
  3731. }
  3732. /* load custom intra matrix */
  3733. if(get_bits1(gb)){
  3734. int last=0;
  3735. for(i=0; i<64; i++){
  3736. v= get_bits(gb, 8);
  3737. if(v==0) break;
  3738. last= v;
  3739. j= s->idct_permutation[ ff_zigzag_direct[i] ];
  3740. s->intra_matrix[j]= v;
  3741. s->chroma_intra_matrix[j]= v;
  3742. }
  3743. /* replicate last value */
  3744. for(; i<64; i++){
  3745. j= s->idct_permutation[ ff_zigzag_direct[i] ];
  3746. s->intra_matrix[j]= v;
  3747. s->chroma_intra_matrix[j]= v;
  3748. }
  3749. }
  3750. /* load custom non intra matrix */
  3751. if(get_bits1(gb)){
  3752. int last=0;
  3753. for(i=0; i<64; i++){
  3754. v= get_bits(gb, 8);
  3755. if(v==0) break;
  3756. last= v;
  3757. j= s->idct_permutation[ ff_zigzag_direct[i] ];
  3758. s->inter_matrix[j]= v;
  3759. s->chroma_inter_matrix[j]= v;
  3760. }
  3761. /* replicate last value */
  3762. for(; i<64; i++){
  3763. j= s->idct_permutation[ ff_zigzag_direct[i] ];
  3764. s->inter_matrix[j]= last;
  3765. s->chroma_inter_matrix[j]= last;
  3766. }
  3767. }
  3768. // FIXME a bunch of grayscale shape things
  3769. }
  3770. if(vo_ver_id != 1)
  3771. s->quarter_sample= get_bits1(gb);
  3772. else s->quarter_sample=0;
  3773. if(!get_bits1(gb)) printf("Complexity estimation not supported\n");
  3774. s->resync_marker= !get_bits1(gb); /* resync_marker_disabled */
  3775. s->data_partitioning= get_bits1(gb);
  3776. if(s->data_partitioning){
  3777. s->rvlc= get_bits1(gb);
  3778. if(s->rvlc){
  3779. printf("reversible vlc not supported\n");
  3780. }
  3781. }
  3782. if(vo_ver_id != 1) {
  3783. s->new_pred= get_bits1(gb);
  3784. if(s->new_pred){
  3785. printf("new pred not supported\n");
  3786. skip_bits(gb, 2); /* requested upstream message type */
  3787. skip_bits1(gb); /* newpred segment type */
  3788. }
  3789. s->reduced_res_vop= get_bits1(gb);
  3790. if(s->reduced_res_vop) printf("reduced resolution VOP not supported\n");
  3791. }
  3792. else{
  3793. s->new_pred=0;
  3794. s->reduced_res_vop= 0;
  3795. }
  3796. s->scalability= get_bits1(gb);
  3797. if (s->scalability) {
  3798. GetBitContext bak= *gb;
  3799. int ref_layer_id;
  3800. int ref_layer_sampling_dir;
  3801. int h_sampling_factor_n;
  3802. int h_sampling_factor_m;
  3803. int v_sampling_factor_n;
  3804. int v_sampling_factor_m;
  3805. s->hierachy_type= get_bits1(gb);
  3806. ref_layer_id= get_bits(gb, 4);
  3807. ref_layer_sampling_dir= get_bits1(gb);
  3808. h_sampling_factor_n= get_bits(gb, 5);
  3809. h_sampling_factor_m= get_bits(gb, 5);
  3810. v_sampling_factor_n= get_bits(gb, 5);
  3811. v_sampling_factor_m= get_bits(gb, 5);
  3812. s->enhancement_type= get_bits1(gb);
  3813. if( h_sampling_factor_n==0 || h_sampling_factor_m==0
  3814. || v_sampling_factor_n==0 || v_sampling_factor_m==0){
  3815. // fprintf(stderr, "illegal scalability header (VERY broken encoder), trying to workaround\n");
  3816. s->scalability=0;
  3817. *gb= bak;
  3818. }else
  3819. printf("scalability not supported\n");
  3820. // bin shape stuff FIXME
  3821. }
  3822. }
  3823. return 0;
  3824. }
  3825. static int decode_user_data(MpegEncContext *s, GetBitContext *gb){
  3826. char buf[256];
  3827. int i;
  3828. int e;
  3829. int ver, build, ver2, ver3;
  3830. buf[0]= show_bits(gb, 8);
  3831. for(i=1; i<256; i++){
  3832. buf[i]= show_bits(gb, 16)&0xFF;
  3833. if(buf[i]==0) break;
  3834. skip_bits(gb, 8);
  3835. }
  3836. buf[255]=0;
  3837. /* divx detection */
  3838. e=sscanf(buf, "DivX%dBuild%d", &ver, &build);
  3839. if(e!=2)
  3840. e=sscanf(buf, "DivX%db%d", &ver, &build);
  3841. if(e==2){
  3842. s->divx_version= ver;
  3843. s->divx_build= build;
  3844. if(s->picture_number==0){
  3845. printf("This file was encoded with DivX%d Build%d\n", ver, build);
  3846. }
  3847. }
  3848. /* ffmpeg detection */
  3849. e=sscanf(buf, "FFmpeg%d.%d.%db%d", &ver, &ver2, &ver3, &build);
  3850. if(e!=4)
  3851. e=sscanf(buf, "FFmpeg v%d.%d.%d / libavcodec build: %d", &ver, &ver2, &ver3, &build);
  3852. if(e!=4){
  3853. if(strcmp(buf, "ffmpeg")==0){
  3854. s->ffmpeg_version= 0x000406;
  3855. s->lavc_build= 4600;
  3856. }
  3857. }
  3858. if(e==4){
  3859. s->ffmpeg_version= ver*256*256 + ver2*256 + ver3;
  3860. s->lavc_build= build;
  3861. if(s->picture_number==0)
  3862. printf("This file was encoded with libavcodec build %d\n", build);
  3863. }
  3864. /* xvid detection */
  3865. e=sscanf(buf, "XviD%d", &build);
  3866. if(e==1){
  3867. s->xvid_build= build;
  3868. if(s->picture_number==0)
  3869. printf("This file was encoded with XviD build %d\n", build);
  3870. }
  3871. //printf("User Data: %s\n", buf);
  3872. return 0;
  3873. }
  3874. static int decode_vop_header(MpegEncContext *s, GetBitContext *gb){
  3875. int time_incr, time_increment;
  3876. s->pict_type = get_bits(gb, 2) + I_TYPE; /* pict type: I = 0 , P = 1 */
  3877. if(s->pict_type==B_TYPE && s->low_delay && s->vol_control_parameters==0){
  3878. printf("low_delay flag set, but shouldnt, clearing it\n");
  3879. s->low_delay=0;
  3880. }
  3881. s->partitioned_frame= s->data_partitioning && s->pict_type!=B_TYPE;
  3882. if(s->partitioned_frame)
  3883. s->decode_mb= mpeg4_decode_partitioned_mb;
  3884. else
  3885. s->decode_mb= ff_h263_decode_mb;
  3886. if(s->time_increment_resolution==0){
  3887. s->time_increment_resolution=1;
  3888. // fprintf(stderr, "time_increment_resolution is illegal\n");
  3889. }
  3890. time_incr=0;
  3891. while (get_bits1(gb) != 0)
  3892. time_incr++;
  3893. check_marker(gb, "before time_increment");
  3894. time_increment= get_bits(gb, s->time_increment_bits);
  3895. //printf(" type:%d modulo_time_base:%d increment:%d\n", s->pict_type, time_incr, time_increment);
  3896. if(s->pict_type!=B_TYPE){
  3897. s->last_time_base= s->time_base;
  3898. s->time_base+= time_incr;
  3899. s->time= s->time_base*s->time_increment_resolution + time_increment;
  3900. if(s->workaround_bugs&FF_BUG_UMP4){
  3901. if(s->time < s->last_non_b_time){
  3902. // fprintf(stderr, "header is not mpeg4 compatible, broken encoder, trying to workaround\n");
  3903. s->time_base++;
  3904. s->time+= s->time_increment_resolution;
  3905. }
  3906. }
  3907. s->pp_time= s->time - s->last_non_b_time;
  3908. s->last_non_b_time= s->time;
  3909. }else{
  3910. s->time= (s->last_time_base + time_incr)*s->time_increment_resolution + time_increment;
  3911. s->pb_time= s->pp_time - (s->last_non_b_time - s->time);
  3912. if(s->pp_time <=s->pb_time || s->pp_time <= s->pp_time - s->pb_time || s->pp_time<=0){
  3913. // printf("messed up order, seeking?, skiping current b frame\n");
  3914. return FRAME_SKIPED;
  3915. }
  3916. if(s->t_frame==0) s->t_frame= s->time - s->last_time_base;
  3917. if(s->t_frame==0) s->t_frame=1; // 1/0 protection
  3918. //printf("%Ld %Ld %d %d\n", s->last_non_b_time, s->time, s->pp_time, s->t_frame); fflush(stdout);
  3919. s->pp_field_time= ( ROUNDED_DIV(s->last_non_b_time, s->t_frame)
  3920. - ROUNDED_DIV(s->last_non_b_time - s->pp_time, s->t_frame))*2;
  3921. s->pb_field_time= ( ROUNDED_DIV(s->time, s->t_frame)
  3922. - ROUNDED_DIV(s->last_non_b_time - s->pp_time, s->t_frame))*2;
  3923. }
  3924. s->avctx->pts= s->time*1000LL*1000LL / s->time_increment_resolution;
  3925. if(check_marker(gb, "before vop_coded")==0 && s->picture_number==0){
  3926. printf("hmm, seems the headers arnt complete, trying to guess time_increment_bits\n");
  3927. for(s->time_increment_bits++ ;s->time_increment_bits<16; s->time_increment_bits++){
  3928. if(get_bits1(gb)) break;
  3929. }
  3930. printf("my guess is %d bits ;)\n",s->time_increment_bits);
  3931. }
  3932. /* vop coded */
  3933. if (get_bits1(gb) != 1){
  3934. printf("vop not coded\n");
  3935. return FRAME_SKIPED;
  3936. }
  3937. //printf("time %d %d %d || %Ld %Ld %Ld\n", s->time_increment_bits, s->time_increment_resolution, s->time_base,
  3938. //s->time, s->last_non_b_time, s->last_non_b_time - s->pp_time);
  3939. if (s->shape != BIN_ONLY_SHAPE && ( s->pict_type == P_TYPE
  3940. || (s->pict_type == S_TYPE && s->vol_sprite_usage==GMC_SPRITE))) {
  3941. /* rounding type for motion estimation */
  3942. s->no_rounding = get_bits1(gb);
  3943. } else {
  3944. s->no_rounding = 0;
  3945. }
  3946. //FIXME reduced res stuff
  3947. if (s->shape != RECT_SHAPE) {
  3948. if (s->vol_sprite_usage != 1 || s->pict_type != I_TYPE) {
  3949. int width, height, hor_spat_ref, ver_spat_ref;
  3950. width = get_bits(gb, 13);
  3951. skip_bits1(gb); /* marker */
  3952. height = get_bits(gb, 13);
  3953. skip_bits1(gb); /* marker */
  3954. hor_spat_ref = get_bits(gb, 13); /* hor_spat_ref */
  3955. skip_bits1(gb); /* marker */
  3956. ver_spat_ref = get_bits(gb, 13); /* ver_spat_ref */
  3957. }
  3958. skip_bits1(gb); /* change_CR_disable */
  3959. if (get_bits1(gb) != 0) {
  3960. skip_bits(gb, 8); /* constant_alpha_value */
  3961. }
  3962. }
  3963. //FIXME complexity estimation stuff
  3964. if (s->shape != BIN_ONLY_SHAPE) {
  3965. int t;
  3966. t=get_bits(gb, 3); /* intra dc VLC threshold */
  3967. //printf("threshold %d\n", t);
  3968. if(!s->progressive_sequence){
  3969. s->top_field_first= get_bits1(gb);
  3970. s->alternate_scan= get_bits1(gb);
  3971. }else
  3972. s->alternate_scan= 0;
  3973. }
  3974. if(s->alternate_scan){
  3975. ff_init_scantable(s, &s->inter_scantable , ff_alternate_vertical_scan);
  3976. ff_init_scantable(s, &s->intra_scantable , ff_alternate_vertical_scan);
  3977. ff_init_scantable(s, &s->intra_h_scantable, ff_alternate_vertical_scan);
  3978. ff_init_scantable(s, &s->intra_v_scantable, ff_alternate_vertical_scan);
  3979. } else{
  3980. ff_init_scantable(s, &s->inter_scantable , ff_zigzag_direct);
  3981. ff_init_scantable(s, &s->intra_scantable , ff_zigzag_direct);
  3982. ff_init_scantable(s, &s->intra_h_scantable, ff_alternate_horizontal_scan);
  3983. ff_init_scantable(s, &s->intra_v_scantable, ff_alternate_vertical_scan);
  3984. }
  3985. if(s->pict_type == S_TYPE && (s->vol_sprite_usage==STATIC_SPRITE || s->vol_sprite_usage==GMC_SPRITE)){
  3986. mpeg4_decode_sprite_trajectory(s);
  3987. if(s->sprite_brightness_change) printf("sprite_brightness_change not supported\n");
  3988. if(s->vol_sprite_usage==STATIC_SPRITE) printf("static sprite not supported\n");
  3989. }
  3990. if (s->shape != BIN_ONLY_SHAPE) {
  3991. s->qscale = get_bits(gb, s->quant_precision);
  3992. if(s->qscale==0){
  3993. printf("Error, header damaged or not MPEG4 header (qscale=0)\n");
  3994. return -1; // makes no sense to continue, as there is nothing left from the image then
  3995. }
  3996. if (s->pict_type != I_TYPE) {
  3997. s->f_code = get_bits(gb, 3); /* fcode_for */
  3998. if(s->f_code==0){
  3999. printf("Error, header damaged or not MPEG4 header (f_code=0)\n");
  4000. return -1; // makes no sense to continue, as the MV decoding will break very quickly
  4001. }
  4002. }else
  4003. s->f_code=1;
  4004. if (s->pict_type == B_TYPE) {
  4005. s->b_code = get_bits(gb, 3);
  4006. }else
  4007. s->b_code=1;
  4008. #if 0
  4009. printf("qp:%d fc:%d bc:%d type:%s size:%d pro:%d alt:%d top:%d qpel:%d part:%d resync:%d w:%d a:%d\n",
  4010. s->qscale, s->f_code, s->b_code,
  4011. s->pict_type == I_TYPE ? "I" : (s->pict_type == P_TYPE ? "P" : (s->pict_type == B_TYPE ? "B" : "S")),
  4012. gb->size,s->progressive_sequence, s->alternate_scan, s->top_field_first,
  4013. s->quarter_sample, s->data_partitioning, s->resync_marker, s->num_sprite_warping_points,
  4014. s->sprite_warping_accuracy);
  4015. #endif
  4016. if(!s->scalability){
  4017. if (s->shape!=RECT_SHAPE && s->pict_type!=I_TYPE) {
  4018. skip_bits1(gb); // vop shape coding type
  4019. }
  4020. }else{
  4021. if(s->enhancement_type){
  4022. int load_backward_shape= get_bits1(gb);
  4023. if(load_backward_shape){
  4024. printf("load backward shape isnt supported\n");
  4025. }
  4026. }
  4027. skip_bits(gb, 2); //ref_select_code
  4028. }
  4029. }
  4030. /* detect buggy encoders which dont set the low_delay flag (divx4/xvid/opendivx)*/
  4031. // note we cannot detect divx5 without b-frames easyly (allthough its buggy too)
  4032. if(s->vo_type==0 && s->vol_control_parameters==0 && s->divx_version==0 && s->picture_number==0){
  4033. printf("looks like this file was encoded with (divx4/(old)xvid/opendivx) -> forcing low_delay flag\n");
  4034. s->low_delay=1;
  4035. }
  4036. s->picture_number++; // better than pic number==0 allways ;)
  4037. s->y_dc_scale_table= ff_mpeg4_y_dc_scale_table; //FIXME add short header support
  4038. s->c_dc_scale_table= ff_mpeg4_c_dc_scale_table;
  4039. if(s->divx_version==0 || s->divx_version < 500){
  4040. s->h_edge_pos= s->width;
  4041. s->v_edge_pos= s->height;
  4042. }
  4043. return 0;
  4044. }
  4045. /**
  4046. * decode mpeg4 headers
  4047. * @return <0 if no VOP found (or a damaged one)
  4048. * FRAME_SKIPPED if a not coded VOP is found
  4049. * 0 if a VOP is found
  4050. */
  4051. int ff_mpeg4_decode_picture_header(MpegEncContext * s, GetBitContext *gb)
  4052. {
  4053. int startcode, v;
  4054. /* search next start code */
  4055. align_get_bits(gb);
  4056. startcode = 0xff;
  4057. for(;;) {
  4058. v = get_bits(gb, 8);
  4059. startcode = ((startcode << 8) | v) & 0xffffffff;
  4060. if(get_bits_count(gb) >= gb->size*8){
  4061. if(gb->size==1 && s->divx_version){
  4062. printf("frame skip %d\n", gb->size);
  4063. return FRAME_SKIPED; //divx bug
  4064. }else
  4065. return -1; //end of stream
  4066. }
  4067. if((startcode&0xFFFFFF00) != 0x100)
  4068. continue; //no startcode
  4069. switch(startcode){
  4070. case 0x120:
  4071. decode_vol_header(s, gb);
  4072. break;
  4073. case 0x1b2:
  4074. decode_user_data(s, gb);
  4075. break;
  4076. case 0x1b6:
  4077. return decode_vop_header(s, gb);
  4078. default:
  4079. // printf("startcode %X found\n", startcode);
  4080. break;
  4081. }
  4082. align_get_bits(gb);
  4083. startcode = 0xff;
  4084. }
  4085. }
  4086. /* don't understand why they choose a different header ! */
  4087. int intel_h263_decode_picture_header(MpegEncContext *s)
  4088. {
  4089. int format;
  4090. /* picture header */
  4091. if (get_bits(&s->gb, 22) != 0x20) {
  4092. fprintf(stderr, "Bad picture start code\n");
  4093. return -1;
  4094. }
  4095. s->picture_number = get_bits(&s->gb, 8); /* picture timestamp */
  4096. if (get_bits1(&s->gb) != 1) {
  4097. fprintf(stderr, "Bad marker\n");
  4098. return -1; /* marker */
  4099. }
  4100. if (get_bits1(&s->gb) != 0) {
  4101. fprintf(stderr, "Bad H263 id\n");
  4102. return -1; /* h263 id */
  4103. }
  4104. skip_bits1(&s->gb); /* split screen off */
  4105. skip_bits1(&s->gb); /* camera off */
  4106. skip_bits1(&s->gb); /* freeze picture release off */
  4107. format = get_bits(&s->gb, 3);
  4108. if (format != 7) {
  4109. fprintf(stderr, "Intel H263 free format not supported\n");
  4110. return -1;
  4111. }
  4112. s->h263_plus = 0;
  4113. s->pict_type = I_TYPE + get_bits1(&s->gb);
  4114. s->unrestricted_mv = get_bits1(&s->gb);
  4115. s->h263_long_vectors = s->unrestricted_mv;
  4116. if (get_bits1(&s->gb) != 0) {
  4117. fprintf(stderr, "SAC not supported\n");
  4118. return -1; /* SAC: off */
  4119. }
  4120. if (get_bits1(&s->gb) != 0) {
  4121. fprintf(stderr, "Advanced Prediction Mode not supported\n");
  4122. return -1; /* advanced prediction mode: off */
  4123. }
  4124. if (get_bits1(&s->gb) != 0) {
  4125. fprintf(stderr, "PB frame mode no supported\n");
  4126. return -1; /* PB frame mode */
  4127. }
  4128. /* skip unknown header garbage */
  4129. skip_bits(&s->gb, 41);
  4130. s->qscale = get_bits(&s->gb, 5);
  4131. skip_bits1(&s->gb); /* Continuous Presence Multipoint mode: off */
  4132. /* PEI */
  4133. while (get_bits1(&s->gb) != 0) {
  4134. skip_bits(&s->gb, 8);
  4135. }
  4136. s->f_code = 1;
  4137. s->y_dc_scale_table=
  4138. s->c_dc_scale_table= ff_mpeg1_dc_scale_table;
  4139. return 0;
  4140. }