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.

1547 lines
44KB

  1. /*
  2. * H263/MPEG4 backend for ffmpeg encoder and decoder
  3. * Copyright (c) 2000,2001 Gerard Lantau.
  4. * H263+ support.
  5. * Copyright (c) 2001 Juan J. Sierralta P.
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; either version 2 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * This program 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
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  20. */
  21. #include "common.h"
  22. #include "dsputil.h"
  23. #include "avcodec.h"
  24. #include "mpegvideo.h"
  25. #include "h263data.h"
  26. #include "mpeg4data.h"
  27. static void h263_encode_block(MpegEncContext * s, DCTELEM * block,
  28. int n);
  29. static void h263_encode_motion(MpegEncContext * s, int val);
  30. static void h263p_encode_umotion(MpegEncContext * s, int val);
  31. static void mpeg4_encode_block(MpegEncContext * s, DCTELEM * block,
  32. int n);
  33. static int h263_decode_motion(MpegEncContext * s, int pred);
  34. static int h263p_decode_umotion(MpegEncContext * s, int pred);
  35. static int h263_decode_block(MpegEncContext * s, DCTELEM * block,
  36. int n, int coded);
  37. static int mpeg4_decode_block(MpegEncContext * s, DCTELEM * block,
  38. int n, int coded);
  39. int h263_get_picture_format(int width, int height)
  40. {
  41. int format;
  42. if (width == 128 && height == 96)
  43. format = 1;
  44. else if (width == 176 && height == 144)
  45. format = 2;
  46. else if (width == 352 && height == 288)
  47. format = 3;
  48. else if (width == 704 && height == 576)
  49. format = 4;
  50. else if (width == 1408 && height == 1152)
  51. format = 5;
  52. else
  53. format = 7;
  54. return format;
  55. }
  56. void h263_encode_picture_header(MpegEncContext * s, int picture_number)
  57. {
  58. int format;
  59. align_put_bits(&s->pb);
  60. put_bits(&s->pb, 22, 0x20);
  61. put_bits(&s->pb, 8, ((s->picture_number * 30 * FRAME_RATE_BASE) /
  62. s->frame_rate) & 0xff);
  63. put_bits(&s->pb, 1, 1); /* marker */
  64. put_bits(&s->pb, 1, 0); /* h263 id */
  65. put_bits(&s->pb, 1, 0); /* split screen off */
  66. put_bits(&s->pb, 1, 0); /* camera off */
  67. put_bits(&s->pb, 1, 0); /* freeze picture release off */
  68. format = h263_get_picture_format(s->width, s->height);
  69. if (!s->h263_plus) {
  70. /* H.263v1 */
  71. put_bits(&s->pb, 3, format);
  72. put_bits(&s->pb, 1, (s->pict_type == P_TYPE));
  73. /* By now UMV IS DISABLED ON H.263v1, since the restrictions
  74. of H.263v1 UMV implies to check the predicted MV after
  75. calculation of the current MB to see if we're on the limits */
  76. put_bits(&s->pb, 1, 0); /* unrestricted motion vector: off */
  77. put_bits(&s->pb, 1, 0); /* SAC: off */
  78. put_bits(&s->pb, 1, 0); /* advanced prediction mode: off */
  79. put_bits(&s->pb, 1, 0); /* not PB frame */
  80. put_bits(&s->pb, 5, s->qscale);
  81. put_bits(&s->pb, 1, 0); /* Continuous Presence Multipoint mode: off */
  82. } else {
  83. /* H.263v2 */
  84. /* H.263 Plus PTYPE */
  85. put_bits(&s->pb, 3, 7);
  86. put_bits(&s->pb,3,1); /* Update Full Extended PTYPE */
  87. if (format == 7)
  88. put_bits(&s->pb,3,6); /* Custom Source Format */
  89. else
  90. put_bits(&s->pb, 3, format);
  91. put_bits(&s->pb,1,0); /* Custom PCF: off */
  92. s->umvplus = (s->pict_type == P_TYPE) && s->unrestricted_mv;
  93. put_bits(&s->pb, 1, s->umvplus); /* Unrestricted Motion Vector */
  94. put_bits(&s->pb,1,0); /* SAC: off */
  95. put_bits(&s->pb,1,0); /* Advanced Prediction Mode: off */
  96. put_bits(&s->pb,1,0); /* Advanced Intra Coding: off */
  97. put_bits(&s->pb,1,0); /* Deblocking Filter: off */
  98. put_bits(&s->pb,1,0); /* Slice Structured: off */
  99. put_bits(&s->pb,1,0); /* Reference Picture Selection: off */
  100. put_bits(&s->pb,1,0); /* Independent Segment Decoding: off */
  101. put_bits(&s->pb,1,0); /* Alternative Inter VLC: off */
  102. put_bits(&s->pb,1,0); /* Modified Quantization: off */
  103. put_bits(&s->pb,1,1); /* "1" to prevent start code emulation */
  104. put_bits(&s->pb,3,0); /* Reserved */
  105. put_bits(&s->pb, 3, s->pict_type == P_TYPE);
  106. put_bits(&s->pb,1,0); /* Reference Picture Resampling: off */
  107. put_bits(&s->pb,1,0); /* Reduced-Resolution Update: off */
  108. put_bits(&s->pb,1,0); /* Rounding Type */
  109. put_bits(&s->pb,2,0); /* Reserved */
  110. put_bits(&s->pb,1,1); /* "1" to prevent start code emulation */
  111. /* This should be here if PLUSPTYPE */
  112. put_bits(&s->pb, 1, 0); /* Continuous Presence Multipoint mode: off */
  113. if (format == 7) {
  114. /* Custom Picture Format (CPFMT) */
  115. put_bits(&s->pb,4,2); /* Aspect ratio: CIF 12:11 (4:3) picture */
  116. put_bits(&s->pb,9,(s->width >> 2) - 1);
  117. put_bits(&s->pb,1,1); /* "1" to prevent start code emulation */
  118. put_bits(&s->pb,9,(s->height >> 2));
  119. }
  120. /* Unlimited Unrestricted Motion Vectors Indicator (UUI) */
  121. if (s->umvplus)
  122. put_bits(&s->pb,1,1); /* Limited according tables of Annex D */
  123. put_bits(&s->pb, 5, s->qscale);
  124. }
  125. put_bits(&s->pb, 1, 0); /* no PEI */
  126. }
  127. int h263_encode_gob_header(MpegEncContext * s, int mb_line)
  128. {
  129. int pdif=0;
  130. /* Check to see if we need to put a new GBSC */
  131. /* for RTP packetization */
  132. if (s->rtp_mode) {
  133. pdif = s->pb.buf_ptr - s->ptr_lastgob;
  134. if (pdif >= s->rtp_payload_size) {
  135. /* Bad luck, packet must be cut before */
  136. align_put_bits(&s->pb);
  137. s->ptr_lastgob = s->pb.buf_ptr;
  138. put_bits(&s->pb, 17, 1); /* GBSC */
  139. s->gob_number = mb_line;
  140. put_bits(&s->pb, 5, s->gob_number); /* GN */
  141. put_bits(&s->pb, 2, 1); /* GFID */
  142. put_bits(&s->pb, 5, s->qscale); /* GQUANT */
  143. return pdif;
  144. } else if (pdif + s->mb_line_avgsize >= s->rtp_payload_size) {
  145. /* Cut the packet before we can't */
  146. align_put_bits(&s->pb);
  147. s->ptr_lastgob = s->pb.buf_ptr;
  148. put_bits(&s->pb, 17, 1); /* GBSC */
  149. s->gob_number = mb_line;
  150. put_bits(&s->pb, 5, s->gob_number); /* GN */
  151. put_bits(&s->pb, 2, 1); /* GFID */
  152. put_bits(&s->pb, 5, s->qscale); /* GQUANT */
  153. return pdif;
  154. }
  155. }
  156. return 0;
  157. }
  158. void h263_encode_mb(MpegEncContext * s,
  159. DCTELEM block[6][64],
  160. int motion_x, int motion_y)
  161. {
  162. int cbpc, cbpy, i, cbp, pred_x, pred_y;
  163. // printf("**mb x=%d y=%d\n", s->mb_x, s->mb_y);
  164. if (!s->mb_intra) {
  165. /* compute cbp */
  166. cbp = 0;
  167. for (i = 0; i < 6; i++) {
  168. if (s->block_last_index[i] >= 0)
  169. cbp |= 1 << (5 - i);
  170. }
  171. if ((cbp | motion_x | motion_y) == 0) {
  172. /* skip macroblock */
  173. put_bits(&s->pb, 1, 1);
  174. return;
  175. }
  176. put_bits(&s->pb, 1, 0); /* mb coded */
  177. cbpc = cbp & 3;
  178. put_bits(&s->pb,
  179. inter_MCBPC_bits[cbpc],
  180. inter_MCBPC_code[cbpc]);
  181. cbpy = cbp >> 2;
  182. cbpy ^= 0xf;
  183. put_bits(&s->pb, cbpy_tab[cbpy][1], cbpy_tab[cbpy][0]);
  184. /* motion vectors: 16x16 mode only now */
  185. h263_pred_motion(s, 0, &pred_x, &pred_y);
  186. if (!s->umvplus) {
  187. h263_encode_motion(s, motion_x - pred_x);
  188. h263_encode_motion(s, motion_y - pred_y);
  189. }
  190. else {
  191. h263p_encode_umotion(s, motion_x - pred_x);
  192. h263p_encode_umotion(s, motion_y - pred_y);
  193. if (((motion_x - pred_x) == 1) && ((motion_y - pred_y) == 1))
  194. /* To prevent Start Code emulation */
  195. put_bits(&s->pb,1,1);
  196. }
  197. } else {
  198. /* compute cbp */
  199. cbp = 0;
  200. for (i = 0; i < 6; i++) {
  201. if (s->block_last_index[i] >= 1)
  202. cbp |= 1 << (5 - i);
  203. }
  204. cbpc = cbp & 3;
  205. if (s->pict_type == I_TYPE) {
  206. put_bits(&s->pb,
  207. intra_MCBPC_bits[cbpc],
  208. intra_MCBPC_code[cbpc]);
  209. } else {
  210. put_bits(&s->pb, 1, 0); /* mb coded */
  211. put_bits(&s->pb,
  212. inter_MCBPC_bits[cbpc + 4],
  213. inter_MCBPC_code[cbpc + 4]);
  214. }
  215. if (s->h263_pred) {
  216. /* XXX: currently, we do not try to use ac prediction */
  217. put_bits(&s->pb, 1, 0); /* no ac prediction */
  218. }
  219. cbpy = cbp >> 2;
  220. put_bits(&s->pb, cbpy_tab[cbpy][1], cbpy_tab[cbpy][0]);
  221. }
  222. /* encode each block */
  223. if (s->h263_pred) {
  224. for (i = 0; i < 6; i++) {
  225. mpeg4_encode_block(s, block[i], i);
  226. }
  227. } else {
  228. for (i = 0; i < 6; i++) {
  229. h263_encode_block(s, block[i], i);
  230. }
  231. }
  232. }
  233. static inline int mid_pred(int a, int b, int c)
  234. {
  235. int vmin, vmax;
  236. vmin = a;
  237. if (b < vmin)
  238. vmin = b;
  239. if (c < vmin)
  240. vmin = c;
  241. vmax = a;
  242. if (b > vmax)
  243. vmax = b;
  244. if (c > vmax)
  245. vmax = c;
  246. return a + b + c - vmin - vmax;
  247. }
  248. INT16 *h263_pred_motion(MpegEncContext * s, int block,
  249. int *px, int *py)
  250. {
  251. int x, y, wrap;
  252. INT16 *A, *B, *C, *mot_val;
  253. x = 2 * s->mb_x + 1 + (block & 1);
  254. y = 2 * s->mb_y + 1 + ((block >> 1) & 1);
  255. wrap = 2 * s->mb_width + 2;
  256. mot_val = s->motion_val[(x) + (y) * wrap];
  257. /* special case for first line */
  258. if (y == 1 || s->first_slice_line || s->first_gob_line) {
  259. A = s->motion_val[(x-1) + (y) * wrap];
  260. *px = A[0];
  261. *py = A[1];
  262. } else {
  263. switch(block) {
  264. default:
  265. case 0:
  266. A = s->motion_val[(x-1) + (y) * wrap];
  267. B = s->motion_val[(x) + (y-1) * wrap];
  268. C = s->motion_val[(x+2) + (y-1) * wrap];
  269. break;
  270. case 1:
  271. case 2:
  272. A = s->motion_val[(x-1) + (y) * wrap];
  273. B = s->motion_val[(x) + (y-1) * wrap];
  274. C = s->motion_val[(x+1) + (y-1) * wrap];
  275. break;
  276. case 3:
  277. A = s->motion_val[(x-1) + (y) * wrap];
  278. B = s->motion_val[(x-1) + (y-1) * wrap];
  279. C = s->motion_val[(x) + (y-1) * wrap];
  280. break;
  281. }
  282. *px = mid_pred(A[0], B[0], C[0]);
  283. *py = mid_pred(A[1], B[1], C[1]);
  284. }
  285. return mot_val;
  286. }
  287. static void h263_encode_motion(MpegEncContext * s, int val)
  288. {
  289. int range, l, m, bit_size, sign, code, bits;
  290. if (val == 0) {
  291. /* zero vector */
  292. code = 0;
  293. put_bits(&s->pb, mvtab[code][1], mvtab[code][0]);
  294. } else {
  295. bit_size = s->f_code - 1;
  296. range = 1 << bit_size;
  297. /* modulo encoding */
  298. l = range * 32;
  299. m = 2 * l;
  300. if (val < -l) {
  301. val += m;
  302. } else if (val >= l) {
  303. val -= m;
  304. }
  305. if (val >= 0) {
  306. val--;
  307. code = (val >> bit_size) + 1;
  308. bits = val & (range - 1);
  309. sign = 0;
  310. } else {
  311. val = -val;
  312. val--;
  313. code = (val >> bit_size) + 1;
  314. bits = val & (range - 1);
  315. sign = 1;
  316. }
  317. put_bits(&s->pb, mvtab[code][1] + 1, (mvtab[code][0] << 1) | sign);
  318. if (bit_size > 0) {
  319. put_bits(&s->pb, bit_size, bits);
  320. }
  321. }
  322. }
  323. /* Encode MV differences on H.263+ with Unrestricted MV mode */
  324. static void h263p_encode_umotion(MpegEncContext * s, int val)
  325. {
  326. short sval = 0;
  327. short i = 0;
  328. short n_bits = 0;
  329. short temp_val;
  330. int code = 0;
  331. int tcode;
  332. if ( val == 0)
  333. put_bits(&s->pb, 1, 1);
  334. else if (val == 1)
  335. put_bits(&s->pb, 3, 0);
  336. else if (val == -1)
  337. put_bits(&s->pb, 3, 2);
  338. else {
  339. sval = ((val < 0) ? (short)(-val):(short)val);
  340. temp_val = sval;
  341. while (temp_val != 0) {
  342. temp_val = temp_val >> 1;
  343. n_bits++;
  344. }
  345. i = n_bits - 1;
  346. while (i > 0) {
  347. tcode = (sval & (1 << (i-1))) >> (i-1);
  348. tcode = (tcode << 1) | 1;
  349. code = (code << 2) | tcode;
  350. i--;
  351. }
  352. code = ((code << 1) | (val < 0)) << 1;
  353. put_bits(&s->pb, (2*n_bits)+1, code);
  354. //printf("\nVal = %d\tCode = %d", sval, code);
  355. }
  356. }
  357. void h263_encode_init_vlc(MpegEncContext *s)
  358. {
  359. static int done = 0;
  360. if (!done) {
  361. done = 1;
  362. init_rl(&rl_inter);
  363. init_rl(&rl_intra);
  364. }
  365. }
  366. static void h263_encode_block(MpegEncContext * s, DCTELEM * block, int n)
  367. {
  368. int level, run, last, i, j, last_index, last_non_zero, sign, slevel;
  369. int code;
  370. RLTable *rl = &rl_inter;
  371. if (s->mb_intra) {
  372. /* DC coef */
  373. level = block[0];
  374. /* 255 cannot be represented, so we clamp */
  375. if (level > 254) {
  376. level = 254;
  377. block[0] = 254;
  378. }
  379. if (level == 128)
  380. put_bits(&s->pb, 8, 0xff);
  381. else
  382. put_bits(&s->pb, 8, level & 0xff);
  383. i = 1;
  384. } else {
  385. i = 0;
  386. }
  387. /* AC coefs */
  388. last_index = s->block_last_index[n];
  389. last_non_zero = i - 1;
  390. for (; i <= last_index; i++) {
  391. j = zigzag_direct[i];
  392. level = block[j];
  393. if (level) {
  394. run = i - last_non_zero - 1;
  395. last = (i == last_index);
  396. sign = 0;
  397. slevel = level;
  398. if (level < 0) {
  399. sign = 1;
  400. level = -level;
  401. }
  402. code = get_rl_index(rl, last, run, level);
  403. put_bits(&s->pb, rl->table_vlc[code][1], rl->table_vlc[code][0]);
  404. if (code == rl->n) {
  405. put_bits(&s->pb, 1, last);
  406. put_bits(&s->pb, 6, run);
  407. put_bits(&s->pb, 8, slevel & 0xff);
  408. } else {
  409. put_bits(&s->pb, 1, sign);
  410. }
  411. last_non_zero = i;
  412. }
  413. }
  414. }
  415. /***************************************************/
  416. /* write mpeg4 VOP header */
  417. void mpeg4_encode_picture_header(MpegEncContext * s, int picture_number)
  418. {
  419. align_put_bits(&s->pb);
  420. put_bits(&s->pb, 32, 0x1B6); /* vop header */
  421. put_bits(&s->pb, 2, s->pict_type - 1); /* pict type: I = 0 , P = 1 */
  422. /* XXX: time base + 1 not always correct */
  423. put_bits(&s->pb, 1, 1);
  424. put_bits(&s->pb, 1, 0);
  425. put_bits(&s->pb, 1, 1); /* marker */
  426. put_bits(&s->pb, 4, 1); /* XXX: correct time increment */
  427. put_bits(&s->pb, 1, 1); /* marker */
  428. put_bits(&s->pb, 1, 1); /* vop coded */
  429. if (s->pict_type == P_TYPE) {
  430. s->no_rounding = 0;
  431. put_bits(&s->pb, 1, s->no_rounding); /* rounding type */
  432. }
  433. put_bits(&s->pb, 3, 0); /* intra dc VLC threshold */
  434. put_bits(&s->pb, 5, s->qscale);
  435. if (s->pict_type != I_TYPE)
  436. put_bits(&s->pb, 3, s->f_code); /* fcode_for */
  437. // printf("****frame %d\n", picture_number);
  438. }
  439. void h263_dc_scale(MpegEncContext * s)
  440. {
  441. int quant;
  442. quant = s->qscale;
  443. /* luminance */
  444. if (quant < 5)
  445. s->y_dc_scale = 8;
  446. else if (quant > 4 && quant < 9)
  447. s->y_dc_scale = (2 * quant);
  448. else if (quant > 8 && quant < 25)
  449. s->y_dc_scale = (quant + 8);
  450. else
  451. s->y_dc_scale = (2 * quant - 16);
  452. /* chrominance */
  453. if (quant < 5)
  454. s->c_dc_scale = 8;
  455. else if (quant > 4 && quant < 25)
  456. s->c_dc_scale = ((quant + 13) / 2);
  457. else
  458. s->c_dc_scale = (quant - 6);
  459. }
  460. static int mpeg4_pred_dc(MpegEncContext * s, int n, UINT16 **dc_val_ptr, int *dir_ptr)
  461. {
  462. int a, b, c, x, y, wrap, pred, scale;
  463. UINT16 *dc_val;
  464. /* find prediction */
  465. if (n < 4) {
  466. x = 2 * s->mb_x + 1 + (n & 1);
  467. y = 2 * s->mb_y + 1 + ((n & 2) >> 1);
  468. wrap = s->mb_width * 2 + 2;
  469. dc_val = s->dc_val[0];
  470. scale = s->y_dc_scale;
  471. } else {
  472. x = s->mb_x + 1;
  473. y = s->mb_y + 1;
  474. wrap = s->mb_width + 2;
  475. dc_val = s->dc_val[n - 4 + 1];
  476. scale = s->c_dc_scale;
  477. }
  478. /* B C
  479. * A X
  480. */
  481. a = dc_val[(x - 1) + (y) * wrap];
  482. b = dc_val[(x - 1) + (y - 1) * wrap];
  483. c = dc_val[(x) + (y - 1) * wrap];
  484. if (abs(a - b) < abs(b - c)) {
  485. pred = c;
  486. *dir_ptr = 1; /* top */
  487. } else {
  488. pred = a;
  489. *dir_ptr = 0; /* left */
  490. }
  491. /* we assume pred is positive */
  492. pred = (pred + (scale >> 1)) / scale;
  493. /* prepare address for prediction update */
  494. *dc_val_ptr = &dc_val[(x) + (y) * wrap];
  495. return pred;
  496. }
  497. void mpeg4_pred_ac(MpegEncContext * s, INT16 *block, int n,
  498. int dir)
  499. {
  500. int x, y, wrap, i;
  501. INT16 *ac_val, *ac_val1;
  502. /* find prediction */
  503. if (n < 4) {
  504. x = 2 * s->mb_x + 1 + (n & 1);
  505. y = 2 * s->mb_y + 1 + ((n & 2) >> 1);
  506. wrap = s->mb_width * 2 + 2;
  507. ac_val = s->ac_val[0][0];
  508. } else {
  509. x = s->mb_x + 1;
  510. y = s->mb_y + 1;
  511. wrap = s->mb_width + 2;
  512. ac_val = s->ac_val[n - 4 + 1][0];
  513. }
  514. ac_val += ((y) * wrap + (x)) * 16;
  515. ac_val1 = ac_val;
  516. if (s->ac_pred) {
  517. if (dir == 0) {
  518. /* left prediction */
  519. ac_val -= 16;
  520. for(i=1;i<8;i++) {
  521. block[i*8] += ac_val[i];
  522. }
  523. } else {
  524. /* top prediction */
  525. ac_val -= 16 * wrap;
  526. for(i=1;i<8;i++) {
  527. block[i] += ac_val[i + 8];
  528. }
  529. }
  530. }
  531. /* left copy */
  532. for(i=1;i<8;i++)
  533. ac_val1[i] = block[i * 8];
  534. /* top copy */
  535. for(i=1;i<8;i++)
  536. ac_val1[8 + i] = block[i];
  537. }
  538. static inline void mpeg4_encode_dc(MpegEncContext * s, int level, int n, int *dir_ptr)
  539. {
  540. int size, v, pred;
  541. UINT16 *dc_val;
  542. pred = mpeg4_pred_dc(s, n, &dc_val, dir_ptr);
  543. if (n < 4) {
  544. *dc_val = level * s->y_dc_scale;
  545. } else {
  546. *dc_val = level * s->c_dc_scale;
  547. }
  548. /* do the prediction */
  549. level -= pred;
  550. /* find number of bits */
  551. size = 0;
  552. v = abs(level);
  553. while (v) {
  554. v >>= 1;
  555. size++;
  556. }
  557. if (n < 4) {
  558. /* luminance */
  559. put_bits(&s->pb, DCtab_lum[size][1], DCtab_lum[size][0]);
  560. } else {
  561. /* chrominance */
  562. put_bits(&s->pb, DCtab_chrom[size][1], DCtab_chrom[size][0]);
  563. }
  564. /* encode remaining bits */
  565. if (size > 0) {
  566. if (level < 0)
  567. level = (-level) ^ ((1 << size) - 1);
  568. put_bits(&s->pb, size, level);
  569. if (size > 8)
  570. put_bits(&s->pb, 1, 1);
  571. }
  572. }
  573. static void mpeg4_encode_block(MpegEncContext * s, DCTELEM * block, int n)
  574. {
  575. int level, run, last, i, j, last_index, last_non_zero, sign, slevel;
  576. int code, dc_pred_dir;
  577. const RLTable *rl;
  578. if (s->mb_intra) {
  579. /* mpeg4 based DC predictor */
  580. mpeg4_encode_dc(s, block[0], n, &dc_pred_dir);
  581. i = 1;
  582. rl = &rl_intra;
  583. } else {
  584. i = 0;
  585. rl = &rl_inter;
  586. }
  587. /* AC coefs */
  588. last_index = s->block_last_index[n];
  589. last_non_zero = i - 1;
  590. for (; i <= last_index; i++) {
  591. j = zigzag_direct[i];
  592. level = block[j];
  593. if (level) {
  594. run = i - last_non_zero - 1;
  595. last = (i == last_index);
  596. sign = 0;
  597. slevel = level;
  598. if (level < 0) {
  599. sign = 1;
  600. level = -level;
  601. }
  602. code = get_rl_index(rl, last, run, level);
  603. put_bits(&s->pb, rl->table_vlc[code][1], rl->table_vlc[code][0]);
  604. if (code == rl->n) {
  605. int level1, run1;
  606. level1 = level - rl->max_level[last][run];
  607. if (level1 < 1)
  608. goto esc2;
  609. code = get_rl_index(rl, last, run, level1);
  610. if (code == rl->n) {
  611. esc2:
  612. put_bits(&s->pb, 1, 1);
  613. if (level > MAX_LEVEL)
  614. goto esc3;
  615. run1 = run - rl->max_run[last][level] - 1;
  616. if (run1 < 0)
  617. goto esc3;
  618. code = get_rl_index(rl, last, run1, level);
  619. if (code == rl->n) {
  620. esc3:
  621. /* third escape */
  622. put_bits(&s->pb, 1, 1);
  623. put_bits(&s->pb, 1, last);
  624. put_bits(&s->pb, 6, run);
  625. put_bits(&s->pb, 1, 1);
  626. put_bits(&s->pb, 12, slevel & 0xfff);
  627. put_bits(&s->pb, 1, 1);
  628. } else {
  629. /* second escape */
  630. put_bits(&s->pb, 1, 0);
  631. put_bits(&s->pb, rl->table_vlc[code][1], rl->table_vlc[code][0]);
  632. put_bits(&s->pb, 1, sign);
  633. }
  634. } else {
  635. /* first escape */
  636. put_bits(&s->pb, 1, 0);
  637. put_bits(&s->pb, rl->table_vlc[code][1], rl->table_vlc[code][0]);
  638. put_bits(&s->pb, 1, sign);
  639. }
  640. } else {
  641. put_bits(&s->pb, 1, sign);
  642. }
  643. last_non_zero = i;
  644. }
  645. }
  646. }
  647. /***********************************************/
  648. /* decoding */
  649. static VLC intra_MCBPC_vlc;
  650. static VLC inter_MCBPC_vlc;
  651. static VLC cbpy_vlc;
  652. static VLC mv_vlc;
  653. static VLC dc_lum, dc_chrom;
  654. void init_rl(RLTable *rl)
  655. {
  656. INT8 max_level[MAX_RUN+1], max_run[MAX_LEVEL+1];
  657. UINT8 index_run[MAX_RUN+1];
  658. int last, run, level, start, end, i;
  659. /* compute max_level[], max_run[] and index_run[] */
  660. for(last=0;last<2;last++) {
  661. if (last == 0) {
  662. start = 0;
  663. end = rl->last;
  664. } else {
  665. start = rl->last;
  666. end = rl->n;
  667. }
  668. memset(max_level, 0, MAX_RUN + 1);
  669. memset(max_run, 0, MAX_LEVEL + 1);
  670. memset(index_run, rl->n, MAX_RUN + 1);
  671. for(i=start;i<end;i++) {
  672. run = rl->table_run[i];
  673. level = rl->table_level[i];
  674. if (index_run[run] == rl->n)
  675. index_run[run] = i;
  676. if (level > max_level[run])
  677. max_level[run] = level;
  678. if (run > max_run[level])
  679. max_run[level] = run;
  680. }
  681. rl->max_level[last] = malloc(MAX_RUN + 1);
  682. memcpy(rl->max_level[last], max_level, MAX_RUN + 1);
  683. rl->max_run[last] = malloc(MAX_LEVEL + 1);
  684. memcpy(rl->max_run[last], max_run, MAX_LEVEL + 1);
  685. rl->index_run[last] = malloc(MAX_RUN + 1);
  686. memcpy(rl->index_run[last], index_run, MAX_RUN + 1);
  687. }
  688. }
  689. void init_vlc_rl(RLTable *rl)
  690. {
  691. init_vlc(&rl->vlc, 9, rl->n + 1,
  692. &rl->table_vlc[0][1], 4, 2,
  693. &rl->table_vlc[0][0], 4, 2);
  694. }
  695. /* init vlcs */
  696. /* XXX: find a better solution to handle static init */
  697. void h263_decode_init_vlc(MpegEncContext *s)
  698. {
  699. static int done = 0;
  700. if (!done) {
  701. done = 1;
  702. init_vlc(&intra_MCBPC_vlc, 6, 8,
  703. intra_MCBPC_bits, 1, 1,
  704. intra_MCBPC_code, 1, 1);
  705. init_vlc(&inter_MCBPC_vlc, 9, 25,
  706. inter_MCBPC_bits, 1, 1,
  707. inter_MCBPC_code, 1, 1);
  708. init_vlc(&cbpy_vlc, 6, 16,
  709. &cbpy_tab[0][1], 2, 1,
  710. &cbpy_tab[0][0], 2, 1);
  711. init_vlc(&mv_vlc, 9, 33,
  712. &mvtab[0][1], 2, 1,
  713. &mvtab[0][0], 2, 1);
  714. init_rl(&rl_inter);
  715. init_rl(&rl_intra);
  716. init_vlc_rl(&rl_inter);
  717. init_vlc_rl(&rl_intra);
  718. init_vlc(&dc_lum, 9, 13,
  719. &DCtab_lum[0][1], 2, 1,
  720. &DCtab_lum[0][0], 2, 1);
  721. init_vlc(&dc_chrom, 9, 13,
  722. &DCtab_chrom[0][1], 2, 1,
  723. &DCtab_chrom[0][0], 2, 1);
  724. }
  725. }
  726. int h263_decode_gob_header(MpegEncContext *s)
  727. {
  728. unsigned int val, gfid;
  729. /* Check for GOB Start Code */
  730. val = show_bits(&s->gb, 16);
  731. if (val == 0) {
  732. /* We have a GBSC probably with GSTUFF */
  733. skip_bits(&s->gb, 16); /* Drop the zeros */
  734. while (get_bits1(&s->gb) == 0); /* Seek the '1' bit */
  735. #ifdef DEBUG
  736. fprintf(stderr,"\nGOB Start Code at MB %d\n", (s->mb_y * s->mb_width) + s->mb_x);
  737. #endif
  738. s->gob_number = get_bits(&s->gb, 5); /* GN */
  739. gfid = get_bits(&s->gb, 2); /* GFID */
  740. s->qscale = get_bits(&s->gb, 5); /* GQUANT */
  741. #ifdef DEBUG
  742. fprintf(stderr, "\nGN: %u GFID: %u Quant: %u\n", gn, gfid, s->qscale);
  743. #endif
  744. return 1;
  745. }
  746. return 0;
  747. }
  748. int h263_decode_mb(MpegEncContext *s,
  749. DCTELEM block[6][64])
  750. {
  751. int cbpc, cbpy, i, cbp, pred_x, pred_y, mx, my, dquant;
  752. INT16 *mot_val;
  753. static INT8 quant_tab[4] = { -1, -2, 1, 2 };
  754. if (s->pict_type == P_TYPE) {
  755. if (get_bits1(&s->gb)) {
  756. /* skip mb */
  757. s->mb_intra = 0;
  758. for(i=0;i<6;i++)
  759. s->block_last_index[i] = -1;
  760. s->mv_dir = MV_DIR_FORWARD;
  761. s->mv_type = MV_TYPE_16X16;
  762. s->mv[0][0][0] = 0;
  763. s->mv[0][0][1] = 0;
  764. s->mb_skiped = 1;
  765. return 0;
  766. }
  767. cbpc = get_vlc(&s->gb, &inter_MCBPC_vlc);
  768. //fprintf(stderr, "\tCBPC: %d", cbpc);
  769. if (cbpc < 0)
  770. return -1;
  771. if (cbpc > 20)
  772. cbpc+=3;
  773. else if (cbpc == 20)
  774. fprintf(stderr, "Stuffing !");
  775. dquant = cbpc & 8;
  776. s->mb_intra = ((cbpc & 4) != 0);
  777. } else {
  778. cbpc = get_vlc(&s->gb, &intra_MCBPC_vlc);
  779. if (cbpc < 0)
  780. return -1;
  781. dquant = cbpc & 4;
  782. s->mb_intra = 1;
  783. }
  784. if (!s->mb_intra) {
  785. cbpy = get_vlc(&s->gb, &cbpy_vlc);
  786. cbp = (cbpc & 3) | ((cbpy ^ 0xf) << 2);
  787. if (dquant) {
  788. s->qscale += quant_tab[get_bits(&s->gb, 2)];
  789. if (s->qscale < 1)
  790. s->qscale = 1;
  791. else if (s->qscale > 31)
  792. s->qscale = 31;
  793. }
  794. s->mv_dir = MV_DIR_FORWARD;
  795. if ((cbpc & 16) == 0) {
  796. /* 16x16 motion prediction */
  797. s->mv_type = MV_TYPE_16X16;
  798. h263_pred_motion(s, 0, &pred_x, &pred_y);
  799. if (s->umvplus_dec)
  800. mx = h263p_decode_umotion(s, pred_x);
  801. else
  802. mx = h263_decode_motion(s, pred_x);
  803. if (mx >= 0xffff)
  804. return -1;
  805. if (s->umvplus_dec)
  806. my = h263p_decode_umotion(s, pred_y);
  807. else
  808. my = h263_decode_motion(s, pred_y);
  809. if (my >= 0xffff)
  810. return -1;
  811. s->mv[0][0][0] = mx;
  812. s->mv[0][0][1] = my;
  813. /*fprintf(stderr, "\n MB %d", (s->mb_y * s->mb_width) + s->mb_x);
  814. fprintf(stderr, "\n\tmvx: %d\t\tpredx: %d", mx, pred_x);
  815. fprintf(stderr, "\n\tmvy: %d\t\tpredy: %d", my, pred_y);*/
  816. if (s->umvplus_dec && (mx - pred_x) == 1 && (my - pred_y) == 1)
  817. skip_bits1(&s->gb); /* Bit stuffing to prevent PSC */
  818. } else {
  819. s->mv_type = MV_TYPE_8X8;
  820. for(i=0;i<4;i++) {
  821. mot_val = h263_pred_motion(s, i, &pred_x, &pred_y);
  822. if (s->umvplus_dec)
  823. mx = h263p_decode_umotion(s, pred_x);
  824. else
  825. mx = h263_decode_motion(s, pred_x);
  826. if (mx >= 0xffff)
  827. return -1;
  828. if (s->umvplus_dec)
  829. my = h263p_decode_umotion(s, pred_y);
  830. else
  831. my = h263_decode_motion(s, pred_y);
  832. if (my >= 0xffff)
  833. return -1;
  834. s->mv[0][i][0] = mx;
  835. s->mv[0][i][1] = my;
  836. if (s->umvplus_dec && (mx - pred_x) == 1 && (my - pred_y) == 1)
  837. skip_bits1(&s->gb); /* Bit stuffing to prevent PSC */
  838. mot_val[0] = mx;
  839. mot_val[1] = my;
  840. }
  841. }
  842. } else {
  843. s->ac_pred = 0;
  844. if (s->h263_pred) {
  845. s->ac_pred = get_bits1(&s->gb);
  846. }
  847. cbpy = get_vlc(&s->gb, &cbpy_vlc);
  848. cbp = (cbpc & 3) | (cbpy << 2);
  849. if (dquant) {
  850. s->qscale += quant_tab[get_bits(&s->gb, 2)];
  851. if (s->qscale < 1)
  852. s->qscale = 1;
  853. else if (s->qscale > 31)
  854. s->qscale = 31;
  855. }
  856. }
  857. /* decode each block */
  858. if (s->h263_pred) {
  859. for (i = 0; i < 6; i++) {
  860. if (mpeg4_decode_block(s, block[i], i, (cbp >> (5 - i)) & 1) < 0)
  861. return -1;
  862. }
  863. } else {
  864. for (i = 0; i < 6; i++) {
  865. if (h263_decode_block(s, block[i], i, (cbp >> (5 - i)) & 1) < 0)
  866. return -1;
  867. }
  868. }
  869. return 0;
  870. }
  871. static int h263_decode_motion(MpegEncContext * s, int pred)
  872. {
  873. int code, val, sign, shift, l, m;
  874. code = get_vlc(&s->gb, &mv_vlc);
  875. if (code < 0)
  876. return 0xffff;
  877. if (code == 0)
  878. return pred;
  879. sign = get_bits1(&s->gb);
  880. shift = s->f_code - 1;
  881. val = (code - 1) << shift;
  882. if (shift > 0)
  883. val |= get_bits(&s->gb, shift);
  884. val++;
  885. if (sign)
  886. val = -val;
  887. val += pred;
  888. /* modulo decoding */
  889. if (!s->h263_long_vectors) {
  890. l = (1 << (s->f_code - 1)) * 32;
  891. m = 2 * l;
  892. if (val < -l) {
  893. val += m;
  894. } else if (val >= l) {
  895. val -= m;
  896. }
  897. } else {
  898. /* horrible h263 long vector mode */
  899. if (pred < -31 && val < -63)
  900. val += 64;
  901. if (pred > 32 && val > 63)
  902. val -= 64;
  903. }
  904. return val;
  905. }
  906. /* Decodes RVLC of H.263+ UMV */
  907. static int h263p_decode_umotion(MpegEncContext * s, int pred)
  908. {
  909. int code = 0, sign;
  910. if (get_bits1(&s->gb)) /* Motion difference = 0 */
  911. return pred;
  912. code = 2 + get_bits1(&s->gb);
  913. while (get_bits1(&s->gb))
  914. {
  915. code <<= 1;
  916. code += get_bits1(&s->gb);
  917. }
  918. sign = code & 1;
  919. code >>= 1;
  920. code = (sign) ? (pred - code) : (pred + code);
  921. #ifdef DEBUG
  922. fprintf(stderr,"H.263+ UMV Motion = %d\n", code);
  923. #endif
  924. return code;
  925. }
  926. static int h263_decode_block(MpegEncContext * s, DCTELEM * block,
  927. int n, int coded)
  928. {
  929. int code, level, i, j, last, run;
  930. RLTable *rl = &rl_inter;
  931. if (s->mb_intra) {
  932. /* DC coef */
  933. if (s->h263_rv10 && s->rv10_version == 3 && s->pict_type == I_TYPE) {
  934. int component, diff;
  935. component = (n <= 3 ? 0 : n - 4 + 1);
  936. level = s->last_dc[component];
  937. if (s->rv10_first_dc_coded[component]) {
  938. diff = rv_decode_dc(s, n);
  939. if (diff == 0xffff)
  940. return -1;
  941. level += diff;
  942. level = level & 0xff; /* handle wrap round */
  943. s->last_dc[component] = level;
  944. } else {
  945. s->rv10_first_dc_coded[component] = 1;
  946. }
  947. } else {
  948. level = get_bits(&s->gb, 8);
  949. if (level == 255)
  950. level = 128;
  951. }
  952. block[0] = level;
  953. i = 1;
  954. } else {
  955. i = 0;
  956. }
  957. if (!coded) {
  958. s->block_last_index[n] = i - 1;
  959. return 0;
  960. }
  961. for(;;) {
  962. code = get_vlc(&s->gb, &rl->vlc);
  963. if (code < 0)
  964. return -1;
  965. if (code == rl->n) {
  966. /* escape */
  967. last = get_bits1(&s->gb);
  968. run = get_bits(&s->gb, 6);
  969. level = (INT8)get_bits(&s->gb, 8);
  970. if (s->h263_rv10 && level == -128) {
  971. /* XXX: should patch encoder too */
  972. level = get_bits(&s->gb, 12);
  973. level = (level << 20) >> 20;
  974. }
  975. } else {
  976. run = rl->table_run[code];
  977. level = rl->table_level[code];
  978. last = code >= rl->last;
  979. if (get_bits1(&s->gb))
  980. level = -level;
  981. }
  982. i += run;
  983. if (i >= 64)
  984. return -1;
  985. j = zigzag_direct[i];
  986. block[j] = level;
  987. if (last)
  988. break;
  989. i++;
  990. }
  991. s->block_last_index[n] = i;
  992. return 0;
  993. }
  994. static int mpeg4_decode_dc(MpegEncContext * s, int n, int *dir_ptr)
  995. {
  996. int level, pred, code;
  997. UINT16 *dc_val;
  998. if (n < 4)
  999. code = get_vlc(&s->gb, &dc_lum);
  1000. else
  1001. code = get_vlc(&s->gb, &dc_chrom);
  1002. if (code < 0)
  1003. return -1;
  1004. if (code == 0) {
  1005. level = 0;
  1006. } else {
  1007. level = get_bits(&s->gb, code);
  1008. if ((level >> (code - 1)) == 0) /* if MSB not set it is negative*/
  1009. level = - (level ^ ((1 << code) - 1));
  1010. if (code > 8)
  1011. skip_bits1(&s->gb); /* marker */
  1012. }
  1013. pred = mpeg4_pred_dc(s, n, &dc_val, dir_ptr);
  1014. level += pred;
  1015. if (level < 0)
  1016. level = 0;
  1017. if (n < 4) {
  1018. *dc_val = level * s->y_dc_scale;
  1019. } else {
  1020. *dc_val = level * s->c_dc_scale;
  1021. }
  1022. return level;
  1023. }
  1024. static int mpeg4_decode_block(MpegEncContext * s, DCTELEM * block,
  1025. int n, int coded)
  1026. {
  1027. int code, level, i, j, last, run;
  1028. int dc_pred_dir;
  1029. RLTable *rl;
  1030. const UINT8 *scan_table;
  1031. if (s->mb_intra) {
  1032. /* DC coef */
  1033. level = mpeg4_decode_dc(s, n, &dc_pred_dir);
  1034. if (level < 0)
  1035. return -1;
  1036. block[0] = level;
  1037. i = 1;
  1038. if (!coded)
  1039. goto not_coded;
  1040. rl = &rl_intra;
  1041. if (s->ac_pred) {
  1042. if (dc_pred_dir == 0)
  1043. scan_table = ff_alternate_vertical_scan; /* left */
  1044. else
  1045. scan_table = ff_alternate_horizontal_scan; /* top */
  1046. } else {
  1047. scan_table = zigzag_direct;
  1048. }
  1049. } else {
  1050. i = 0;
  1051. if (!coded) {
  1052. s->block_last_index[n] = i - 1;
  1053. return 0;
  1054. }
  1055. rl = &rl_inter;
  1056. scan_table = zigzag_direct;
  1057. }
  1058. for(;;) {
  1059. code = get_vlc(&s->gb, &rl->vlc);
  1060. if (code < 0)
  1061. return -1;
  1062. if (code == rl->n) {
  1063. /* escape */
  1064. if (get_bits1(&s->gb) != 0) {
  1065. if (get_bits1(&s->gb) != 0) {
  1066. /* third escape */
  1067. last = get_bits1(&s->gb);
  1068. run = get_bits(&s->gb, 6);
  1069. get_bits1(&s->gb); /* marker */
  1070. level = get_bits(&s->gb, 12);
  1071. level = (level << 20) >> 20; /* sign extend */
  1072. skip_bits1(&s->gb); /* marker */
  1073. } else {
  1074. /* second escape */
  1075. code = get_vlc(&s->gb, &rl->vlc);
  1076. if (code < 0 || code >= rl->n)
  1077. return -1;
  1078. run = rl->table_run[code];
  1079. level = rl->table_level[code];
  1080. last = code >= rl->last;
  1081. run += rl->max_run[last][level] + 1;
  1082. if (get_bits1(&s->gb))
  1083. level = -level;
  1084. }
  1085. } else {
  1086. /* first escape */
  1087. code = get_vlc(&s->gb, &rl->vlc);
  1088. if (code < 0 || code >= rl->n)
  1089. return -1;
  1090. run = rl->table_run[code];
  1091. level = rl->table_level[code];
  1092. last = code >= rl->last;
  1093. level += rl->max_level[last][run];
  1094. if (get_bits1(&s->gb))
  1095. level = -level;
  1096. }
  1097. } else {
  1098. run = rl->table_run[code];
  1099. level = rl->table_level[code];
  1100. last = code >= rl->last;
  1101. if (get_bits1(&s->gb))
  1102. level = -level;
  1103. }
  1104. i += run;
  1105. if (i >= 64)
  1106. return -1;
  1107. j = scan_table[i];
  1108. block[j] = level;
  1109. i++;
  1110. if (last)
  1111. break;
  1112. }
  1113. not_coded:
  1114. if (s->mb_intra) {
  1115. mpeg4_pred_ac(s, block, n, dc_pred_dir);
  1116. if (s->ac_pred) {
  1117. i = 64; /* XXX: not optimal */
  1118. }
  1119. }
  1120. s->block_last_index[n] = i - 1;
  1121. return 0;
  1122. }
  1123. /* most is hardcoded. should extend to handle all h263 streams */
  1124. int h263_decode_picture_header(MpegEncContext *s)
  1125. {
  1126. int format, width, height;
  1127. /* picture header */
  1128. if (get_bits(&s->gb, 22) != 0x20)
  1129. return -1;
  1130. skip_bits(&s->gb, 8); /* picture timestamp */
  1131. if (get_bits1(&s->gb) != 1)
  1132. return -1; /* marker */
  1133. if (get_bits1(&s->gb) != 0)
  1134. return -1; /* h263 id */
  1135. skip_bits1(&s->gb); /* split screen off */
  1136. skip_bits1(&s->gb); /* camera off */
  1137. skip_bits1(&s->gb); /* freeze picture release off */
  1138. /* Reset GOB number */
  1139. s->gob_number = 0;
  1140. format = get_bits(&s->gb, 3);
  1141. if (format != 7 && format != 6) {
  1142. s->h263_plus = 0;
  1143. /* H.263v1 */
  1144. width = h263_format[format][0];
  1145. height = h263_format[format][1];
  1146. if (!width)
  1147. return -1;
  1148. s->width = width;
  1149. s->height = height;
  1150. s->pict_type = I_TYPE + get_bits1(&s->gb);
  1151. s->unrestricted_mv = get_bits1(&s->gb);
  1152. s->h263_long_vectors = s->unrestricted_mv;
  1153. if (get_bits1(&s->gb) != 0)
  1154. return -1; /* SAC: off */
  1155. if (get_bits1(&s->gb) != 0) {
  1156. s->mv_type = MV_TYPE_8X8; /* Advanced prediction mode */
  1157. }
  1158. if (get_bits1(&s->gb) != 0)
  1159. return -1; /* not PB frame */
  1160. s->qscale = get_bits(&s->gb, 5);
  1161. skip_bits1(&s->gb); /* Continuous Presence Multipoint mode: off */
  1162. } else {
  1163. int ufep;
  1164. /* H.263v2 */
  1165. s->h263_plus = 1;
  1166. ufep = get_bits(&s->gb, 3); /* Update Full Extended PTYPE */
  1167. if (ufep == 1) {
  1168. /* OPPTYPE */
  1169. format = get_bits(&s->gb, 3);
  1170. skip_bits(&s->gb,1); /* Custom PCF */
  1171. s->umvplus_dec = get_bits(&s->gb, 1); /* Unrestricted Motion Vector */
  1172. skip_bits1(&s->gb); /* Syntax-based Arithmetic Coding (SAC) */
  1173. if (get_bits1(&s->gb) != 0) {
  1174. s->mv_type = MV_TYPE_8X8; /* Advanced prediction mode */
  1175. }
  1176. skip_bits(&s->gb, 8);
  1177. skip_bits(&s->gb, 3); /* Reserved */
  1178. } else if (ufep != 0)
  1179. return -1;
  1180. /* MPPTYPE */
  1181. s->pict_type = get_bits(&s->gb, 3) + 1;
  1182. if (s->pict_type != I_TYPE &&
  1183. s->pict_type != P_TYPE)
  1184. return -1;
  1185. skip_bits(&s->gb, 7);
  1186. /* Get the picture dimensions */
  1187. if (ufep) {
  1188. if (format == 6) {
  1189. /* Custom Picture Format (CPFMT) */
  1190. skip_bits(&s->gb, 4); /* aspect ratio */
  1191. width = (get_bits(&s->gb, 9) + 1) * 4;
  1192. skip_bits1(&s->gb);
  1193. height = get_bits(&s->gb, 9) * 4;
  1194. #ifdef DEBUG
  1195. fprintf(stderr,"\nH.263+ Custom picture: %dx%d\n",width,height);
  1196. #endif
  1197. }
  1198. else {
  1199. width = h263_format[format][0];
  1200. height = h263_format[format][1];
  1201. }
  1202. if ((width == 0) || (height == 0))
  1203. return -1;
  1204. s->width = width;
  1205. s->height = height;
  1206. if (s->umvplus_dec) {
  1207. skip_bits1(&s->gb); /* Unlimited Unrestricted Motion Vectors Indicator (UUI) */
  1208. }
  1209. }
  1210. s->qscale = get_bits(&s->gb, 5);
  1211. }
  1212. /* PEI */
  1213. while (get_bits1(&s->gb) != 0) {
  1214. skip_bits(&s->gb, 8);
  1215. }
  1216. s->f_code = 1;
  1217. return 0;
  1218. }
  1219. /* decode mpeg4 VOP header */
  1220. int mpeg4_decode_picture_header(MpegEncContext * s)
  1221. {
  1222. int time_incr, startcode, state, v;
  1223. redo:
  1224. /* search next start code */
  1225. align_get_bits(&s->gb);
  1226. state = 0xff;
  1227. for(;;) {
  1228. v = get_bits(&s->gb, 8);
  1229. if (state == 0x000001) {
  1230. state = ((state << 8) | v) & 0xffffff;
  1231. startcode = state;
  1232. break;
  1233. }
  1234. state = ((state << 8) | v) & 0xffffff;
  1235. /* XXX: really detect end of frame */
  1236. if (state == 0)
  1237. return -1;
  1238. }
  1239. if (startcode == 0x120) {
  1240. int time_increment_resolution, width, height, vo_ver_id;
  1241. /* vol header */
  1242. skip_bits(&s->gb, 1); /* random access */
  1243. skip_bits(&s->gb, 8); /* vo_type */
  1244. if (get_bits1(&s->gb) != 0) { /* is_ol_id */
  1245. vo_ver_id = get_bits(&s->gb, 4); /* vo_ver_id */
  1246. skip_bits(&s->gb, 3); /* vo_priority */
  1247. } else {
  1248. vo_ver_id = 1;
  1249. }
  1250. skip_bits(&s->gb, 4); /* aspect_ratio_info */
  1251. skip_bits1(&s->gb); /* vol control parameter */
  1252. s->shape = get_bits(&s->gb, 2); /* vol shape */
  1253. skip_bits1(&s->gb); /* marker */
  1254. time_increment_resolution = get_bits(&s->gb, 16);
  1255. s->time_increment_bits = av_log2(time_increment_resolution - 1) + 1;
  1256. if (s->time_increment_bits < 1)
  1257. s->time_increment_bits = 1;
  1258. skip_bits1(&s->gb); /* marker */
  1259. if (get_bits1(&s->gb) != 0) { /* fixed_vop_rate */
  1260. skip_bits(&s->gb, s->time_increment_bits);
  1261. }
  1262. if (s->shape != 2) {
  1263. if (s->shape == 0) {
  1264. skip_bits1(&s->gb); /* marker */
  1265. width = get_bits(&s->gb, 13);
  1266. skip_bits1(&s->gb); /* marker */
  1267. height = get_bits(&s->gb, 13);
  1268. skip_bits1(&s->gb); /* marker */
  1269. }
  1270. skip_bits1(&s->gb); /* interlaced */
  1271. skip_bits1(&s->gb); /* OBMC */
  1272. if (vo_ver_id == 1) {
  1273. s->vol_sprite_usage = get_bits1(&s->gb); /* vol_sprite_usage */
  1274. } else {
  1275. s->vol_sprite_usage = get_bits(&s->gb, 2); /* vol_sprite_usage */
  1276. }
  1277. if (get_bits1(&s->gb) == 1) { /* not_8_bit */
  1278. s->quant_precision = get_bits(&s->gb, 4); /* quant_precision */
  1279. skip_bits(&s->gb, 4); /* bits_per_pixel */
  1280. } else {
  1281. s->quant_precision = 5;
  1282. }
  1283. skip_bits1(&s->gb); /* vol_quant_type */
  1284. skip_bits1(&s->gb); /* vol_quarter_pixel */
  1285. skip_bits1(&s->gb); /* complexity_estimation_disabled */
  1286. skip_bits1(&s->gb); /* resync_marker_disabled */
  1287. skip_bits1(&s->gb); /* data_partioning_enabled */
  1288. if (get_bits1(&s->gb) != 0) { /* scalability */
  1289. printf("bad scalability!!!\n");
  1290. return -1;
  1291. }
  1292. }
  1293. goto redo;
  1294. } else if (startcode != 0x1b6) {
  1295. goto redo;
  1296. }
  1297. s->pict_type = get_bits(&s->gb, 2) + 1; /* pict type: I = 0 , P = 1 */
  1298. if (s->pict_type != I_TYPE &&
  1299. s->pict_type != P_TYPE)
  1300. return -1;
  1301. /* XXX: parse time base */
  1302. time_incr = 0;
  1303. while (get_bits1(&s->gb) != 0)
  1304. time_incr++;
  1305. skip_bits1(&s->gb); /* marker */
  1306. skip_bits(&s->gb, s->time_increment_bits);
  1307. skip_bits1(&s->gb); /* marker */
  1308. /* vop coded */
  1309. if (get_bits1(&s->gb) != 1)
  1310. goto redo;
  1311. if (s->shape != 2 && s->pict_type == P_TYPE) {
  1312. /* rounding type for motion estimation */
  1313. s->no_rounding = get_bits1(&s->gb);
  1314. } else {
  1315. s->no_rounding = 0;
  1316. }
  1317. if (s->shape != 0) {
  1318. if (s->vol_sprite_usage != 1 || s->pict_type != I_TYPE) {
  1319. int width, height, hor_spat_ref, ver_spat_ref;
  1320. width = get_bits(&s->gb, 13);
  1321. skip_bits1(&s->gb); /* marker */
  1322. height = get_bits(&s->gb, 13);
  1323. skip_bits1(&s->gb); /* marker */
  1324. hor_spat_ref = get_bits(&s->gb, 13); /* hor_spat_ref */
  1325. skip_bits1(&s->gb); /* marker */
  1326. ver_spat_ref = get_bits(&s->gb, 13); /* ver_spat_ref */
  1327. }
  1328. skip_bits1(&s->gb); /* change_CR_disable */
  1329. if (get_bits1(&s->gb) != 0) {
  1330. skip_bits(&s->gb, 8); /* constant_alpha_value */
  1331. }
  1332. }
  1333. if (s->shape != 2) {
  1334. skip_bits(&s->gb, 3); /* intra dc VLC threshold */
  1335. /* note: we do not use quant_precision to avoid problem if no
  1336. MPEG4 vol header as it is found on some old opendivx
  1337. movies */
  1338. s->qscale = get_bits(&s->gb, 5);
  1339. if (s->pict_type != I_TYPE) {
  1340. s->f_code = get_bits(&s->gb, 3); /* fcode_for */
  1341. }
  1342. if (s->shape && (s->pict_type != I_TYPE)) {
  1343. skip_bits1(&s->gb); // vop shape coding type
  1344. }
  1345. }
  1346. return 0;
  1347. }
  1348. /* don't understand why they choose a different header ! */
  1349. int intel_h263_decode_picture_header(MpegEncContext *s)
  1350. {
  1351. int format;
  1352. /* picture header */
  1353. if (get_bits(&s->gb, 22) != 0x20)
  1354. return -1;
  1355. skip_bits(&s->gb, 8); /* picture timestamp */
  1356. if (get_bits1(&s->gb) != 1)
  1357. return -1; /* marker */
  1358. if (get_bits1(&s->gb) != 0)
  1359. return -1; /* h263 id */
  1360. skip_bits1(&s->gb); /* split screen off */
  1361. skip_bits1(&s->gb); /* camera off */
  1362. skip_bits1(&s->gb); /* freeze picture release off */
  1363. format = get_bits(&s->gb, 3);
  1364. if (format != 7)
  1365. return -1;
  1366. s->h263_plus = 0;
  1367. s->pict_type = I_TYPE + get_bits1(&s->gb);
  1368. s->unrestricted_mv = get_bits1(&s->gb);
  1369. s->h263_long_vectors = s->unrestricted_mv;
  1370. if (get_bits1(&s->gb) != 0)
  1371. return -1; /* SAC: off */
  1372. if (get_bits1(&s->gb) != 0)
  1373. return -1; /* advanced prediction mode: off */
  1374. if (get_bits1(&s->gb) != 0)
  1375. return -1; /* not PB frame */
  1376. /* skip unknown header garbage */
  1377. skip_bits(&s->gb, 41);
  1378. s->qscale = get_bits(&s->gb, 5);
  1379. skip_bits1(&s->gb); /* Continuous Presence Multipoint mode: off */
  1380. /* PEI */
  1381. while (get_bits1(&s->gb) != 0) {
  1382. skip_bits(&s->gb, 8);
  1383. }
  1384. s->f_code = 1;
  1385. return 0;
  1386. }