annotate libmpeg2/header.c @ 13395:07708ec98d87

New MD5 sum video output driver. For every frame, it calculates the MD5 sum and writes a list of those sums to an, optionally specified, output file. It does not rely on external programs to be installed. The MD5 sum code is borrowed from the uCIFS library, written by Christopher R. Hertel in 2004 and released under the LGPL license. Note: This driver is not yet activated and will not be compiled and linked to libvo. A separate patch will take care of that. This is just for adding the files to the repository.
author ivo
date Mon, 20 Sep 2004 01:01:08 +0000
parents 34df725814e8
children 1385ec491ffb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
1 /*
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
2 * header.c
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
3 * Copyright (C) 2000-2003 Michel Lespinasse <walken@zoy.org>
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
4 * Copyright (C) 2003 Regis Duchesne <hpreg@zoy.org>
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
5 * Copyright (C) 1999-2000 Aaron Holtzman <aholtzma@ess.engr.uvic.ca>
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
6 *
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
7 * This file is part of mpeg2dec, a free MPEG-2 video stream decoder.
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
8 * See http://libmpeg2.sourceforge.net/ for updates.
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
9 *
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
10 * mpeg2dec is free software; you can redistribute it and/or modify
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
11 * it under the terms of the GNU General Public License as published by
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
12 * the Free Software Foundation; either version 2 of the License, or
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
13 * (at your option) any later version.
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
14 *
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
15 * mpeg2dec is distributed in the hope that it will be useful,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
18 * GNU General Public License for more details.
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
19 *
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
20 * You should have received a copy of the GNU General Public License
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
21 * along with this program; if not, write to the Free Software
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
22 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
23 */
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
24
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
25 #include "config.h"
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
26
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
27 #include <inttypes.h>
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
28 #include <stdlib.h> /* defines NULL */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
29 #include <string.h> /* memcmp */
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
30
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
31 #include "mpeg2.h"
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
32 #include "attributes.h"
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
33 #include "mpeg2_internal.h"
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
34
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
35 #define SEQ_EXT 2
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
36 #define SEQ_DISPLAY_EXT 4
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
37 #define QUANT_MATRIX_EXT 8
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
38 #define COPYRIGHT_EXT 0x10
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
39 #define PIC_DISPLAY_EXT 0x80
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
40 #define PIC_CODING_EXT 0x100
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
41
36
846535ace7a2 libmpeg2-0.2.0 merge
arpi_esp
parents: 1
diff changeset
42 /* default intra quant matrix, in zig-zag order */
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
43 static const uint8_t default_intra_quantizer_matrix[64] ATTR_ALIGN(16) = {
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
44 8,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
45 16, 16,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
46 19, 16, 19,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
47 22, 22, 22, 22,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
48 22, 22, 26, 24, 26,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
49 27, 27, 27, 26, 26, 26,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
50 26, 27, 27, 27, 29, 29, 29,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
51 34, 34, 34, 29, 29, 29, 27, 27,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
52 29, 29, 32, 32, 34, 34, 37,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
53 38, 37, 35, 35, 34, 35,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
54 38, 38, 40, 40, 40,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
55 48, 48, 46, 46,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
56 56, 56, 58,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
57 69, 69,
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
58 83
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
59 };
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
60
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
61 uint8_t mpeg2_scan_norm[64] ATTR_ALIGN(16) = {
36
846535ace7a2 libmpeg2-0.2.0 merge
arpi_esp
parents: 1
diff changeset
62 /* Zig-Zag scan pattern */
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
63 0, 1, 8, 16, 9, 2, 3, 10, 17, 24, 32, 25, 18, 11, 4, 5,
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
64 12, 19, 26, 33, 40, 48, 41, 34, 27, 20, 13, 6, 7, 14, 21, 28,
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
65 35, 42, 49, 56, 57, 50, 43, 36, 29, 22, 15, 23, 30, 37, 44, 51,
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
66 58, 59, 52, 45, 38, 31, 39, 46, 53, 60, 61, 54, 47, 55, 62, 63
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
67 };
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
68
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
69 uint8_t mpeg2_scan_alt[64] ATTR_ALIGN(16) = {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
70 /* Alternate scan pattern */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
71 0, 8, 16, 24, 1, 9, 2, 10, 17, 25, 32, 40, 48, 56, 57, 49,
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
72 41, 33, 26, 18, 3, 11, 4, 12, 19, 27, 34, 42, 50, 58, 35, 43,
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
73 51, 59, 20, 28, 5, 13, 6, 14, 21, 29, 36, 44, 52, 60, 37, 45,
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
74 53, 61, 22, 30, 7, 15, 23, 31, 38, 46, 54, 62, 39, 47, 55, 63
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
75 };
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
76
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
77 void mpeg2_header_state_init (mpeg2dec_t * mpeg2dec)
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
78 {
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
79 if (mpeg2dec->sequence.width != (unsigned)-1) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
80 int i;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
81
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
82 mpeg2dec->sequence.width = (unsigned)-1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
83 if (!mpeg2dec->custom_fbuf)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
84 for (i = mpeg2dec->alloc_index_user;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
85 i < mpeg2dec->alloc_index; i++) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
86 mpeg2_free (mpeg2dec->fbuf_alloc[i].fbuf.buf[0]);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
87 mpeg2_free (mpeg2dec->fbuf_alloc[i].fbuf.buf[1]);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
88 mpeg2_free (mpeg2dec->fbuf_alloc[i].fbuf.buf[2]);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
89 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
90 if (mpeg2dec->convert_start)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
91 for (i = 0; i < 3; i++) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
92 mpeg2_free (mpeg2dec->yuv_buf[i][0]);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
93 mpeg2_free (mpeg2dec->yuv_buf[i][1]);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
94 mpeg2_free (mpeg2dec->yuv_buf[i][2]);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
95 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
96 if (mpeg2dec->decoder.convert_id)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
97 mpeg2_free (mpeg2dec->decoder.convert_id);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
98 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
99 mpeg2dec->decoder.coding_type = I_TYPE;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
100 mpeg2dec->decoder.convert = NULL;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
101 mpeg2dec->decoder.convert_id = NULL;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
102 mpeg2dec->picture = mpeg2dec->pictures;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
103 memset(&mpeg2dec->fbuf_alloc[0].fbuf, 0, sizeof(mpeg2_fbuf_t));
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
104 memset(&mpeg2dec->fbuf_alloc[1].fbuf, 0, sizeof(mpeg2_fbuf_t));
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
105 memset(&mpeg2dec->fbuf_alloc[2].fbuf, 0, sizeof(mpeg2_fbuf_t));
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
106 mpeg2dec->fbuf[0] = &mpeg2dec->fbuf_alloc[0].fbuf;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
107 mpeg2dec->fbuf[1] = &mpeg2dec->fbuf_alloc[1].fbuf;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
108 mpeg2dec->fbuf[2] = &mpeg2dec->fbuf_alloc[2].fbuf;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
109 mpeg2dec->first = 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
110 mpeg2dec->alloc_index = 0;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
111 mpeg2dec->alloc_index_user = 0;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
112 mpeg2dec->first_decode_slice = 1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
113 mpeg2dec->nb_decode_slices = 0xb0 - 1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
114 mpeg2dec->convert = NULL;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
115 mpeg2dec->convert_start = NULL;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
116 mpeg2dec->custom_fbuf = 0;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
117 mpeg2dec->yuv_index = 0;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
118 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
119
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
120 void mpeg2_reset_info (mpeg2_info_t * info)
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
121 {
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
122 info->current_picture = info->current_picture_2nd = NULL;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
123 info->display_picture = info->display_picture_2nd = NULL;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
124 info->current_fbuf = info->display_fbuf = info->discard_fbuf = NULL;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
125 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
126
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
127 static void info_user_data (mpeg2dec_t * mpeg2dec)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
128 {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
129 if (mpeg2dec->user_data_len) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
130 mpeg2dec->info.user_data = mpeg2dec->chunk_buffer;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
131 mpeg2dec->info.user_data_len = mpeg2dec->user_data_len - 3;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
132 }
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
133 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
134
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
135 int mpeg2_header_sequence (mpeg2dec_t * mpeg2dec)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
136 {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
137 uint8_t * buffer = mpeg2dec->chunk_start;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
138 mpeg2_sequence_t * sequence = &(mpeg2dec->new_sequence);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
139 static unsigned int frame_period[16] = {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
140 0, 1126125, 1125000, 1080000, 900900, 900000, 540000, 450450, 450000,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
141 /* unofficial: xing 15 fps */
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
142 1800000,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
143 /* unofficial: libmpeg3 "Unofficial economy rates" 5/10/12/15 fps */
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
144 5400000, 2700000, 2250000, 1800000, 0, 0
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
145 };
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
146 int i;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
147
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
148 if ((buffer[6] & 0x20) != 0x20) /* missing marker_bit */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
149 return 1;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
150
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
151 i = (buffer[0] << 16) | (buffer[1] << 8) | buffer[2];
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
152 if (! (sequence->display_width = sequence->picture_width = i >> 12))
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
153 return 1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
154 if (! (sequence->display_height = sequence->picture_height = i & 0xfff))
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
155 return 1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
156 sequence->width = (sequence->picture_width + 15) & ~15;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
157 sequence->height = (sequence->picture_height + 15) & ~15;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
158 sequence->chroma_width = sequence->width >> 1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
159 sequence->chroma_height = sequence->height >> 1;
12617
55b9c352d019 width and height in seq_header could never be 0
iive
parents: 10509
diff changeset
160
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
161 sequence->flags = (SEQ_FLAG_PROGRESSIVE_SEQUENCE |
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
162 SEQ_VIDEO_FORMAT_UNSPECIFIED);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
163
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
164 sequence->pixel_width = buffer[3] >> 4; /* aspect ratio */
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
165 sequence->frame_period = frame_period[buffer[3] & 15];
36
846535ace7a2 libmpeg2-0.2.0 merge
arpi_esp
parents: 1
diff changeset
166
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
167 sequence->byte_rate = (buffer[4]<<10) | (buffer[5]<<2) | (buffer[6]>>6);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
168
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
169 sequence->vbv_buffer_size = ((buffer[6]<<16)|(buffer[7]<<8))&0x1ff800;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
170
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
171 if (buffer[7] & 4)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
172 sequence->flags |= SEQ_FLAG_CONSTRAINED_PARAMETERS;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
173
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
174 mpeg2dec->copy_matrix = 3;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
175 if (buffer[7] & 2) {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
176 for (i = 0; i < 64; i++)
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
177 mpeg2dec->new_quantizer_matrix[0][mpeg2_scan_norm[i]] =
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
178 (buffer[i+7] << 7) | (buffer[i+8] >> 1);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
179 buffer += 64;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
180 } else
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
181 for (i = 0; i < 64; i++)
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
182 mpeg2dec->new_quantizer_matrix[0][mpeg2_scan_norm[i]] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
183 default_intra_quantizer_matrix[i];
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
184
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
185 if (buffer[7] & 1)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
186 for (i = 0; i < 64; i++)
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
187 mpeg2dec->new_quantizer_matrix[1][mpeg2_scan_norm[i]] =
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
188 buffer[i+8];
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
189 else
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
190 memset (mpeg2dec->new_quantizer_matrix[1], 16, 64);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
191
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
192 sequence->profile_level_id = 0x80;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
193 sequence->colour_primaries = 0;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
194 sequence->transfer_characteristics = 0;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
195 sequence->matrix_coefficients = 0;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
196
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
197 mpeg2dec->ext_state = SEQ_EXT;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
198 mpeg2dec->state = STATE_SEQUENCE;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
199 mpeg2dec->display_offset_x = mpeg2dec->display_offset_y = 0;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
200
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
201 return 0;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
202 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
203
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
204 static int sequence_ext (mpeg2dec_t * mpeg2dec)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
205 {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
206 uint8_t * buffer = mpeg2dec->chunk_start;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
207 mpeg2_sequence_t * sequence = &(mpeg2dec->new_sequence);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
208 uint32_t flags;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
209
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
210 if (!(buffer[3] & 1))
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
211 return 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
212
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
213 sequence->profile_level_id = (buffer[0] << 4) | (buffer[1] >> 4);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
214
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
215 sequence->display_width = sequence->picture_width +=
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
216 ((buffer[1] << 13) | (buffer[2] << 5)) & 0x3000;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
217 sequence->display_height = sequence->picture_height +=
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
218 (buffer[2] << 7) & 0x3000;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
219 sequence->width = (sequence->picture_width + 15) & ~15;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
220 sequence->height = (sequence->picture_height + 15) & ~15;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
221 flags = sequence->flags | SEQ_FLAG_MPEG2;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
222 if (!(buffer[1] & 8)) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
223 flags &= ~SEQ_FLAG_PROGRESSIVE_SEQUENCE;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
224 sequence->height = (sequence->height + 31) & ~31;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
225 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
226 if (buffer[5] & 0x80)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
227 flags |= SEQ_FLAG_LOW_DELAY;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
228 sequence->flags = flags;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
229 sequence->chroma_width = sequence->width;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
230 sequence->chroma_height = sequence->height;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
231 switch (buffer[1] & 6) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
232 case 0: /* invalid */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
233 return 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
234 case 2: /* 4:2:0 */
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
235 sequence->chroma_height >>= 1;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
236 case 4: /* 4:2:2 */
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
237 sequence->chroma_width >>= 1;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
238 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
239
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
240 sequence->byte_rate += ((buffer[2]<<25) | (buffer[3]<<17)) & 0x3ffc0000;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
241
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
242 sequence->vbv_buffer_size |= buffer[4] << 21;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
243
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
244 sequence->frame_period =
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
245 sequence->frame_period * ((buffer[5]&31)+1) / (((buffer[5]>>2)&3)+1);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
246
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
247 mpeg2dec->ext_state = SEQ_DISPLAY_EXT;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
248
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
249 return 0;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
250 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
251
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
252 static int sequence_display_ext (mpeg2dec_t * mpeg2dec)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
253 {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
254 uint8_t * buffer = mpeg2dec->chunk_start;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
255 mpeg2_sequence_t * sequence = &(mpeg2dec->new_sequence);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
256 uint32_t flags;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
257
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
258 flags = ((sequence->flags & ~SEQ_MASK_VIDEO_FORMAT) |
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
259 ((buffer[0]<<4) & SEQ_MASK_VIDEO_FORMAT));
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
260 if (buffer[0] & 1) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
261 flags |= SEQ_FLAG_COLOUR_DESCRIPTION;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
262 sequence->colour_primaries = buffer[1];
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
263 sequence->transfer_characteristics = buffer[2];
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
264 sequence->matrix_coefficients = buffer[3];
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
265 buffer += 3;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
266 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
267
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
268 if (!(buffer[2] & 2)) /* missing marker_bit */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
269 return 1;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
270
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
271 sequence->display_width = (buffer[1] << 6) | (buffer[2] >> 2);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
272 sequence->display_height =
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
273 ((buffer[2]& 1 ) << 13) | (buffer[3] << 5) | (buffer[4] >> 3);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
274
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
275 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
276 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
277
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
278 static inline void finalize_sequence (mpeg2_sequence_t * sequence)
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
279 {
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
280 int width;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
281 int height;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
282
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
283 sequence->byte_rate *= 50;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
284
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
285 if (sequence->flags & SEQ_FLAG_MPEG2) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
286 switch (sequence->pixel_width) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
287 case 1: /* square pixels */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
288 sequence->pixel_width = sequence->pixel_height = 1; return;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
289 case 2: /* 4:3 aspect ratio */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
290 width = 4; height = 3; break;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
291 case 3: /* 16:9 aspect ratio */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
292 width = 16; height = 9; break;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
293 case 4: /* 2.21:1 aspect ratio */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
294 width = 221; height = 100; break;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
295 default: /* illegal */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
296 sequence->pixel_width = sequence->pixel_height = 0; return;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
297 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
298 width *= sequence->display_height;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
299 height *= sequence->display_width;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
300
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
301 } else {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
302 if (sequence->byte_rate == 50 * 0x3ffff)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
303 sequence->byte_rate = 0; /* mpeg-1 VBR */
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
304
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
305 switch (sequence->pixel_width) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
306 case 0: case 15: /* illegal */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
307 sequence->pixel_width = sequence->pixel_height = 0; return;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
308 case 1: /* square pixels */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
309 sequence->pixel_width = sequence->pixel_height = 1; return;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
310 case 3: /* 720x576 16:9 */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
311 sequence->pixel_width = 64; sequence->pixel_height = 45; return;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
312 case 6: /* 720x480 16:9 */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
313 sequence->pixel_width = 32; sequence->pixel_height = 27; return;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
314 case 12: /* 720*480 4:3 */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
315 sequence->pixel_width = 8; sequence->pixel_height = 9; return;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
316 default:
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
317 height = 88 * sequence->pixel_width + 1171;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
318 width = 2000;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
319 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
320 }
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
321
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
322 sequence->pixel_width = width;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
323 sequence->pixel_height = height;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
324 while (width) { /* find greatest common divisor */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
325 int tmp = width;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
326 width = height % tmp;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
327 height = tmp;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
328 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
329 sequence->pixel_width /= height;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
330 sequence->pixel_height /= height;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
331 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
332
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
333 static void copy_matrix (mpeg2dec_t * mpeg2dec, int index)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
334 {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
335 if (memcmp (mpeg2dec->quantizer_matrix[index],
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
336 mpeg2dec->new_quantizer_matrix[index], 64)) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
337 memcpy (mpeg2dec->quantizer_matrix[index],
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
338 mpeg2dec->new_quantizer_matrix[index], 64);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
339 mpeg2dec->scaled[index] = -1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
340 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
341 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
342
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
343 static void finalize_matrix (mpeg2dec_t * mpeg2dec)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
344 {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
345 mpeg2_decoder_t * decoder = &(mpeg2dec->decoder);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
346 int i;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
347
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
348 for (i = 0; i < 2; i++) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
349 if (mpeg2dec->copy_matrix & (1 << i))
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
350 copy_matrix (mpeg2dec, i);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
351 if ((mpeg2dec->copy_matrix & (4 << i)) &&
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
352 memcmp (mpeg2dec->quantizer_matrix[i],
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
353 mpeg2dec->new_quantizer_matrix[i+2], 64)) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
354 copy_matrix (mpeg2dec, i + 2);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
355 decoder->chroma_quantizer[i] = decoder->quantizer_prescale[i+2];
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
356 } else if (mpeg2dec->copy_matrix & (5 << i))
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
357 decoder->chroma_quantizer[i] = decoder->quantizer_prescale[i];
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
358 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
359 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
360
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
361 static mpeg2_state_t invalid_end_action (mpeg2dec_t * mpeg2dec)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
362 {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
363 mpeg2_reset_info (&(mpeg2dec->info));
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
364 mpeg2dec->info.gop = NULL;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
365 info_user_data (mpeg2dec);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
366 mpeg2_header_state_init (mpeg2dec);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
367 mpeg2dec->sequence = mpeg2dec->new_sequence;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
368 mpeg2dec->action = mpeg2_seek_header;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
369 mpeg2dec->state = STATE_SEQUENCE;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
370 return STATE_SEQUENCE;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
371 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
372
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
373 void mpeg2_header_sequence_finalize (mpeg2dec_t * mpeg2dec)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
374 {
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
375 mpeg2_sequence_t * sequence = &(mpeg2dec->new_sequence);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
376 mpeg2_decoder_t * decoder = &(mpeg2dec->decoder);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
377
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
378 finalize_sequence (sequence);
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
379 finalize_matrix (mpeg2dec);
36
846535ace7a2 libmpeg2-0.2.0 merge
arpi_esp
parents: 1
diff changeset
380
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
381 decoder->mpeg1 = !(sequence->flags & SEQ_FLAG_MPEG2);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
382 decoder->width = sequence->width;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
383 decoder->height = sequence->height;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
384 decoder->vertical_position_extension = (sequence->picture_height > 2800);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
385 decoder->chroma_format = ((sequence->chroma_width == sequence->width) +
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
386 (sequence->chroma_height == sequence->height));
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
387
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
388 if (mpeg2dec->sequence.width != (unsigned)-1) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
389 unsigned int new_byte_rate;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
390
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
391 /*
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
392 * According to 6.1.1.6, repeat sequence headers should be
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
393 * identical to the original. However some DVDs dont respect
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
394 * that and have different bitrates in the repeat sequence
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
395 * headers. So we'll ignore that in the comparison and still
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
396 * consider these as repeat sequence headers.
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
397 *
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
398 * However, be careful not to alter the current sequence when
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
399 * returning STATE_INVALID_END.
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
400 */
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
401 new_byte_rate = sequence->byte_rate;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
402 sequence->byte_rate = mpeg2dec->sequence.byte_rate;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
403 if (memcmp (&(mpeg2dec->sequence), sequence,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
404 sizeof (mpeg2_sequence_t))) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
405 decoder->stride_frame = sequence->width;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
406 sequence->byte_rate = new_byte_rate;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
407 mpeg2_header_end (mpeg2dec);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
408 mpeg2dec->action = invalid_end_action;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
409 mpeg2dec->state = STATE_INVALID_END;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
410 return;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
411 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
412 sequence->byte_rate = new_byte_rate;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
413 mpeg2dec->state = STATE_SEQUENCE_REPEATED;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
414 } else
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
415 decoder->stride_frame = sequence->width;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
416 mpeg2dec->sequence = *sequence;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
417 mpeg2_reset_info (&(mpeg2dec->info));
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
418 mpeg2dec->info.sequence = &(mpeg2dec->sequence);
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
419 mpeg2dec->info.gop = NULL;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
420 info_user_data (mpeg2dec);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
421 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
422
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
423 int mpeg2_header_gop (mpeg2dec_t * mpeg2dec)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
424 {
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
425 uint8_t * buffer = mpeg2dec->chunk_start;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
426 mpeg2_gop_t * gop = &(mpeg2dec->new_gop);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
427
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
428 if (! (buffer[1] & 8))
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
429 return 1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
430 gop->hours = (buffer[0] >> 2) & 31;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
431 gop->minutes = ((buffer[0] << 4) | (buffer[1] >> 4)) & 63;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
432 gop->seconds = ((buffer[1] << 3) | (buffer[2] >> 5)) & 63;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
433 gop->pictures = ((buffer[2] << 1) | (buffer[3] >> 7)) & 63;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
434 gop->flags = (buffer[0] >> 7) | ((buffer[3] >> 4) & 6);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
435 mpeg2dec->state = STATE_GOP;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
436 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
437 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
438
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
439 void mpeg2_header_gop_finalize (mpeg2dec_t * mpeg2dec)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
440 {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
441 mpeg2dec->gop = mpeg2dec->new_gop;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
442 mpeg2_reset_info (&(mpeg2dec->info));
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
443 mpeg2dec->info.gop = &(mpeg2dec->gop);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
444 info_user_data (mpeg2dec);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
445 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
446
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
447 void mpeg2_set_fbuf (mpeg2dec_t * mpeg2dec, int b_type)
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
448 {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
449 int i;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
450
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
451 for (i = 0; i < 3; i++)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
452 if (mpeg2dec->fbuf[1] != &mpeg2dec->fbuf_alloc[i].fbuf &&
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
453 mpeg2dec->fbuf[2] != &mpeg2dec->fbuf_alloc[i].fbuf) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
454 mpeg2dec->fbuf[0] = &mpeg2dec->fbuf_alloc[i].fbuf;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
455 mpeg2dec->info.current_fbuf = mpeg2dec->fbuf[0];
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
456 if (b_type || (mpeg2dec->sequence.flags & SEQ_FLAG_LOW_DELAY)) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
457 if (b_type || mpeg2dec->convert)
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
458 mpeg2dec->info.discard_fbuf = mpeg2dec->fbuf[0];
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
459 mpeg2dec->info.display_fbuf = mpeg2dec->fbuf[0];
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
460 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
461 break;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
462 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
463 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
464
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
465 mpeg2_state_t mpeg2_header_picture_start (mpeg2dec_t * mpeg2dec)
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
466 {
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
467 mpeg2_picture_t * picture = &(mpeg2dec->new_picture);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
468
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
469 mpeg2dec->state = ((mpeg2dec->state != STATE_SLICE_1ST) ?
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
470 STATE_PICTURE : STATE_PICTURE_2ND);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
471 picture->flags = 0;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
472 picture->tag = picture->tag2 = 0;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
473 if (mpeg2dec->num_tags) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
474 if (mpeg2dec->bytes_since_tag >= 4) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
475 mpeg2dec->num_tags = 0;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
476 picture->tag = mpeg2dec->tag_current;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
477 picture->tag2 = mpeg2dec->tag2_current;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
478 picture->flags = PIC_FLAG_TAGS;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
479 } else if (mpeg2dec->num_tags > 1) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
480 mpeg2dec->num_tags = 1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
481 picture->tag = mpeg2dec->tag_previous;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
482 picture->tag2 = mpeg2dec->tag2_previous;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
483 picture->flags = PIC_FLAG_TAGS;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
484 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
485 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
486 picture->display_offset[0].x = picture->display_offset[1].x =
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
487 picture->display_offset[2].x = mpeg2dec->display_offset_x;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
488 picture->display_offset[0].y = picture->display_offset[1].y =
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
489 picture->display_offset[2].y = mpeg2dec->display_offset_y;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
490 return mpeg2_parse_header (mpeg2dec);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
491 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
492
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
493 int mpeg2_header_picture (mpeg2dec_t * mpeg2dec)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
494 {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
495 uint8_t * buffer = mpeg2dec->chunk_start;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
496 mpeg2_picture_t * picture = &(mpeg2dec->new_picture);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
497 mpeg2_decoder_t * decoder = &(mpeg2dec->decoder);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
498 int type;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
499
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
500 type = (buffer [1] >> 3) & 7;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
501 mpeg2dec->ext_state = PIC_CODING_EXT;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
502
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
503 picture->temporal_reference = (buffer[0] << 2) | (buffer[1] >> 6);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
504
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
505 picture->flags |= type;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
506
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
507 if (type == PIC_FLAG_CODING_TYPE_P || type == PIC_FLAG_CODING_TYPE_B) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
508 /* forward_f_code and backward_f_code - used in mpeg1 only */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
509 decoder->f_motion.f_code[1] = (buffer[3] >> 2) & 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
510 decoder->f_motion.f_code[0] =
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
511 (((buffer[3] << 1) | (buffer[4] >> 7)) & 7) - 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
512 decoder->b_motion.f_code[1] = (buffer[4] >> 6) & 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
513 decoder->b_motion.f_code[0] = ((buffer[4] >> 3) & 7) - 1;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
514 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
515
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
516 /* XXXXXX decode extra_information_picture as well */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
517
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
518 picture->nb_fields = 2;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
519
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
520 mpeg2dec->q_scale_type = 0;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
521 decoder->intra_dc_precision = 7;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
522 decoder->frame_pred_frame_dct = 1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
523 decoder->concealment_motion_vectors = 0;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
524 decoder->scan = mpeg2_scan_norm;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
525 decoder->picture_structure = FRAME_PICTURE;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
526 mpeg2dec->copy_matrix = 0;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
527
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
528 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
529 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
530
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
531 static int picture_coding_ext (mpeg2dec_t * mpeg2dec)
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
532 {
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
533 uint8_t * buffer = mpeg2dec->chunk_start;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
534 mpeg2_picture_t * picture = &(mpeg2dec->new_picture);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
535 mpeg2_decoder_t * decoder = &(mpeg2dec->decoder);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
536 uint32_t flags;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
537
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
538 /* pre subtract 1 for use later in compute_motion_vector */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
539 decoder->f_motion.f_code[0] = (buffer[0] & 15) - 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
540 decoder->f_motion.f_code[1] = (buffer[1] >> 4) - 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
541 decoder->b_motion.f_code[0] = (buffer[1] & 15) - 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
542 decoder->b_motion.f_code[1] = (buffer[2] >> 4) - 1;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
543
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
544 flags = picture->flags;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
545 decoder->intra_dc_precision = 7 - ((buffer[2] >> 2) & 3);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
546 decoder->picture_structure = buffer[2] & 3;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
547 switch (decoder->picture_structure) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
548 case TOP_FIELD:
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
549 flags |= PIC_FLAG_TOP_FIELD_FIRST;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
550 case BOTTOM_FIELD:
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
551 picture->nb_fields = 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
552 break;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
553 case FRAME_PICTURE:
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
554 if (!(mpeg2dec->sequence.flags & SEQ_FLAG_PROGRESSIVE_SEQUENCE)) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
555 picture->nb_fields = (buffer[3] & 2) ? 3 : 2;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
556 flags |= (buffer[3] & 128) ? PIC_FLAG_TOP_FIELD_FIRST : 0;
10509
d9d24093db2e Export flags needed for softpulldown filter.
ranma
parents: 9858
diff changeset
557 flags |= (buffer[3] & 2) ? PIC_FLAG_REPEAT_FIRST_FIELD : 0;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
558 } else
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
559 picture->nb_fields = (buffer[3]&2) ? ((buffer[3]&128) ? 6 : 4) : 2;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
560 break;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
561 default:
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
562 return 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
563 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
564 decoder->top_field_first = buffer[3] >> 7;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
565 decoder->frame_pred_frame_dct = (buffer[3] >> 6) & 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
566 decoder->concealment_motion_vectors = (buffer[3] >> 5) & 1;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
567 mpeg2dec->q_scale_type = buffer[3] & 16;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
568 decoder->intra_vlc_format = (buffer[3] >> 3) & 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
569 decoder->scan = (buffer[3] & 4) ? mpeg2_scan_alt : mpeg2_scan_norm;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
570 flags |= (buffer[4] & 0x80) ? PIC_FLAG_PROGRESSIVE_FRAME : 0;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
571 if (buffer[4] & 0x40)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
572 flags |= (((buffer[4]<<26) | (buffer[5]<<18) | (buffer[6]<<10)) &
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
573 PIC_MASK_COMPOSITE_DISPLAY) | PIC_FLAG_COMPOSITE_DISPLAY;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
574 picture->flags = flags;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
575
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
576 mpeg2dec->ext_state = PIC_DISPLAY_EXT | COPYRIGHT_EXT | QUANT_MATRIX_EXT;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
577
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
578 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
579 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
580
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
581 static int picture_display_ext (mpeg2dec_t * mpeg2dec)
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
582 {
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
583 uint8_t * buffer = mpeg2dec->chunk_start;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
584 mpeg2_picture_t * picture = &(mpeg2dec->new_picture);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
585 int i, nb_pos;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
586
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
587 nb_pos = picture->nb_fields;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
588 if (mpeg2dec->sequence.flags & SEQ_FLAG_PROGRESSIVE_SEQUENCE)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
589 nb_pos >>= 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
590
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
591 for (i = 0; i < nb_pos; i++) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
592 int x, y;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
593
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
594 x = ((buffer[4*i] << 24) | (buffer[4*i+1] << 16) |
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
595 (buffer[4*i+2] << 8) | buffer[4*i+3]) >> (11-2*i);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
596 y = ((buffer[4*i+2] << 24) | (buffer[4*i+3] << 16) |
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
597 (buffer[4*i+4] << 8) | buffer[4*i+5]) >> (10-2*i);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
598 if (! (x & y & 1))
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
599 return 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
600 picture->display_offset[i].x = mpeg2dec->display_offset_x = x >> 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
601 picture->display_offset[i].y = mpeg2dec->display_offset_y = y >> 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
602 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
603 for (; i < 3; i++) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
604 picture->display_offset[i].x = mpeg2dec->display_offset_x;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
605 picture->display_offset[i].y = mpeg2dec->display_offset_y;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
606 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
607 return 0;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
608 }
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
609
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
610 void mpeg2_header_picture_finalize (mpeg2dec_t * mpeg2dec, uint32_t accels)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
611 {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
612 mpeg2_decoder_t * decoder = &(mpeg2dec->decoder);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
613 int old_type_b = (decoder->coding_type == B_TYPE);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
614 int low_delay = mpeg2dec->sequence.flags & SEQ_FLAG_LOW_DELAY;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
615
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
616 finalize_matrix (mpeg2dec);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
617 decoder->coding_type = mpeg2dec->new_picture.flags & PIC_MASK_CODING_TYPE;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
618
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
619 if (mpeg2dec->state == STATE_PICTURE) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
620 mpeg2_picture_t * picture;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
621 mpeg2_picture_t * other;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
622
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
623 decoder->second_field = 0;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
624
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
625 picture = other = mpeg2dec->pictures;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
626 if (old_type_b ^ (mpeg2dec->picture < mpeg2dec->pictures + 2))
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
627 picture += 2;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
628 else
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
629 other += 2;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
630 mpeg2dec->picture = picture;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
631 *picture = mpeg2dec->new_picture;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
632
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
633 if (!old_type_b) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
634 mpeg2dec->fbuf[2] = mpeg2dec->fbuf[1];
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
635 mpeg2dec->fbuf[1] = mpeg2dec->fbuf[0];
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
636 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
637 mpeg2dec->fbuf[0] = NULL;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
638 mpeg2_reset_info (&(mpeg2dec->info));
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
639 mpeg2dec->info.current_picture = picture;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
640 mpeg2dec->info.display_picture = picture;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
641 if (decoder->coding_type != B_TYPE) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
642 if (!low_delay) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
643 if (mpeg2dec->first) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
644 mpeg2dec->info.display_picture = NULL;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
645 mpeg2dec->first = 0;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
646 } else {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
647 mpeg2dec->info.display_picture = other;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
648 if (other->nb_fields == 1)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
649 mpeg2dec->info.display_picture_2nd = other + 1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
650 mpeg2dec->info.display_fbuf = mpeg2dec->fbuf[1];
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
651 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
652 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
653 if (!low_delay + !mpeg2dec->convert)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
654 mpeg2dec->info.discard_fbuf =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
655 mpeg2dec->fbuf[!low_delay + !mpeg2dec->convert];
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
656 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
657 if (mpeg2dec->convert) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
658 mpeg2_convert_init_t convert_init;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
659 if (!mpeg2dec->convert_start) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
660 int y_size, uv_size;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
661
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
662 mpeg2dec->decoder.convert_id =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
663 mpeg2_malloc (mpeg2dec->convert_id_size,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
664 MPEG2_ALLOC_CONVERT_ID);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
665 mpeg2dec->convert (MPEG2_CONVERT_START,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
666 mpeg2dec->decoder.convert_id,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
667 &(mpeg2dec->sequence),
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
668 mpeg2dec->convert_stride, accels,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
669 mpeg2dec->convert_arg, &convert_init);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
670 mpeg2dec->convert_start = convert_init.start;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
671 mpeg2dec->decoder.convert = convert_init.copy;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
672
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
673 y_size = decoder->stride_frame * mpeg2dec->sequence.height;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
674 uv_size = y_size >> (2 - mpeg2dec->decoder.chroma_format);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
675 mpeg2dec->yuv_buf[0][0] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
676 (uint8_t *) mpeg2_malloc (y_size, MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
677 mpeg2dec->yuv_buf[0][1] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
678 (uint8_t *) mpeg2_malloc (uv_size, MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
679 mpeg2dec->yuv_buf[0][2] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
680 (uint8_t *) mpeg2_malloc (uv_size, MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
681 mpeg2dec->yuv_buf[1][0] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
682 (uint8_t *) mpeg2_malloc (y_size, MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
683 mpeg2dec->yuv_buf[1][1] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
684 (uint8_t *) mpeg2_malloc (uv_size, MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
685 mpeg2dec->yuv_buf[1][2] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
686 (uint8_t *) mpeg2_malloc (uv_size, MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
687 y_size = decoder->stride_frame * 32;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
688 uv_size = y_size >> (2 - mpeg2dec->decoder.chroma_format);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
689 mpeg2dec->yuv_buf[2][0] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
690 (uint8_t *) mpeg2_malloc (y_size, MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
691 mpeg2dec->yuv_buf[2][1] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
692 (uint8_t *) mpeg2_malloc (uv_size, MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
693 mpeg2dec->yuv_buf[2][2] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
694 (uint8_t *) mpeg2_malloc (uv_size, MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
695 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
696 if (!mpeg2dec->custom_fbuf) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
697 while (mpeg2dec->alloc_index < 3) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
698 mpeg2_fbuf_t * fbuf;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
699
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
700 fbuf = &mpeg2dec->fbuf_alloc[mpeg2dec->alloc_index++].fbuf;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
701 fbuf->id = NULL;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
702 fbuf->buf[0] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
703 (uint8_t *) mpeg2_malloc (convert_init.buf_size[0],
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
704 MPEG2_ALLOC_CONVERTED);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
705 fbuf->buf[1] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
706 (uint8_t *) mpeg2_malloc (convert_init.buf_size[1],
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
707 MPEG2_ALLOC_CONVERTED);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
708 fbuf->buf[2] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
709 (uint8_t *) mpeg2_malloc (convert_init.buf_size[2],
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
710 MPEG2_ALLOC_CONVERTED);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
711 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
712 mpeg2_set_fbuf (mpeg2dec, (decoder->coding_type == B_TYPE));
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
713 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
714 } else if (!mpeg2dec->custom_fbuf) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
715 while (mpeg2dec->alloc_index < 3) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
716 mpeg2_fbuf_t * fbuf;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
717 int y_size, uv_size;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
718
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
719 fbuf = &(mpeg2dec->fbuf_alloc[mpeg2dec->alloc_index++].fbuf);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
720 fbuf->id = NULL;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
721 y_size = decoder->stride_frame * mpeg2dec->sequence.height;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
722 uv_size = y_size >> (2 - decoder->chroma_format);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
723 fbuf->buf[0] = (uint8_t *) mpeg2_malloc (y_size,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
724 MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
725 fbuf->buf[1] = (uint8_t *) mpeg2_malloc (uv_size,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
726 MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
727 fbuf->buf[2] = (uint8_t *) mpeg2_malloc (uv_size,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
728 MPEG2_ALLOC_YUV);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
729 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
730 mpeg2_set_fbuf (mpeg2dec, (decoder->coding_type == B_TYPE));
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
731 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
732 } else {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
733 decoder->second_field = 1;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
734 mpeg2dec->picture++; /* second field picture */
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
735 *(mpeg2dec->picture) = mpeg2dec->new_picture;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
736 mpeg2dec->info.current_picture_2nd = mpeg2dec->picture;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
737 if (low_delay || decoder->coding_type == B_TYPE)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
738 mpeg2dec->info.display_picture_2nd = mpeg2dec->picture;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
739 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
740
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
741 info_user_data (mpeg2dec);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
742 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
743
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
744 static int copyright_ext (mpeg2dec_t * mpeg2dec)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
745 {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
746 return 0;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
747 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
748
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
749 static int quant_matrix_ext (mpeg2dec_t * mpeg2dec)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
750 {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
751 uint8_t * buffer = mpeg2dec->chunk_start;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
752 int i, j;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
753
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
754 for (i = 0; i < 4; i++)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
755 if (buffer[0] & (8 >> i)) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
756 for (j = 0; j < 64; j++)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
757 mpeg2dec->new_quantizer_matrix[i][mpeg2_scan_norm[j]] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
758 (buffer[j] << (i+5)) | (buffer[j+1] >> (3-i));
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
759 mpeg2dec->copy_matrix |= 1 << i;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
760 buffer += 64;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
761 }
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
762
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
763 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
764 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
765
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
766 int mpeg2_header_extension (mpeg2dec_t * mpeg2dec)
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
767 {
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
768 static int (* parser[]) (mpeg2dec_t *) = {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
769 0, sequence_ext, sequence_display_ext, quant_matrix_ext,
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
770 copyright_ext, 0, 0, picture_display_ext, picture_coding_ext
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
771 };
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
772 int ext, ext_bit;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
773
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
774 ext = mpeg2dec->chunk_start[0] >> 4;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
775 ext_bit = 1 << ext;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
776
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
777 if (!(mpeg2dec->ext_state & ext_bit))
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
778 return 0; /* ignore illegal extensions */
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
779 mpeg2dec->ext_state &= ~ext_bit;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
780 return parser[ext] (mpeg2dec);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
781 }
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
782
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
783 int mpeg2_header_user_data (mpeg2dec_t * mpeg2dec)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
784 {
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
785 mpeg2dec->user_data_len += mpeg2dec->chunk_ptr - 1 - mpeg2dec->chunk_start;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
786 mpeg2dec->chunk_start = mpeg2dec->chunk_ptr - 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
787
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
788 return 0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
789 }
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
790
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
791 static void prescale (mpeg2dec_t * mpeg2dec, int index)
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
792 {
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
793 static int non_linear_scale [] = {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
794 0, 1, 2, 3, 4, 5, 6, 7,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
795 8, 10, 12, 14, 16, 18, 20, 22,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
796 24, 28, 32, 36, 40, 44, 48, 52,
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
797 56, 64, 72, 80, 88, 96, 104, 112
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
798 };
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
799 int i, j, k;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
800 mpeg2_decoder_t * decoder = &(mpeg2dec->decoder);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
801
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
802 if (mpeg2dec->scaled[index] != mpeg2dec->q_scale_type) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
803 mpeg2dec->scaled[index] = mpeg2dec->q_scale_type;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
804 for (i = 0; i < 32; i++) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
805 k = mpeg2dec->q_scale_type ? non_linear_scale[i] : (i << 1);
13123
34df725814e8 postproc fix
henry
parents: 12935
diff changeset
806 decoder->quantizer_scales[i] = k;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
807 for (j = 0; j < 64; j++)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
808 decoder->quantizer_prescale[index][i][j] =
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
809 k * mpeg2dec->quantizer_matrix[index][j];
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
810 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
811 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
812 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
813
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
814 mpeg2_state_t mpeg2_header_slice_start (mpeg2dec_t * mpeg2dec)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
815 {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
816 mpeg2_decoder_t * decoder = &(mpeg2dec->decoder);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
817
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
818 mpeg2dec->info.user_data = NULL; mpeg2dec->info.user_data_len = 0;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
819 mpeg2dec->state = ((mpeg2dec->picture->nb_fields > 1 ||
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
820 mpeg2dec->state == STATE_PICTURE_2ND) ?
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
821 STATE_SLICE : STATE_SLICE_1ST);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
822
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
823 if (mpeg2dec->decoder.coding_type != D_TYPE) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
824 prescale (mpeg2dec, 0);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
825 if (decoder->chroma_quantizer[0] == decoder->quantizer_prescale[2])
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
826 prescale (mpeg2dec, 2);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
827 if (mpeg2dec->decoder.coding_type != I_TYPE) {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
828 prescale (mpeg2dec, 1);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
829 if (decoder->chroma_quantizer[1] == decoder->quantizer_prescale[3])
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
830 prescale (mpeg2dec, 3);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
831 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
832 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
833
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
834 if (!(mpeg2dec->nb_decode_slices))
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
835 mpeg2dec->picture->flags |= PIC_FLAG_SKIP;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
836 else if (mpeg2dec->convert_start) {
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
837 mpeg2dec->convert_start (decoder->convert_id, mpeg2dec->fbuf[0],
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
838 mpeg2dec->picture, mpeg2dec->info.gop);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
839
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
840 if (mpeg2dec->decoder.coding_type == B_TYPE)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
841 mpeg2_init_fbuf (&(mpeg2dec->decoder), mpeg2dec->yuv_buf[2],
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
842 mpeg2dec->yuv_buf[mpeg2dec->yuv_index ^ 1],
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
843 mpeg2dec->yuv_buf[mpeg2dec->yuv_index]);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
844 else {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
845 mpeg2_init_fbuf (&(mpeg2dec->decoder),
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
846 mpeg2dec->yuv_buf[mpeg2dec->yuv_index ^ 1],
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
847 mpeg2dec->yuv_buf[mpeg2dec->yuv_index],
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
848 mpeg2dec->yuv_buf[mpeg2dec->yuv_index]);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
849 if (mpeg2dec->state == STATE_SLICE)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
850 mpeg2dec->yuv_index ^= 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
851 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
852 } else {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
853 int b_type;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
854
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
855 b_type = (mpeg2dec->decoder.coding_type == B_TYPE);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
856 mpeg2_init_fbuf (&(mpeg2dec->decoder), mpeg2dec->fbuf[0]->buf,
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
857 mpeg2dec->fbuf[b_type + 1]->buf,
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
858 mpeg2dec->fbuf[b_type]->buf);
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
859 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
860 mpeg2dec->action = NULL;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
861 return (mpeg2_state_t)-1;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
862 }
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
863
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
864 static mpeg2_state_t seek_sequence (mpeg2dec_t * mpeg2dec)
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
865 {
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
866 mpeg2_reset_info (&(mpeg2dec->info));
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
867 mpeg2dec->info.sequence = NULL;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
868 mpeg2dec->info.gop = NULL;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
869 mpeg2_header_state_init (mpeg2dec);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
870 mpeg2dec->action = mpeg2_seek_header;
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
871 return mpeg2_seek_header (mpeg2dec);
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
872 }
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
873
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
874 mpeg2_state_t mpeg2_header_end (mpeg2dec_t * mpeg2dec)
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
875 {
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
876 mpeg2_picture_t * picture;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
877 int b_type;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
878
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
879 b_type = (mpeg2dec->decoder.coding_type == B_TYPE);
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
880 picture = mpeg2dec->pictures;
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
881 if ((mpeg2dec->picture >= picture + 2) ^ b_type)
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
882 picture = mpeg2dec->pictures + 2;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
883
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
884 mpeg2_reset_info (&(mpeg2dec->info));
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
885 if (!(mpeg2dec->sequence.flags & SEQ_FLAG_LOW_DELAY)) {
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
886 mpeg2dec->info.display_picture = picture;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
887 if (picture->nb_fields == 1)
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
888 mpeg2dec->info.display_picture_2nd = picture + 1;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
889 mpeg2dec->info.display_fbuf = mpeg2dec->fbuf[b_type];
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
890 if (!mpeg2dec->convert)
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
891 mpeg2dec->info.discard_fbuf = mpeg2dec->fbuf[b_type + 1];
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
892 } else if (!mpeg2dec->convert)
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
893 mpeg2dec->info.discard_fbuf = mpeg2dec->fbuf[b_type];
12932
d0a8810e155c Importing libmpeg2 from mpeg2dec-0.4.0b
henry
parents: 12617
diff changeset
894 mpeg2dec->action = seek_sequence;
9852
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
895 return STATE_END;
47984e3f54ce Importing libmpeg2 from mpeg2dec-0.3.1
arpi
parents: 3839
diff changeset
896 }