Mercurial > mplayer.hg
annotate libmpdemux/demux_ty.c @ 24500:dcb02dadd06c
Get rid of bloated ty_extension function
author | reimar |
---|---|
date | Sat, 15 Sep 2007 11:03:38 +0000 |
parents | 1e57ce7abdbd |
children | 0d9578ee65cf |
rev | line source |
---|---|
10263 | 1 /* |
2 * tivo@wingert.org, February 2003 | |
3 * | |
4 * Copyright (C) 2003 Christopher R. Wingert | |
5 * | |
6 * The license covers the portions of this file regarding TiVo additions. | |
7 * | |
24487 | 8 * Olaf Beck and Tridge (indirectly) were essential at providing |
9 * information regarding the format of the TiVo streams. | |
10263 | 10 * |
24487 | 11 * However, no code in the following subsection is directly copied from |
10263 | 12 * either author. |
13 * | |
14 * | |
15 * This program is free software; you can redistribute it and/or | |
16 * modify it under the terms of the GNU General Public License | |
17 * as published by the Free Software Foundation; either version 2 | |
18 * of the License, or (at your option) any later version. | |
19 * | |
20 * This program is distributed in the hope that it will be useful, | |
21 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
22 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
23 * GNU General Public License for more details. | |
24 * | |
25 * You should have received a copy of the GNU General Public License | |
26 * along with this program; if not, write to the Free Software | |
19614 | 27 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
10263 | 28 * |
29 */ | |
30 | |
31 | |
32 #include <stdio.h> | |
33 #include <stdlib.h> | |
34 #include <unistd.h> | |
35 #include <time.h> | |
36 #include <stdarg.h> | |
37 | |
38 #include "config.h" | |
39 #include "mp_msg.h" | |
40 #include "help_mp.h" | |
41 | |
22605
4d81dbdf46b9
Add explicit location for headers from the stream/ directory.
diego
parents:
20141
diff
changeset
|
42 #include "stream/stream.h" |
10263 | 43 #include "demuxer.h" |
44 #include "parse_es.h" | |
45 #include "stheader.h" | |
17012 | 46 #include "sub_cc.h" |
23703
9fb716ab06a3
Avoid code duplication and ugly config.h hack by using av_strlcat/av_strlcpy
reimar
parents:
23381
diff
changeset
|
47 #include "libavutil/avstring.h" |
24461
921de822048c
Fix completely broken get_ty_pts (it's an ordinary MPEG timestamp)
reimar
parents:
24460
diff
changeset
|
48 #include "libavutil/intreadwrite.h" |
10263 | 49 |
50 extern void skip_audio_frame( sh_audio_t *sh_audio ); | |
51 extern int sub_justify; | |
52 | |
53 // 2/c0: audio data | |
54 // 3/c0: audio packet header (PES header) | |
55 // 4/c0: audio data (S/A only?) | |
56 // 9/c0: audio packet header, AC-3 audio | |
57 // 2/e0: video data | |
58 // 6/e0: video packet header (PES header) | |
59 // 7/e0: video sequence header start | |
60 // 8/e0: video I-frame header start | |
61 // a/e0: video P-frame header start | |
62 // b/e0: video B-frame header start | |
63 // c/e0: video GOP header start | |
64 // e/01: closed-caption data | |
24487 | 65 // e/02: Extended data services data |
10263 | 66 |
67 | |
24446 | 68 #define TIVO_PES_FILEID 0xf5467abd |
69 #define TIVO_PART_LENGTH 0x20000000 | |
10263 | 70 |
71 #define CHUNKSIZE ( 128 * 1024 ) | |
72 #define MAX_AUDIO_BUFFER ( 16 * 1024 ) | |
73 | |
24446 | 74 #define TY_V 1 |
75 #define TY_A 2 | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
76 |
24499 | 77 typedef struct |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
78 { |
24498
7d955b1de13c
Remove another variable and reorder to avoid wasting space due to alignment
reimar
parents:
24497
diff
changeset
|
79 off_t startOffset; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
80 off_t fileSize; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
81 int chunks; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
82 } tmf_fileParts; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
83 |
24446 | 84 #define MAX_TMF_PARTS 16 |
10263 | 85 |
24499 | 86 typedef struct |
10263 | 87 { |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
88 int whichChunk; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
89 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
90 unsigned char lastAudio[ MAX_AUDIO_BUFFER ]; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
91 int lastAudioEnd; |
10263 | 92 |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
93 int tivoType; // 1 = SA, 2 = DTiVo |
10263 | 94 |
24463 | 95 int64_t lastAudioPTS; |
96 int64_t lastVideoPTS; | |
10263 | 97 |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
98 off_t size; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
99 int readHeader; |
24487 | 100 |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
101 int tmf; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
102 tmf_fileParts tmfparts[ MAX_TMF_PARTS ]; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
103 int tmf_totalparts; |
10263 | 104 } TiVoInfo; |
105 | |
106 off_t vstream_streamsize( ); | |
107 void ty_ClearOSD( int start ); | |
108 | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
109 // =========================================================================== |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
110 #define TMF_SIG "showing.xml" |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
111 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
112 // =========================================================================== |
24443 | 113 static int ty_tmf_filetoparts( demuxer_t *demux, TiVoInfo *tivo ) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
114 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
115 off_t offset; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
116 off_t totalsize; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
117 int parts = 0; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
118 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
119 offset = 0; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
120 totalsize = demux->stream->end_pos; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
121 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
122 mp_msg( MSGT_DEMUX, MSGL_DBG3, "Dumping tar contents\n" ); |
24456 | 123 while (1) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
124 { |
24488 | 125 char header[ 512 ]; |
126 char *name; | |
24500 | 127 char *extension; |
24488 | 128 char *sizestr; |
129 int size; | |
130 off_t skip; | |
131 int isty; | |
24457 | 132 if (!stream_seek(demux->stream, offset)) |
24487 | 133 { |
17366 | 134 mp_msg( MSGT_DEMUX, MSGL_DBG3, "Seek bad %"PRId64"\n", (int64_t)offset ); |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
135 break; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
136 } |
24457 | 137 if (stream_read(demux->stream, header, 512) < 512) |
24487 | 138 { |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
139 mp_msg( MSGT_DEMUX, MSGL_DBG3, "Read bad\n" ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
140 break; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
141 } |
24448
044d3ec97bf7
Avoid strlcpy, tar headers already have space to ensure 0-termination
reimar
parents:
24447
diff
changeset
|
142 name = header; |
044d3ec97bf7
Avoid strlcpy, tar headers already have space to ensure 0-termination
reimar
parents:
24447
diff
changeset
|
143 name[99] = 0; |
044d3ec97bf7
Avoid strlcpy, tar headers already have space to ensure 0-termination
reimar
parents:
24447
diff
changeset
|
144 sizestr = &header[124]; |
24449 | 145 sizestr[11] = 0; |
24442
9fc610537539
Use strtol instead of horribly suboptimal ty_octaltodecimal
reimar
parents:
24423
diff
changeset
|
146 size = strtol(sizestr, NULL, 8); |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
147 |
24450 | 148 // size rounded up to blocks + header size |
149 skip = 512 + ((size + 511) & ~511); | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
150 |
24446 | 151 if ( offset + skip > totalsize ) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
152 size = totalsize - offset; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
153 |
24500 | 154 extension = strrchr(name, '.'); |
155 isty = extension && strcmp(extension, ".ty") == 0; | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
156 |
24487 | 157 mp_msg( MSGT_DEMUX, MSGL_DBG3, "name %-20.20s size %-12.12s %d %d\n", |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
158 name, sizestr, size, isty ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
159 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
160 if ( isty ) |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
161 { |
24455 | 162 if ( parts >= MAX_TMF_PARTS ) { |
163 mp_msg( MSGT_DEMUX, MSGL_ERR, "ty:tmf too big\n" ); | |
164 break; | |
165 } | |
24447
c6253f3b5f47
Do not ignore last chunk in .tmf files, it will cause part of the file to be
reimar
parents:
24446
diff
changeset
|
166 tivo->tmfparts[ parts ].fileSize = size; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
167 tivo->tmfparts[ parts ].startOffset = offset + 512; |
24450 | 168 tivo->tmfparts[ parts ].chunks = size / CHUNKSIZE; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
169 mp_msg |
24487 | 170 ( |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
171 MSGT_DEMUX, MSGL_DBG3, |
24498
7d955b1de13c
Remove another variable and reorder to avoid wasting space due to alignment
reimar
parents:
24497
diff
changeset
|
172 "tmf_filetoparts(): index %d, chunks %d\n", |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
173 parts, |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
174 tivo->tmfparts[ parts ].chunks |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
175 ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
176 mp_msg |
24487 | 177 ( |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
178 MSGT_DEMUX, MSGL_DBG3, |
16750
0a31740dd5e6
Use PRI?64 defines as format strings for 64 bit variables.
reimar
parents:
16346
diff
changeset
|
179 "tmf_filetoparts(): size %"PRId64"\n", |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
180 tivo->tmfparts[ parts ].fileSize |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
181 ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
182 mp_msg |
24487 | 183 ( |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
184 MSGT_DEMUX, MSGL_DBG3, |
16750
0a31740dd5e6
Use PRI?64 defines as format strings for 64 bit variables.
reimar
parents:
16346
diff
changeset
|
185 "tmf_filetoparts(): startOffset %"PRId64"\n", |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
186 tivo->tmfparts[ parts ].startOffset |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
187 ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
188 parts++; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
189 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
190 |
24485 | 191 offset += skip; |
192 if (offset >= totalsize) | |
24456 | 193 break; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
194 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
195 tivo->tmf_totalparts = parts; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
196 mp_msg( MSGT_DEMUX, MSGL_DBG3, |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
197 "tmf_filetoparts(): No More Part Files %d\n", parts ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
198 |
24446 | 199 return 1; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
200 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
201 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
202 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
203 // =========================================================================== |
24451 | 204 static off_t tmf_filetooffset(TiVoInfo *tivo, int chunk) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
205 { |
24451 | 206 int i; |
207 for (i = 0; i < tivo->tmf_totalparts; i++) { | |
208 if (chunk < tivo->tmfparts[i].chunks) | |
209 return tivo->tmfparts[i].startOffset + chunk * CHUNKSIZE; | |
210 chunk -= tivo->tmfparts[i].chunks; | |
211 } | |
212 return -1; | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
213 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
214 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
215 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
216 // =========================================================================== |
24487 | 217 static int tmf_load_chunk( demuxer_t *demux, TiVoInfo *tivo, |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
218 unsigned char *buff, int size, int readChunk ) |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
219 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
220 off_t fileoffset; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
221 int count; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
222 |
24487 | 223 mp_msg( MSGT_DEMUX, MSGL_DBG3, "\ntmf_load_chunk() begin %d\n", |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
224 readChunk ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
225 |
24452 | 226 fileoffset = tmf_filetooffset(tivo, readChunk); |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
227 |
24452 | 228 if (fileoffset == -1) { |
229 mp_msg(MSGT_DEMUX, MSGL_ERR, "Read past EOF()\n"); | |
230 return 0; | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
231 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
232 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
233 if ( stream_seek( demux->stream, fileoffset ) != 1 ) |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
234 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
235 mp_msg( MSGT_DEMUX, MSGL_ERR, "Read past EOF()\n" ); |
24464 | 236 return 0; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
237 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
238 count = stream_read( demux->stream, buff, size ); |
24487 | 239 demux->filepos = stream_tell( demux->stream ); |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
240 |
24487 | 241 mp_msg( MSGT_DEMUX, MSGL_DBG3, "tmf_load_chunk() count %x\n", |
242 count ); | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
243 |
24487 | 244 mp_msg( MSGT_DEMUX, MSGL_DBG3, |
245 "tmf_load_chunk() bytes %x %x %x %x %x %x %x %x\n", | |
246 buff[ 0 ], buff[ 1 ], buff[ 2 ], buff[ 3 ], | |
247 buff[ 4 ], buff[ 5 ], buff[ 6 ], buff[ 7 ] ); | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
248 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
249 mp_msg( MSGT_DEMUX, MSGL_DBG3, "tmf_load_chunk() end\n" ); |
24487 | 250 |
24446 | 251 return count; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
252 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
253 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
254 // =========================================================================== |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
255 |
10263 | 256 // DTiVo MPEG 336, 480, 576, 768 |
257 // SA TiVo 864 | |
258 // DTiVo AC-3 1550 | |
259 // | |
24446 | 260 #define SERIES1_PTS_LENGTH 11 |
261 #define SERIES1_PTS_OFFSET 6 | |
262 #define SERIES2_PTS_LENGTH 16 | |
263 #define SERIES2_PTS_OFFSET 9 | |
264 #define AC3_PTS_LENGTH 16 | |
265 #define AC3_PTS_OFFSET 9 | |
10263 | 266 |
267 static int IsValidAudioPacket( int size, int *ptsOffset, int *ptsLen ) | |
268 { | |
269 *ptsOffset = 0; | |
270 *ptsLen = 0; | |
271 | |
272 // AC-3 | |
24446 | 273 if ( size == 1550 || size == 1552 ) |
10263 | 274 { |
275 *ptsOffset = AC3_PTS_OFFSET; | |
276 *ptsLen = AC3_PTS_LENGTH; | |
24446 | 277 return 1; |
10263 | 278 } |
279 | |
280 // MPEG | |
24471
516c6a2277b1
Greatly simplify IsValidAudioPacket, though this might break something
reimar
parents:
24470
diff
changeset
|
281 if ( (size & 15) == (SERIES1_PTS_LENGTH & 15) ) |
10263 | 282 { |
283 *ptsOffset = SERIES1_PTS_OFFSET; | |
284 *ptsLen = SERIES1_PTS_LENGTH; | |
24470 | 285 return 1; |
10263 | 286 } |
24471
516c6a2277b1
Greatly simplify IsValidAudioPacket, though this might break something
reimar
parents:
24470
diff
changeset
|
287 if ( (size & 15) == (SERIES2_PTS_LENGTH & 15) ) |
10263 | 288 { |
289 *ptsOffset = SERIES2_PTS_OFFSET; | |
290 *ptsLen = SERIES2_PTS_LENGTH; | |
24470 | 291 return 1; |
10263 | 292 } |
24487 | 293 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Tossing Audio Packet Size %d\n", |
10263 | 294 size ); |
24446 | 295 return 0; |
10263 | 296 } |
297 | |
298 | |
24463 | 299 static int64_t get_ty_pts( unsigned char *buf ) |
10263 | 300 { |
24461
921de822048c
Fix completely broken get_ty_pts (it's an ordinary MPEG timestamp)
reimar
parents:
24460
diff
changeset
|
301 int a = buf[0] & 0xe; |
921de822048c
Fix completely broken get_ty_pts (it's an ordinary MPEG timestamp)
reimar
parents:
24460
diff
changeset
|
302 int b = AV_RB16(buf + 1); |
921de822048c
Fix completely broken get_ty_pts (it's an ordinary MPEG timestamp)
reimar
parents:
24460
diff
changeset
|
303 int c = AV_RB16(buf + 3); |
10263 | 304 |
24461
921de822048c
Fix completely broken get_ty_pts (it's an ordinary MPEG timestamp)
reimar
parents:
24460
diff
changeset
|
305 if (!(1 & a & b & c)) // invalid MPEG timestamp |
24463 | 306 return MP_NOPTS_VALUE; |
24461
921de822048c
Fix completely broken get_ty_pts (it's an ordinary MPEG timestamp)
reimar
parents:
24460
diff
changeset
|
307 a >>= 1; b >>= 1; c >>= 1; |
24463 | 308 return (((uint64_t)a) << 30) | (b << 15) | c; |
10263 | 309 } |
310 | |
24487 | 311 static void demux_ty_AddToAudioBuffer( TiVoInfo *tivo, unsigned char *buffer, |
10263 | 312 int size ) |
313 { | |
24446 | 314 if ( tivo->lastAudioEnd + size < MAX_AUDIO_BUFFER ) |
10263 | 315 { |
24487 | 316 memcpy( &tivo->lastAudio[ tivo->lastAudioEnd ], |
10263 | 317 buffer, size ); |
318 tivo->lastAudioEnd += size; | |
319 } | |
320 else | |
321 mp_msg( MSGT_DEMUX, MSGL_ERR, | |
322 "ty:WARNING - Would have blown my audio buffer\n" ); | |
323 } | |
324 | |
24496
42693ad6dd30
Remove now useless parameters from demux_ty_CopyToDemuxPacket
reimar
parents:
24495
diff
changeset
|
325 static void demux_ty_CopyToDemuxPacket( demux_stream_t *ds, |
24497
713ad2d3878d
PTS should be passed as int64_t to demux_ty_CopyToDemuxPacket
reimar
parents:
24496
diff
changeset
|
326 unsigned char *buffer, int size, off_t pos, int64_t pts ) |
10263 | 327 { |
24482 | 328 demux_packet_t *dp = new_demux_packet( size ); |
10263 | 329 memcpy( dp->buffer, buffer, size ); |
24463 | 330 if (pts != MP_NOPTS_VALUE) |
331 dp->pts = pts / 90000.0; | |
10263 | 332 dp->pos = pos; |
333 dp->flags = 0; | |
334 ds_add_packet( ds, dp ); | |
335 } | |
336 | |
24484 | 337 static int demux_ty_FindESHeader( uint8_t nal, |
24478 | 338 unsigned char *buffer, int bufferSize ) |
10263 | 339 { |
24484 | 340 uint32_t search = 0x00000100 | nal; |
24483 | 341 uint32_t found = -1; |
342 uint8_t *p = buffer; | |
343 uint8_t *end = p + bufferSize; | |
344 while (p < end) { | |
345 found <<= 8; | |
346 found |= *p++; | |
347 if (found == search) | |
348 return p - buffer - 4; | |
10263 | 349 } |
24446 | 350 return -1; |
10263 | 351 } |
352 | |
24487 | 353 static void demux_ty_FindESPacket( uint8_t nal, |
10263 | 354 unsigned char *buffer, int bufferSize, int *esOffset1, int *esOffset2 ) |
355 { | |
24484 | 356 *esOffset1 = demux_ty_FindESHeader(nal, buffer, bufferSize); |
24480
a365d70938b3
Simplify demux_ty_FindESPacket by reusing demux_ty_FindESHeader
reimar
parents:
24479
diff
changeset
|
357 if (*esOffset1 == -1) { |
a365d70938b3
Simplify demux_ty_FindESPacket by reusing demux_ty_FindESHeader
reimar
parents:
24479
diff
changeset
|
358 *esOffset2 = -1; |
a365d70938b3
Simplify demux_ty_FindESPacket by reusing demux_ty_FindESHeader
reimar
parents:
24479
diff
changeset
|
359 return; |
a365d70938b3
Simplify demux_ty_FindESPacket by reusing demux_ty_FindESHeader
reimar
parents:
24479
diff
changeset
|
360 } |
a365d70938b3
Simplify demux_ty_FindESPacket by reusing demux_ty_FindESHeader
reimar
parents:
24479
diff
changeset
|
361 buffer += *esOffset1 + 1; |
a365d70938b3
Simplify demux_ty_FindESPacket by reusing demux_ty_FindESHeader
reimar
parents:
24479
diff
changeset
|
362 bufferSize -= *esOffset1 + 1; |
24484 | 363 *esOffset2 = demux_ty_FindESHeader(nal, buffer, bufferSize); |
24480
a365d70938b3
Simplify demux_ty_FindESPacket by reusing demux_ty_FindESHeader
reimar
parents:
24479
diff
changeset
|
364 if (*esOffset2 != -1) |
a365d70938b3
Simplify demux_ty_FindESPacket by reusing demux_ty_FindESHeader
reimar
parents:
24479
diff
changeset
|
365 *esOffset2 += *esOffset1 + 1; |
10263 | 366 } |
367 | |
24484 | 368 #define VIDEO_NAL 0xe0 |
369 #define AUDIO_NAL 0xc0 | |
370 #define AC3_NAL 0xbd | |
10263 | 371 |
16175 | 372 static int demux_ty_fill_buffer( demuxer_t *demux, demux_stream_t *dsds ) |
10263 | 373 { |
374 int invalidType = 0; | |
375 int errorHeader = 0; | |
376 int recordsDecoded = 0; | |
377 | |
378 unsigned char chunk[ CHUNKSIZE ]; | |
379 int readSize; | |
380 | |
381 int numberRecs; | |
382 unsigned char *recPtr; | |
383 int offset; | |
384 | |
385 int counter; | |
386 | |
387 int aid; | |
24487 | 388 |
24469
afbab72dbf2c
Do not misuse a_streams for private info, demuxer->priv is for that!
reimar
parents:
24468
diff
changeset
|
389 TiVoInfo *tivo = demux->priv; |
10263 | 390 |
391 if ( demux->stream->type == STREAMTYPE_DVD ) | |
24487 | 392 return 0; |
10263 | 393 |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
394 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:ty processing\n" ); |
10263 | 395 |
396 if( demux->stream->eof ) return 0; | |
24487 | 397 |
10263 | 398 // ====================================================================== |
11000 | 399 // If we haven't figured out the size of the stream, let's do so |
10263 | 400 // ====================================================================== |
401 #ifdef STREAMTYPE_STREAM_TY | |
402 if ( demux->stream->type == STREAMTYPE_STREAM_TY ) | |
403 { | |
404 // The vstream code figures out the exact size of the stream | |
405 demux->movi_start = 0; | |
406 demux->movi_end = vstream_streamsize(); | |
407 tivo->size = vstream_streamsize(); | |
408 } | |
409 else | |
410 #endif | |
411 { | |
412 // If its a local file, try to find the Part Headers, so we can | |
413 // calculate the ACTUAL stream size | |
414 // If we can't find it, go off with the file size and hope the | |
415 // extract program did the "right thing" | |
416 if ( tivo->readHeader == 0 ) | |
417 { | |
24477
8c9d86adb28e
Move variable declarations into the block where they are used
reimar
parents:
24476
diff
changeset
|
418 off_t filePos; |
10263 | 419 tivo->readHeader = 1; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
420 tivo->size = demux->stream->end_pos; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
421 |
10263 | 422 filePos = demux->filepos; |
423 stream_seek( demux->stream, 0 ); | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
424 |
10263 | 425 readSize = stream_read( demux->stream, chunk, CHUNKSIZE ); |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
426 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
427 if ( memcmp( chunk, TMF_SIG, sizeof( TMF_SIG ) ) == 0 ) |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
428 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
429 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Detected a tmf\n" ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
430 tivo->tmf = 1; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
431 ty_tmf_filetoparts( demux, tivo ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
432 readSize = tmf_load_chunk( demux, tivo, chunk, CHUNKSIZE, 0 ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
433 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
434 |
24467 | 435 if ( readSize == CHUNKSIZE && AV_RB32(chunk) == TIVO_PES_FILEID ) |
10263 | 436 { |
437 off_t numberParts; | |
438 | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
439 readSize = 0; |
24487 | 440 |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
441 if ( tivo->tmf != 1 ) |
10263 | 442 { |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
443 off_t offset; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
444 |
10263 | 445 numberParts = demux->stream->end_pos / TIVO_PART_LENGTH; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
446 offset = numberParts * TIVO_PART_LENGTH; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
447 |
17366 | 448 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:ty/ty+Number Parts %"PRId64"\n", |
449 (int64_t)numberParts ); | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
450 |
24446 | 451 if ( offset + CHUNKSIZE < demux->stream->end_pos ) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
452 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
453 stream_seek( demux->stream, offset ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
454 readSize = stream_read( demux->stream, chunk, CHUNKSIZE ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
455 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
456 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
457 else |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
458 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
459 numberParts = tivo->tmf_totalparts; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
460 offset = numberParts * TIVO_PART_LENGTH; |
24487 | 461 readSize = tmf_load_chunk( demux, tivo, chunk, CHUNKSIZE, |
462 numberParts * ( TIVO_PART_LENGTH - CHUNKSIZE ) / | |
24446 | 463 CHUNKSIZE ); |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
464 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
465 |
24467 | 466 if ( readSize == CHUNKSIZE && AV_RB32(chunk) == TIVO_PES_FILEID ) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
467 { |
24477
8c9d86adb28e
Move variable declarations into the block where they are used
reimar
parents:
24476
diff
changeset
|
468 int size = AV_RB24(chunk + 12); |
10263 | 469 size -= 4; |
470 size *= CHUNKSIZE; | |
471 tivo->size = numberParts * TIVO_PART_LENGTH; | |
472 tivo->size += size; | |
24487 | 473 mp_msg( MSGT_DEMUX, MSGL_DBG3, |
16750
0a31740dd5e6
Use PRI?64 defines as format strings for 64 bit variables.
reimar
parents:
16346
diff
changeset
|
474 "ty:Header Calc Stream Size %"PRId64"\n", tivo->size ); |
10263 | 475 } |
476 } | |
477 if ( tivo->size > demux->stream->end_pos ) | |
478 tivo->size = demux->stream->end_pos; | |
479 | |
24487 | 480 if ( demux->stream->start_pos > 0 ) |
481 filePos = demux->stream->start_pos; | |
10263 | 482 stream_seek( demux->stream, filePos ); |
24487 | 483 demux->filepos = stream_tell( demux->stream ); |
24446 | 484 tivo->whichChunk = filePos / CHUNKSIZE; |
10263 | 485 } |
486 demux->movi_start = 0; | |
487 demux->movi_end = tivo->size; | |
488 } | |
489 | |
490 // ====================================================================== | |
491 // Give a clue as to where we are in the stream | |
492 // ====================================================================== | |
493 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
17366 | 494 "ty:ty header size %"PRIx64"\n", (int64_t)tivo->size ); |
10263 | 495 mp_msg( MSGT_DEMUX, MSGL_DBG3, |
17366 | 496 "ty:ty which Chunk %d\n", tivo->whichChunk ); |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
497 mp_msg( MSGT_DEMUX, MSGL_DBG3, |
17366 | 498 "ty:file end_pos %"PRIx64"\n", (int64_t)demux->stream->end_pos ); |
10263 | 499 mp_msg( MSGT_DEMUX, MSGL_DBG3, |
17366 | 500 "\nty:wanted current offset %"PRIx64"\n", (int64_t)stream_tell( demux->stream ) ); |
10263 | 501 |
24464 | 502 if ( tivo->size > 0 && stream_tell( demux->stream ) > tivo->size ) |
10263 | 503 { |
504 demux->stream->eof = 1; | |
24464 | 505 return 0; |
10263 | 506 } |
507 | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
508 if ( tivo->tmf != 1 ) |
10263 | 509 { |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
510 // Make sure we are on a 128k boundary |
24446 | 511 if ( demux->filepos % CHUNKSIZE != 0 ) |
10263 | 512 { |
24477
8c9d86adb28e
Move variable declarations into the block where they are used
reimar
parents:
24476
diff
changeset
|
513 int whichChunk = demux->filepos / CHUNKSIZE; |
24446 | 514 if ( demux->filepos % CHUNKSIZE > CHUNKSIZE / 2 ) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
515 whichChunk++; |
24446 | 516 stream_seek( demux->stream, whichChunk * CHUNKSIZE ); |
10263 | 517 } |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
518 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
519 demux->filepos = stream_tell( demux->stream ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
520 tivo->whichChunk = demux->filepos / CHUNKSIZE; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
521 readSize = stream_read( demux->stream, chunk, CHUNKSIZE ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
522 if ( readSize != CHUNKSIZE ) |
24464 | 523 return 0; |
10263 | 524 } |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
525 else |
10263 | 526 { |
24487 | 527 readSize = tmf_load_chunk( demux, tivo, chunk, CHUNKSIZE, |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
528 tivo->whichChunk ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
529 if ( readSize != CHUNKSIZE ) |
24446 | 530 return 0; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
531 tivo->whichChunk++; |
10263 | 532 } |
533 | |
534 // We found a part header, skip it | |
24467 | 535 if( AV_RB32(chunk) == TIVO_PES_FILEID ) |
10263 | 536 { |
537 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Skipping PART Header\n" ); | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
538 if ( tivo->tmf != 1 ) |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
539 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
540 demux->filepos = stream_tell( demux->stream ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
541 readSize = stream_read( demux->stream, chunk, CHUNKSIZE ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
542 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
543 else |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
544 { |
24487 | 545 readSize = tmf_load_chunk( demux, tivo, chunk, CHUNKSIZE, |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
546 tivo->whichChunk ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
547 tivo->whichChunk++; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
548 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
549 |
10263 | 550 if ( readSize != CHUNKSIZE ) |
24446 | 551 return 0; |
24487 | 552 } |
10263 | 553 mp_msg( MSGT_DEMUX, MSGL_DBG3, |
24487 | 554 "\nty:actual current offset %"PRIx64"\n", stream_tell( demux->stream ) - |
555 CHUNKSIZE ); | |
10263 | 556 |
557 | |
12860 | 558 // Let's make a Video Demux Stream for MPlayer |
10263 | 559 aid = 0x0; |
560 if( !demux->v_streams[ aid ] ) new_sh_video( demux, aid ); | |
561 if( demux->video->id == -1 ) demux->video->id = aid; | |
562 if( demux->video->id == aid ) | |
563 { | |
24477
8c9d86adb28e
Move variable declarations into the block where they are used
reimar
parents:
24476
diff
changeset
|
564 demux_stream_t *ds = demux->video; |
10263 | 565 if( !ds->sh ) ds->sh = demux->v_streams[ aid ]; |
566 } | |
567 | |
568 // ====================================================================== | |
569 // Finally, we get to actually parse the chunk | |
570 // ====================================================================== | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
571 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:ty parsing a chunk\n" ); |
10263 | 572 numberRecs = chunk[ 0 ]; |
573 recPtr = &chunk[ 4 ]; | |
24446 | 574 offset = numberRecs * 16 + 4; |
10263 | 575 for ( counter = 0 ; counter < numberRecs ; counter++ ) |
576 { | |
24477
8c9d86adb28e
Move variable declarations into the block where they are used
reimar
parents:
24476
diff
changeset
|
577 int size = AV_RB24(recPtr) >> 4; |
8c9d86adb28e
Move variable declarations into the block where they are used
reimar
parents:
24476
diff
changeset
|
578 int type = recPtr[ 3 ]; |
8c9d86adb28e
Move variable declarations into the block where they are used
reimar
parents:
24476
diff
changeset
|
579 int nybbleType = recPtr[ 2 ] & 0x0f; |
10263 | 580 recordsDecoded++; |
581 | |
582 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
583 "ty:Record Type %x/%x %d\n", nybbleType, type, size ); | |
584 | |
585 // ================================================================ | |
586 // Video Parsing | |
587 // ================================================================ | |
588 if ( type == 0xe0 ) | |
589 { | |
24446 | 590 if ( size > 0 && size + offset <= CHUNKSIZE ) |
10263 | 591 { |
24487 | 592 int esOffset1 = demux_ty_FindESHeader( VIDEO_NAL, &chunk[ offset ], |
24478 | 593 size); |
10263 | 594 if ( esOffset1 != -1 ) |
24487 | 595 tivo->lastVideoPTS = get_ty_pts( |
10263 | 596 &chunk[ offset + esOffset1 + 9 ] ); |
597 | |
598 // Do NOT Pass the PES Header onto the MPEG2 Decode | |
599 if( nybbleType != 0x06 ) | |
24496
42693ad6dd30
Remove now useless parameters from demux_ty_CopyToDemuxPacket
reimar
parents:
24495
diff
changeset
|
600 demux_ty_CopyToDemuxPacket( demux->video, |
24487 | 601 &chunk[ offset ], size, demux->filepos + offset, |
602 tivo->lastVideoPTS ); | |
10263 | 603 offset += size; |
604 } | |
24487 | 605 else |
606 errorHeader++; | |
10263 | 607 } |
608 // ================================================================ | |
609 // Audio Parsing | |
610 // ================================================================ | |
24487 | 611 else if ( type == 0xc0 ) |
10263 | 612 { |
24446 | 613 if ( size > 0 && size + offset <= CHUNKSIZE ) |
10263 | 614 { |
615 if( demux->audio->id == -1 ) | |
616 { | |
617 if ( nybbleType == 0x02 ) | |
618 continue; // DTiVo inconclusive, wait for more | |
619 else if ( nybbleType == 0x09 ) | |
620 { | |
621 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Setting AC-3 Audio\n" ); | |
622 aid = 0x80; // AC-3 | |
623 } | |
624 else | |
625 { | |
626 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Setting MPEG Audio\n" ); | |
627 aid = 0x0; // MPEG Audio | |
628 } | |
629 | |
630 demux->audio->id = aid; | |
631 if( !demux->a_streams[ aid ] ) new_sh_audio( demux, aid ); | |
632 if( demux->audio->id == aid ) | |
633 { | |
24477
8c9d86adb28e
Move variable declarations into the block where they are used
reimar
parents:
24476
diff
changeset
|
634 demux_stream_t *ds = demux->audio; |
15580 | 635 if( !ds->sh ) { |
636 sh_audio_t* sh_a; | |
637 ds->sh = demux->a_streams[ aid ]; | |
638 sh_a = (sh_audio_t*)ds->sh; | |
639 switch(aid & 0xE0){ // 1110 0000 b (high 3 bit: type low 5: id) | |
640 case 0x00: sh_a->format=0x50;break; // mpeg | |
641 case 0xA0: sh_a->format=0x10001;break; // dvd pcm | |
642 case 0x80: if((aid & 0xF8) == 0x88) sh_a->format=0x2001;//dts | |
643 else sh_a->format=0x2000;break; // ac3 | |
644 } | |
645 } | |
10263 | 646 } |
647 } | |
648 | |
649 aid = demux->audio->id; | |
650 | |
651 | |
652 // SA DTiVo Audio Data, no PES | |
653 // ================================================ | |
24476 | 654 if ( nybbleType == 0x02 || nybbleType == 0x04 ) |
10263 | 655 { |
24476 | 656 if ( nybbleType == 0x02 && tivo->tivoType == 2 ) |
10263 | 657 demux_ty_AddToAudioBuffer( tivo, &chunk[ offset ], size ); |
658 else | |
659 { | |
660 | |
661 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
662 "ty:Adding Audio Packet Size %d\n", size ); | |
24496
42693ad6dd30
Remove now useless parameters from demux_ty_CopyToDemuxPacket
reimar
parents:
24495
diff
changeset
|
663 demux_ty_CopyToDemuxPacket( demux->audio, |
24487 | 664 &chunk[ offset ], size, ( demux->filepos + offset ), |
665 tivo->lastAudioPTS ); | |
10263 | 666 } |
667 } | |
668 | |
24475 | 669 // 3 - MPEG Audio with PES Header, either SA or DTiVo |
670 // 9 - DTiVo AC3 Audio Data with PES Header | |
10263 | 671 // ================================================ |
24475 | 672 if ( nybbleType == 0x03 || nybbleType == 0x09 ) |
10263 | 673 { |
24477
8c9d86adb28e
Move variable declarations into the block where they are used
reimar
parents:
24476
diff
changeset
|
674 int esOffset1, esOffset2; |
24475 | 675 if ( nybbleType == 0x03 ) |
24487 | 676 esOffset1 = demux_ty_FindESHeader( AUDIO_NAL, &chunk[ offset ], |
24478 | 677 size); |
10263 | 678 |
679 // SA PES Header, No Audio Data | |
680 // ================================================ | |
24475 | 681 if ( nybbleType == 0x03 && esOffset1 == 0 && size == 16 ) |
10263 | 682 { |
683 tivo->tivoType = 1; | |
24487 | 684 tivo->lastAudioPTS = get_ty_pts( &chunk[ offset + |
10263 | 685 SERIES2_PTS_OFFSET ] ); |
686 } | |
687 else | |
688 // DTiVo Audio with PES Header | |
689 // ================================================ | |
690 { | |
691 tivo->tivoType = 2; | |
692 | |
693 demux_ty_AddToAudioBuffer( tivo, &chunk[ offset ], size ); | |
24484 | 694 demux_ty_FindESPacket( nybbleType == 9 ? AC3_NAL : AUDIO_NAL, |
10263 | 695 tivo->lastAudio, tivo->lastAudioEnd, &esOffset1, |
696 &esOffset2 ); | |
697 | |
24446 | 698 if ( esOffset1 != -1 && esOffset2 != -1 ) |
10263 | 699 { |
700 int packetSize = esOffset2 - esOffset1; | |
701 int headerSize; | |
702 int ptsOffset; | |
703 | |
24487 | 704 if ( IsValidAudioPacket( packetSize, &ptsOffset, |
10263 | 705 &headerSize ) ) |
706 { | |
707 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
24487 | 708 "ty:Adding DTiVo Audio Packet Size %d\n", |
10263 | 709 packetSize ); |
710 | |
24487 | 711 tivo->lastAudioPTS = get_ty_pts( |
10263 | 712 &tivo->lastAudio[ esOffset1 + ptsOffset ] ); |
713 | |
24475 | 714 if (nybbleType == 9) headerSize = 0; |
10263 | 715 demux_ty_CopyToDemuxPacket |
24487 | 716 ( |
717 demux->audio, | |
24486 | 718 &tivo->lastAudio[ esOffset1 + headerSize ], |
719 packetSize - headerSize, | |
720 demux->filepos + offset, | |
24487 | 721 tivo->lastAudioPTS |
10263 | 722 ); |
723 | |
724 } | |
725 | |
726 // Collapse the Audio Buffer | |
24485 | 727 tivo->lastAudioEnd -= esOffset2; |
24487 | 728 memmove( &tivo->lastAudio[ 0 ], |
729 &tivo->lastAudio[ esOffset2 ], | |
24485 | 730 tivo->lastAudioEnd ); |
10263 | 731 } |
732 } | |
733 } | |
734 | |
735 offset += size; | |
736 } | |
24487 | 737 else |
738 errorHeader++; | |
739 } | |
10263 | 740 // ================================================================ |
24474 | 741 // 1 = Closed Caption |
742 // 2 = Extended Data Services | |
10263 | 743 // ================================================================ |
24487 | 744 else if ( type == 0x01 || type == 0x02 ) |
745 { | |
24474 | 746 unsigned char lastXDS[ 16 ]; |
24487 | 747 int b = AV_RB24(recPtr) >> 4; |
748 b &= 0x7f7f; | |
10263 | 749 |
24474 | 750 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:%s %04x\n", type == 1 ? "CC" : "XDS", b); |
10263 | 751 |
24487 | 752 lastXDS[ 0x00 ] = 0x00; |
753 lastXDS[ 0x01 ] = 0x00; | |
754 lastXDS[ 0x02 ] = 0x01; | |
755 lastXDS[ 0x03 ] = 0xb2; | |
756 lastXDS[ 0x04 ] = 'T'; | |
757 lastXDS[ 0x05 ] = 'Y'; | |
758 lastXDS[ 0x06 ] = type; | |
759 lastXDS[ 0x07 ] = b >> 8; | |
760 lastXDS[ 0x08 ] = b; | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
761 if ( subcc_enabled ) |
24496
42693ad6dd30
Remove now useless parameters from demux_ty_CopyToDemuxPacket
reimar
parents:
24495
diff
changeset
|
762 demux_ty_CopyToDemuxPacket( demux->video, lastXDS, 0x09, |
24487 | 763 demux->filepos + offset, tivo->lastVideoPTS ); |
764 } | |
10263 | 765 // ================================================================ |
766 // Unknown | |
767 // ================================================================ | |
24487 | 768 else |
769 { | |
24446 | 770 if ( size > 0 && size + offset <= CHUNKSIZE ) |
10263 | 771 offset += size; |
24489
97eba82233f5
live recordings can contain 0-size type 0 chunks, ignore them instead
reimar
parents:
24488
diff
changeset
|
772 if (type != 3 && type != 5 && (type != 0 || size > 0)) { |
10263 | 773 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Invalid Type %x\n", type ); |
24487 | 774 invalidType++; |
24472 | 775 } |
24487 | 776 } |
10263 | 777 recPtr += 16; |
778 } | |
779 | |
20141
bd3afd5a2e48
Fix misdetection of http://samples.mplayerhq.hu/tta/tivo_misdetect.tta as TiVo file
reimar
parents:
19614
diff
changeset
|
780 if ( errorHeader > 0 || invalidType > 0 ) |
10263 | 781 { |
24487 | 782 mp_msg( MSGT_DEMUX, MSGL_DBG3, |
20141
bd3afd5a2e48
Fix misdetection of http://samples.mplayerhq.hu/tta/tivo_misdetect.tta as TiVo file
reimar
parents:
19614
diff
changeset
|
783 "ty:Error Check - Records %d, Parsed %d, Errors %d + %d\n", |
bd3afd5a2e48
Fix misdetection of http://samples.mplayerhq.hu/tta/tivo_misdetect.tta as TiVo file
reimar
parents:
19614
diff
changeset
|
784 numberRecs, recordsDecoded, errorHeader, invalidType ); |
10263 | 785 |
786 // Invalid MPEG ES Size Check | |
24446 | 787 if ( errorHeader > numberRecs / 2 ) |
788 return 0; | |
10263 | 789 |
790 // Invalid MPEG Stream Type Check | |
24446 | 791 if ( invalidType > numberRecs / 2 ) |
792 return 0; | |
10263 | 793 } |
794 | |
795 demux->filepos = stream_tell( demux->stream ); | |
796 | |
24446 | 797 return 1; |
10263 | 798 } |
799 | |
17636 | 800 static void demux_seek_ty( demuxer_t *demuxer, float rel_seek_secs, float audio_delay, int flags ) |
10263 | 801 { |
802 demux_stream_t *d_audio = demuxer->audio; | |
803 demux_stream_t *d_video = demuxer->video; | |
804 sh_audio_t *sh_audio = d_audio->sh; | |
805 sh_video_t *sh_video = d_video->sh; | |
806 off_t newpos; | |
807 off_t res; | |
24469
afbab72dbf2c
Do not misuse a_streams for private info, demuxer->priv is for that!
reimar
parents:
24468
diff
changeset
|
808 TiVoInfo *tivo = demuxer->priv; |
10263 | 809 |
810 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Seeking to %7.1f\n", rel_seek_secs ); | |
811 | |
812 tivo->lastAudioEnd = 0; | |
24463 | 813 tivo->lastAudioPTS = MP_NOPTS_VALUE; |
814 tivo->lastVideoPTS = MP_NOPTS_VALUE; | |
10263 | 815 // |
816 //================= seek in MPEG ========================== | |
817 demuxer->filepos = stream_tell( demuxer->stream ); | |
818 | |
819 newpos = ( flags & 1 ) ? demuxer->movi_start : demuxer->filepos; | |
24487 | 820 |
10263 | 821 if( flags & 2 ) |
24487 | 822 // float seek 0..1 |
823 newpos += ( demuxer->movi_end - demuxer->movi_start ) * rel_seek_secs; | |
824 else | |
10263 | 825 { |
24487 | 826 // time seek (secs) |
10263 | 827 if( ! sh_video->i_bps ) // unspecified or VBR |
828 newpos += 2324 * 75 * rel_seek_secs; // 174.3 kbyte/sec | |
829 else | |
830 newpos += sh_video->i_bps * rel_seek_secs; | |
831 } | |
832 | |
833 if ( newpos < demuxer->movi_start ) | |
834 { | |
24487 | 835 if( demuxer->stream->type != STREAMTYPE_VCD ) demuxer->movi_start = 0; |
836 if( newpos < demuxer->movi_start ) newpos = demuxer->movi_start; | |
837 } | |
10263 | 838 |
839 res = newpos / CHUNKSIZE; | |
840 if ( rel_seek_secs >= 0 ) | |
841 newpos = ( res + 1 ) * CHUNKSIZE; | |
842 else | |
843 newpos = res * CHUNKSIZE; | |
844 | |
845 if ( newpos < 0 ) | |
846 newpos = 0; | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
847 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
848 tivo->whichChunk = newpos / CHUNKSIZE; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
849 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
850 stream_seek( demuxer->stream, newpos ); |
10263 | 851 |
852 // re-sync video: | |
853 videobuf_code_len = 0; // reset ES stream buffer | |
854 | |
24487 | 855 ds_fill_buffer( d_video ); |
856 if( sh_audio ) | |
857 ds_fill_buffer( d_audio ); | |
10263 | 858 |
24487 | 859 while( 1 ) |
10263 | 860 { |
24487 | 861 int i; |
10263 | 862 if( sh_audio && !d_audio->eof && d_video->pts && d_audio->pts ) |
863 { | |
24487 | 864 float a_pts = d_audio->pts; |
10263 | 865 a_pts += ( ds_tell_pts( d_audio ) - sh_audio->a_in_buffer_len ) / |
866 (float)sh_audio->i_bps; | |
24487 | 867 if( d_video->pts > a_pts ) |
10263 | 868 { |
24487 | 869 skip_audio_frame( sh_audio ); // sync audio |
870 continue; | |
871 } | |
10263 | 872 } |
873 i = sync_video_packet( d_video ); | |
874 if( i == 0x1B3 || i == 0x1B8 ) break; // found it! | |
875 if( !i || !skip_video_packet( d_video ) ) break; // EOF? | |
876 } | |
24487 | 877 if ( subcc_enabled ) |
878 ty_ClearOSD( 0 ); | |
10263 | 879 } |
880 | |
24443 | 881 static int demux_ty_control( demuxer_t *demuxer,int cmd, void *arg ) |
10263 | 882 { |
883 demux_stream_t *d_video = demuxer->video; | |
884 sh_video_t *sh_video = d_video->sh; | |
885 | |
24487 | 886 switch(cmd) |
10263 | 887 { |
24487 | 888 case DEMUXER_CTRL_GET_TIME_LENGTH: |
889 if(!sh_video->i_bps) // unspecified or VBR | |
890 return DEMUXER_CTRL_DONTKNOW; | |
891 *(double *)arg= | |
24446 | 892 (double)demuxer->movi_end-demuxer->movi_start/sh_video->i_bps; |
24487 | 893 return DEMUXER_CTRL_GUESS; |
10263 | 894 |
24487 | 895 case DEMUXER_CTRL_GET_PERCENT_POS: |
896 return DEMUXER_CTRL_DONTKNOW; | |
897 default: | |
898 return DEMUXER_CTRL_NOTIMPL; | |
10263 | 899 } |
900 } | |
901 | |
902 | |
17174
83a8c738be89
make demuxer seek and close functions return void, patch by Dominik Mierzejewski
wanderer
parents:
17012
diff
changeset
|
903 static void demux_close_ty( demuxer_t *demux ) |
10263 | 904 { |
24469
afbab72dbf2c
Do not misuse a_streams for private info, demuxer->priv is for that!
reimar
parents:
24468
diff
changeset
|
905 TiVoInfo *tivo = demux->priv; |
10263 | 906 |
907 free( tivo ); | |
24487 | 908 sub_justify = 0; |
10263 | 909 } |
910 | |
911 | |
16175 | 912 static int ty_check_file(demuxer_t* demuxer) |
913 { | |
24469
afbab72dbf2c
Do not misuse a_streams for private info, demuxer->priv is for that!
reimar
parents:
24468
diff
changeset
|
914 TiVoInfo *tivo = calloc(1, sizeof(TiVoInfo)); |
afbab72dbf2c
Do not misuse a_streams for private info, demuxer->priv is for that!
reimar
parents:
24468
diff
changeset
|
915 demuxer->priv = tivo; |
16175 | 916 return ds_fill_buffer(demuxer->video) ? DEMUXER_TYPE_MPEG_TY : 0; |
917 } | |
918 | |
919 | |
920 static demuxer_t* demux_open_ty(demuxer_t* demuxer) | |
921 { | |
922 sh_audio_t *sh_audio=NULL; | |
923 sh_video_t *sh_video=NULL; | |
924 | |
925 sh_video=demuxer->video->sh;sh_video->ds=demuxer->video; | |
926 | |
927 if(demuxer->audio->id!=-2) { | |
928 if(!ds_fill_buffer(demuxer->audio)){ | |
929 mp_msg(MSGT_DEMUXER,MSGL_INFO,"MPEG: " MSGTR_MissingAudioStream); | |
930 demuxer->audio->sh=NULL; | |
931 } else { | |
932 sh_audio=demuxer->audio->sh;sh_audio->ds=demuxer->audio; | |
933 } | |
934 } | |
935 | |
936 return demuxer; | |
937 } | |
938 | |
939 | |
940 demuxer_desc_t demuxer_desc_mpeg_ty = { | |
941 "TiVo demuxer", | |
942 "tivo", | |
943 "TiVo", | |
944 "Christopher R. Wingert", | |
945 "Demux streams from TiVo", | |
946 DEMUXER_TYPE_MPEG_TY, | |
947 0, // unsafe autodetect | |
948 ty_check_file, | |
949 demux_ty_fill_buffer, | |
950 demux_open_ty, | |
951 demux_close_ty, | |
952 demux_seek_ty, | |
953 demux_ty_control | |
954 }; |