Mercurial > mplayer.hg
annotate libmpdemux/demux_ty.c @ 24466:f44f604dd68a
Simplify AV_RB32 / 256 -> AV_RB24
author | reimar |
---|---|
date | Fri, 14 Sep 2007 18:26:55 +0000 |
parents | 8eb74a8f8da7 |
children | 8231358722ed |
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 * | |
8 * Olaf Beck and Tridge (indirectly) were essential at providing | |
9 * information regarding the format of the TiVo streams. | |
10 * | |
11 * However, no code in the following subsection is directly copied from | |
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 | |
65 // e/02: Extended data services data | |
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 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
77 typedef struct stmf_fileParts |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
78 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
79 int fileNo; |
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 off_t startOffset; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
83 } tmf_fileParts; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
84 |
24446 | 85 #define MAX_TMF_PARTS 16 |
10263 | 86 |
87 typedef struct sTivoInfo | |
88 { | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
89 int whichChunk; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
90 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
91 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
|
92 int lastAudioEnd; |
10263 | 93 |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
94 int tivoType; // 1 = SA, 2 = DTiVo |
10263 | 95 |
24463 | 96 int64_t firstAudioPTS; |
97 int64_t firstVideoPTS; | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
98 |
24463 | 99 int64_t lastAudioPTS; |
100 int64_t lastVideoPTS; | |
10263 | 101 |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
102 int headerOk; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
103 unsigned int pesFileId; // Should be 0xf5467abd |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
104 int streamType; // Should be 0x02 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
105 int chunkSize; // Should always be 128k |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
106 off_t size; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
107 int readHeader; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
108 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
109 int tmf; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
110 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
|
111 int tmf_totalparts; |
10263 | 112 } TiVoInfo; |
113 | |
114 off_t vstream_streamsize( ); | |
115 void ty_ClearOSD( int start ); | |
116 | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
117 // =========================================================================== |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
118 #define TMF_SIG "showing.xml" |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
119 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
120 // =========================================================================== |
24444 | 121 static int ty_extensionis(const char *name, const char *ext ) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
122 { |
24444 | 123 int delta = strlen(name) - strlen(ext); |
124 if (delta < 0) return 0; | |
125 name += delta; | |
126 return strcmp(name, ext) == 0; | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
127 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
128 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
129 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
130 // =========================================================================== |
24443 | 131 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
|
132 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
133 char header[ 512 ]; |
24448
044d3ec97bf7
Avoid strlcpy, tar headers already have space to ensure 0-termination
reimar
parents:
24447
diff
changeset
|
134 char *name; |
044d3ec97bf7
Avoid strlcpy, tar headers already have space to ensure 0-termination
reimar
parents:
24447
diff
changeset
|
135 char *sizestr; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
136 int size; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
137 off_t offset; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
138 off_t totalsize; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
139 off_t skip; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
140 int parts = 0; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
141 int isty; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
142 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
143 offset = 0; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
144 totalsize = demux->stream->end_pos; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
145 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
146 mp_msg( MSGT_DEMUX, MSGL_DBG3, "Dumping tar contents\n" ); |
24456 | 147 while (1) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
148 { |
24457 | 149 if (!stream_seek(demux->stream, offset)) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
150 { |
17366 | 151 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
|
152 break; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
153 } |
24457 | 154 if (stream_read(demux->stream, header, 512) < 512) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
155 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
156 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
|
157 break; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
158 } |
24448
044d3ec97bf7
Avoid strlcpy, tar headers already have space to ensure 0-termination
reimar
parents:
24447
diff
changeset
|
159 name = header; |
044d3ec97bf7
Avoid strlcpy, tar headers already have space to ensure 0-termination
reimar
parents:
24447
diff
changeset
|
160 name[99] = 0; |
044d3ec97bf7
Avoid strlcpy, tar headers already have space to ensure 0-termination
reimar
parents:
24447
diff
changeset
|
161 sizestr = &header[124]; |
24449 | 162 sizestr[11] = 0; |
24442
9fc610537539
Use strtol instead of horribly suboptimal ty_octaltodecimal
reimar
parents:
24423
diff
changeset
|
163 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
|
164 |
24450 | 165 // size rounded up to blocks + header size |
166 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
|
167 |
24446 | 168 if ( offset + skip > totalsize ) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
169 size = totalsize - offset; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
170 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
171 isty = ty_extensionis( name, ".ty" ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
172 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
173 mp_msg( MSGT_DEMUX, MSGL_DBG3, "name %-20.20s size %-12.12s %d %d\n", |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
174 name, sizestr, size, isty ); |
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 if ( isty ) |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
177 { |
24455 | 178 if ( parts >= MAX_TMF_PARTS ) { |
179 mp_msg( MSGT_DEMUX, MSGL_ERR, "ty:tmf too big\n" ); | |
180 break; | |
181 } | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
182 tivo->tmfparts[ parts ].fileNo = parts; |
24447
c6253f3b5f47
Do not ignore last chunk in .tmf files, it will cause part of the file to be
reimar
parents:
24446
diff
changeset
|
183 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
|
184 tivo->tmfparts[ parts ].startOffset = offset + 512; |
24450 | 185 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
|
186 mp_msg |
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 MSGT_DEMUX, MSGL_DBG3, |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
189 "tmf_filetoparts(): index %d, file %d, chunks %d\n", |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
190 parts, |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
191 tivo->tmfparts[ parts ].fileNo, |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
192 tivo->tmfparts[ parts ].chunks |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
193 ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
194 mp_msg |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
195 ( |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
196 MSGT_DEMUX, MSGL_DBG3, |
16750
0a31740dd5e6
Use PRI?64 defines as format strings for 64 bit variables.
reimar
parents:
16346
diff
changeset
|
197 "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
|
198 tivo->tmfparts[ parts ].fileSize |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
199 ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
200 mp_msg |
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 MSGT_DEMUX, MSGL_DBG3, |
16750
0a31740dd5e6
Use PRI?64 defines as format strings for 64 bit variables.
reimar
parents:
16346
diff
changeset
|
203 "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
|
204 tivo->tmfparts[ parts ].startOffset |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
205 ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
206 parts++; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
207 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
208 |
24457 | 209 if (offset + skip >= totalsize) |
24456 | 210 break; |
24457 | 211 offset += skip; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
212 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
213 tivo->tmf_totalparts = parts; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
214 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
|
215 "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
|
216 |
24446 | 217 return 1; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
218 } |
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 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
221 // =========================================================================== |
24451 | 222 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
|
223 { |
24451 | 224 int i; |
225 for (i = 0; i < tivo->tmf_totalparts; i++) { | |
226 if (chunk < tivo->tmfparts[i].chunks) | |
227 return tivo->tmfparts[i].startOffset + chunk * CHUNKSIZE; | |
228 chunk -= tivo->tmfparts[i].chunks; | |
229 } | |
230 return -1; | |
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 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
234 // =========================================================================== |
24443 | 235 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
|
236 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
|
237 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
238 off_t fileoffset; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
239 int count; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
240 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
241 mp_msg( MSGT_DEMUX, MSGL_DBG3, "\ntmf_load_chunk() begin %d\n", |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
242 readChunk ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
243 |
24452 | 244 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
|
245 |
24452 | 246 if (fileoffset == -1) { |
247 mp_msg(MSGT_DEMUX, MSGL_ERR, "Read past EOF()\n"); | |
248 return 0; | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
249 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
250 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
251 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
|
252 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
253 mp_msg( MSGT_DEMUX, MSGL_ERR, "Read past EOF()\n" ); |
24464 | 254 return 0; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
255 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
256 count = stream_read( demux->stream, buff, size ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
257 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
|
258 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
259 mp_msg( MSGT_DEMUX, MSGL_DBG3, "tmf_load_chunk() count %x\n", |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
260 count ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
261 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
262 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
|
263 "tmf_load_chunk() bytes %x %x %x %x %x %x %x %x\n", |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
264 buff[ 0 ], buff[ 1 ], buff[ 2 ], buff[ 3 ], |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
265 buff[ 4 ], buff[ 5 ], buff[ 6 ], buff[ 7 ] ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
266 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
267 mp_msg( MSGT_DEMUX, MSGL_DBG3, "tmf_load_chunk() end\n" ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
268 |
24446 | 269 return count; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
270 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
271 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
272 // =========================================================================== |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
273 |
10263 | 274 // DTiVo MPEG 336, 480, 576, 768 |
275 // SA TiVo 864 | |
276 // DTiVo AC-3 1550 | |
277 // | |
24446 | 278 #define SERIES1_PTS_LENGTH 11 |
279 #define SERIES1_PTS_OFFSET 6 | |
280 #define SERIES2_PTS_LENGTH 16 | |
281 #define SERIES2_PTS_OFFSET 9 | |
282 #define AC3_PTS_LENGTH 16 | |
283 #define AC3_PTS_OFFSET 9 | |
10263 | 284 |
24446 | 285 #define NUMBER_DIFFERENT_AUDIO_SIZES 7 |
10263 | 286 static int Series1AudioWithPTS[ NUMBER_DIFFERENT_AUDIO_SIZES ] = |
287 { | |
288 336 + SERIES1_PTS_LENGTH, | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
289 384 + SERIES1_PTS_LENGTH, |
10263 | 290 480 + SERIES1_PTS_LENGTH, |
291 576 + SERIES1_PTS_LENGTH, | |
292 768 + SERIES1_PTS_LENGTH, | |
293 864 + SERIES1_PTS_LENGTH | |
294 }; | |
295 static int Series2AudioWithPTS[ NUMBER_DIFFERENT_AUDIO_SIZES ] = | |
296 { | |
297 336 + SERIES2_PTS_LENGTH, | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
298 384 + SERIES2_PTS_LENGTH, |
10263 | 299 480 + SERIES2_PTS_LENGTH, |
300 576 + SERIES2_PTS_LENGTH, | |
301 768 + SERIES2_PTS_LENGTH, | |
302 864 + SERIES2_PTS_LENGTH | |
303 }; | |
304 | |
305 static int IsValidAudioPacket( int size, int *ptsOffset, int *ptsLen ) | |
306 { | |
307 int count; | |
308 | |
309 *ptsOffset = 0; | |
310 *ptsLen = 0; | |
311 | |
312 // AC-3 | |
24446 | 313 if ( size == 1550 || size == 1552 ) |
10263 | 314 { |
315 *ptsOffset = AC3_PTS_OFFSET; | |
316 *ptsLen = AC3_PTS_LENGTH; | |
24446 | 317 return 1; |
10263 | 318 } |
319 | |
320 // MPEG | |
321 for( count = 0 ; count < NUMBER_DIFFERENT_AUDIO_SIZES ; count++ ) | |
322 { | |
323 if ( size == Series1AudioWithPTS[ count ] ) | |
324 { | |
325 *ptsOffset = SERIES1_PTS_OFFSET; | |
326 *ptsLen = SERIES1_PTS_LENGTH; | |
327 break; | |
328 } | |
329 } | |
330 if ( *ptsOffset == 0 ) | |
331 { | |
332 for( count = 0 ; count < NUMBER_DIFFERENT_AUDIO_SIZES ; count++ ) | |
333 { | |
334 if ( size == Series2AudioWithPTS[ count ] ) | |
335 { | |
336 *ptsOffset = SERIES2_PTS_OFFSET; | |
337 *ptsLen = SERIES2_PTS_LENGTH; | |
338 break; | |
339 } | |
340 } | |
341 } | |
342 if ( *ptsOffset == 0 ) | |
343 { | |
344 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Tossing Audio Packet Size %d\n", | |
345 size ); | |
24446 | 346 return 0; |
10263 | 347 } |
24464 | 348 return 1; |
10263 | 349 } |
350 | |
351 | |
24463 | 352 static int64_t get_ty_pts( unsigned char *buf ) |
10263 | 353 { |
24461
921de822048c
Fix completely broken get_ty_pts (it's an ordinary MPEG timestamp)
reimar
parents:
24460
diff
changeset
|
354 int a = buf[0] & 0xe; |
921de822048c
Fix completely broken get_ty_pts (it's an ordinary MPEG timestamp)
reimar
parents:
24460
diff
changeset
|
355 int b = AV_RB16(buf + 1); |
921de822048c
Fix completely broken get_ty_pts (it's an ordinary MPEG timestamp)
reimar
parents:
24460
diff
changeset
|
356 int c = AV_RB16(buf + 3); |
10263 | 357 |
24461
921de822048c
Fix completely broken get_ty_pts (it's an ordinary MPEG timestamp)
reimar
parents:
24460
diff
changeset
|
358 if (!(1 & a & b & c)) // invalid MPEG timestamp |
24463 | 359 return MP_NOPTS_VALUE; |
24461
921de822048c
Fix completely broken get_ty_pts (it's an ordinary MPEG timestamp)
reimar
parents:
24460
diff
changeset
|
360 a >>= 1; b >>= 1; c >>= 1; |
24463 | 361 return (((uint64_t)a) << 30) | (b << 15) | c; |
10263 | 362 } |
363 | |
364 static void demux_ty_AddToAudioBuffer( TiVoInfo *tivo, unsigned char *buffer, | |
365 int size ) | |
366 { | |
24446 | 367 if ( tivo->lastAudioEnd + size < MAX_AUDIO_BUFFER ) |
10263 | 368 { |
24446 | 369 memcpy( &tivo->lastAudio[ tivo->lastAudioEnd ], |
10263 | 370 buffer, size ); |
371 tivo->lastAudioEnd += size; | |
372 } | |
373 else | |
374 mp_msg( MSGT_DEMUX, MSGL_ERR, | |
375 "ty:WARNING - Would have blown my audio buffer\n" ); | |
376 } | |
377 | |
378 static void demux_ty_CopyToDemuxPacket( int type, TiVoInfo *tivo, demux_stream_t *ds, | |
379 unsigned char *buffer, int size, off_t pos, float pts ) | |
380 { | |
381 demux_packet_t *dp; | |
382 | |
383 // mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Calling ds_add_packet() %7.1f\n", pts ); | |
384 // printf( "%x %x %x %x\n", | |
385 // buffer[ 0 ], buffer[ 1 ], buffer[ 2 ], buffer[ 3 ] ); | |
386 | |
387 dp = new_demux_packet( size ); | |
388 memcpy( dp->buffer, buffer, size ); | |
24463 | 389 if (pts != MP_NOPTS_VALUE) |
390 dp->pts = pts / 90000.0; | |
10263 | 391 dp->pos = pos; |
392 dp->flags = 0; | |
393 ds_add_packet( ds, dp ); | |
24463 | 394 if ( type == TY_V && tivo->firstVideoPTS == MP_NOPTS_VALUE ) |
10263 | 395 tivo->firstVideoPTS = pts; |
24463 | 396 if ( type == TY_A && tivo->firstAudioPTS == MP_NOPTS_VALUE ) |
10263 | 397 tivo->firstAudioPTS = pts; |
398 } | |
399 | |
400 static int demux_ty_FindESHeader( unsigned char *header, int headerSize, | |
401 unsigned char *buffer, int bufferSize, int *esOffset1 ) | |
402 { | |
403 int count; | |
404 | |
405 *esOffset1 = -1; | |
406 for( count = 0 ; count < bufferSize ; count++ ) | |
407 { | |
24446 | 408 if ( buffer[ count + 0 ] == header[ 0 ] && |
409 buffer[ count + 1 ] == header[ 1 ] && | |
410 buffer[ count + 2 ] == header[ 2 ] && | |
411 buffer[ count + 3 ] == header[ 3 ] ) | |
10263 | 412 { |
413 *esOffset1 = count; | |
24446 | 414 return 1; |
10263 | 415 } |
416 } | |
24446 | 417 return -1; |
10263 | 418 } |
419 | |
420 static void demux_ty_FindESPacket( unsigned char *header, int headerSize, | |
421 unsigned char *buffer, int bufferSize, int *esOffset1, int *esOffset2 ) | |
422 { | |
423 int count; | |
424 | |
425 *esOffset1 = -1; | |
426 *esOffset2 = -1; | |
427 | |
428 for( count = 0 ; count < bufferSize ; count++ ) | |
429 { | |
24446 | 430 if ( buffer[ count + 0 ] == header[ 0 ] && |
431 buffer[ count + 1 ] == header[ 1 ] && | |
432 buffer[ count + 2 ] == header[ 2 ] && | |
433 buffer[ count + 3 ] == header[ 3 ] ) | |
10263 | 434 { |
435 *esOffset1 = count; | |
436 break; | |
437 } | |
438 } | |
439 | |
440 if ( *esOffset1 != -1 ) | |
441 { | |
442 for( count = *esOffset1 + 1 ; | |
443 count < bufferSize ; count++ ) | |
444 { | |
24446 | 445 if ( buffer[ count + 0 ] == header[ 0 ] && |
446 buffer[ count + 1 ] == header[ 1 ] && | |
447 buffer[ count + 2 ] == header[ 2 ] && | |
448 buffer[ count + 3 ] == header[ 3 ] ) | |
10263 | 449 { |
450 *esOffset2 = count; | |
451 break; | |
452 } | |
453 } | |
454 } | |
455 } | |
456 | |
457 static unsigned char ty_VideoPacket[] = { 0x00, 0x00, 0x01, 0xe0 }; | |
458 static unsigned char ty_MPEGAudioPacket[] = { 0x00, 0x00, 0x01, 0xc0 }; | |
459 static unsigned char ty_AC3AudioPacket[] = { 0x00, 0x00, 0x01, 0xbd }; | |
460 | |
16175 | 461 static int demux_ty_fill_buffer( demuxer_t *demux, demux_stream_t *dsds ) |
10263 | 462 { |
463 int invalidType = 0; | |
464 int errorHeader = 0; | |
465 int recordsDecoded = 0; | |
466 off_t filePos = 0; | |
467 | |
468 unsigned char chunk[ CHUNKSIZE ]; | |
469 int whichChunk; | |
470 int readSize; | |
471 unsigned int pesFileId = 0; | |
472 | |
473 int numberRecs; | |
474 unsigned char *recPtr; | |
475 int offset; | |
476 int size; | |
477 | |
478 int type; | |
479 int nybbleType; | |
480 | |
481 int counter; | |
482 | |
483 int aid; | |
484 demux_stream_t *ds = NULL; | |
485 | |
486 int esOffset1; | |
487 int esOffset2; | |
488 | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
489 unsigned char lastCC[ 16 ]; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
490 unsigned char lastXDS[ 16 ]; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
491 |
10263 | 492 TiVoInfo *tivo = 0; |
493 | |
494 if ( demux->stream->type == STREAMTYPE_DVD ) | |
24446 | 495 return 0; |
10263 | 496 |
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, "ty:ty processing\n" ); |
24446 | 498 if ( demux->a_streams[ MAX_A_STREAMS - 1 ] == 0 ) |
10263 | 499 { |
500 demux->a_streams[ MAX_A_STREAMS - 1 ] = malloc( sizeof( TiVoInfo ) ); | |
501 tivo = demux->a_streams[ MAX_A_STREAMS - 1 ]; | |
502 memset( tivo, 0, sizeof( TiVoInfo ) ); | |
24463 | 503 tivo->firstAudioPTS = MP_NOPTS_VALUE; |
504 tivo->firstVideoPTS = MP_NOPTS_VALUE; | |
10263 | 505 } |
506 else | |
507 tivo = demux->a_streams[ MAX_A_STREAMS - 1 ]; | |
508 | |
509 if( demux->stream->eof ) return 0; | |
510 | |
511 // ====================================================================== | |
11000 | 512 // If we haven't figured out the size of the stream, let's do so |
10263 | 513 // ====================================================================== |
514 #ifdef STREAMTYPE_STREAM_TY | |
515 if ( demux->stream->type == STREAMTYPE_STREAM_TY ) | |
516 { | |
517 // The vstream code figures out the exact size of the stream | |
518 demux->movi_start = 0; | |
519 demux->movi_end = vstream_streamsize(); | |
520 tivo->size = vstream_streamsize(); | |
521 } | |
522 else | |
523 #endif | |
524 { | |
525 // If its a local file, try to find the Part Headers, so we can | |
526 // calculate the ACTUAL stream size | |
527 // If we can't find it, go off with the file size and hope the | |
528 // extract program did the "right thing" | |
529 if ( tivo->readHeader == 0 ) | |
530 { | |
531 tivo->readHeader = 1; | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
532 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
|
533 |
10263 | 534 filePos = demux->filepos; |
535 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
|
536 |
10263 | 537 // mp_msg( MSGT_DEMUX, MSGL_DBG3, |
538 // "ty:Reading a chunk %d\n", __LINE__ ); | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
539 |
10263 | 540 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
|
541 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
542 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
|
543 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
544 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
|
545 tivo->tmf = 1; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
546 ty_tmf_filetoparts( demux, tivo ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
547 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
|
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 ) |
551 { | |
24465 | 552 tivo->pesFileId = AV_RB32(chunk); |
553 tivo->streamType = AV_RB32(chunk + 4); | |
554 tivo->chunkSize = AV_RB32(chunk + 8); | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
555 |
10263 | 556 if ( tivo->pesFileId == TIVO_PES_FILEID ) |
557 { | |
558 off_t numberParts; | |
559 | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
560 readSize = 0; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
561 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
562 if ( tivo->tmf != 1 ) |
10263 | 563 { |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
564 off_t offset; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
565 |
10263 | 566 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
|
567 offset = numberParts * TIVO_PART_LENGTH; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
568 |
17366 | 569 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:ty/ty+Number Parts %"PRId64"\n", |
570 (int64_t)numberParts ); | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
571 |
24446 | 572 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
|
573 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
574 stream_seek( demux->stream, offset ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
575 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
|
576 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
577 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
578 else |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
579 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
580 numberParts = tivo->tmf_totalparts; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
581 offset = numberParts * TIVO_PART_LENGTH; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
582 readSize = tmf_load_chunk( demux, tivo, chunk, CHUNKSIZE, |
24446 | 583 numberParts * ( TIVO_PART_LENGTH - CHUNKSIZE ) / |
584 CHUNKSIZE ); | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
585 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
586 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
587 if ( readSize == CHUNKSIZE ) |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
588 { |
24465 | 589 pesFileId = AV_RB32(chunk); |
10263 | 590 if ( pesFileId == TIVO_PES_FILEID ) |
591 { | |
24466 | 592 size = AV_RB24(chunk + 12); |
10263 | 593 size -= 4; |
594 size *= CHUNKSIZE; | |
595 tivo->size = numberParts * TIVO_PART_LENGTH; | |
596 tivo->size += size; | |
597 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
16750
0a31740dd5e6
Use PRI?64 defines as format strings for 64 bit variables.
reimar
parents:
16346
diff
changeset
|
598 "ty:Header Calc Stream Size %"PRId64"\n", tivo->size ); |
10263 | 599 } |
600 } | |
601 } | |
602 } | |
603 if ( tivo->size > demux->stream->end_pos ) | |
604 tivo->size = demux->stream->end_pos; | |
605 | |
606 if ( demux->stream->start_pos > 0 ) | |
607 filePos = demux->stream->start_pos; | |
608 stream_seek( demux->stream, filePos ); | |
609 demux->filepos = stream_tell( demux->stream ); | |
24446 | 610 tivo->whichChunk = filePos / CHUNKSIZE; |
10263 | 611 } |
612 demux->movi_start = 0; | |
613 demux->movi_end = tivo->size; | |
614 } | |
615 | |
616 // ====================================================================== | |
617 // Give a clue as to where we are in the stream | |
618 // ====================================================================== | |
619 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
17366 | 620 "ty:ty header size %"PRIx64"\n", (int64_t)tivo->size ); |
10263 | 621 mp_msg( MSGT_DEMUX, MSGL_DBG3, |
17366 | 622 "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
|
623 mp_msg( MSGT_DEMUX, MSGL_DBG3, |
17366 | 624 "ty:file end_pos %"PRIx64"\n", (int64_t)demux->stream->end_pos ); |
10263 | 625 mp_msg( MSGT_DEMUX, MSGL_DBG3, |
17366 | 626 "\nty:wanted current offset %"PRIx64"\n", (int64_t)stream_tell( demux->stream ) ); |
10263 | 627 |
24464 | 628 if ( tivo->size > 0 && stream_tell( demux->stream ) > tivo->size ) |
10263 | 629 { |
630 demux->stream->eof = 1; | |
24464 | 631 return 0; |
10263 | 632 } |
633 | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
634 if ( tivo->tmf != 1 ) |
10263 | 635 { |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
636 // Make sure we are on a 128k boundary |
24446 | 637 if ( demux->filepos % CHUNKSIZE != 0 ) |
10263 | 638 { |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
639 whichChunk = demux->filepos / CHUNKSIZE; |
24446 | 640 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
|
641 whichChunk++; |
24446 | 642 stream_seek( demux->stream, whichChunk * CHUNKSIZE ); |
10263 | 643 } |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
644 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
645 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
|
646 tivo->whichChunk = demux->filepos / CHUNKSIZE; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
647 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
|
648 if ( readSize != CHUNKSIZE ) |
24464 | 649 return 0; |
10263 | 650 } |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
651 else |
10263 | 652 { |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
653 readSize = tmf_load_chunk( demux, tivo, chunk, CHUNKSIZE, |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
654 tivo->whichChunk ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
655 if ( readSize != CHUNKSIZE ) |
24446 | 656 return 0; |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
657 tivo->whichChunk++; |
10263 | 658 } |
659 | |
660 // We found a part header, skip it | |
24465 | 661 pesFileId = AV_RB32(chunk); |
10263 | 662 if( pesFileId == TIVO_PES_FILEID ) |
663 { | |
664 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
|
665 if ( tivo->tmf != 1 ) |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
666 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
667 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
|
668 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
|
669 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
670 else |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
671 { |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
672 readSize = tmf_load_chunk( demux, tivo, chunk, CHUNKSIZE, |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
673 tivo->whichChunk ); |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
674 tivo->whichChunk++; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
675 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
676 |
10263 | 677 if ( readSize != CHUNKSIZE ) |
24446 | 678 return 0; |
10263 | 679 } |
680 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
24446 | 681 "\nty:actual current offset %"PRIx64"\n", stream_tell( demux->stream ) - |
682 CHUNKSIZE ); | |
10263 | 683 |
684 | |
12860 | 685 // Let's make a Video Demux Stream for MPlayer |
10263 | 686 aid = 0x0; |
687 if( !demux->v_streams[ aid ] ) new_sh_video( demux, aid ); | |
688 if( demux->video->id == -1 ) demux->video->id = aid; | |
689 if( demux->video->id == aid ) | |
690 { | |
691 ds = demux->video; | |
692 if( !ds->sh ) ds->sh = demux->v_streams[ aid ]; | |
693 } | |
694 | |
695 // ====================================================================== | |
696 // Finally, we get to actually parse the chunk | |
697 // ====================================================================== | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
698 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:ty parsing a chunk\n" ); |
10263 | 699 numberRecs = chunk[ 0 ]; |
700 recPtr = &chunk[ 4 ]; | |
24446 | 701 offset = numberRecs * 16 + 4; |
10263 | 702 for ( counter = 0 ; counter < numberRecs ; counter++ ) |
703 { | |
704 size = ( recPtr[ 0 ] << 8 | recPtr[ 1 ] ) << 4 | ( recPtr[ 2 ] >> 4 ); | |
705 type = recPtr[ 3 ]; | |
706 nybbleType = recPtr[ 2 ] & 0x0f; | |
707 recordsDecoded++; | |
708 | |
709 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
710 "ty:Record Type %x/%x %d\n", nybbleType, type, size ); | |
711 | |
712 // ================================================================ | |
713 // Video Parsing | |
714 // ================================================================ | |
715 if ( type == 0xe0 ) | |
716 { | |
24446 | 717 if ( size > 0 && size + offset <= CHUNKSIZE ) |
10263 | 718 { |
719 #if 0 | |
720 printf( "Video Chunk Header " ); | |
721 for( count = 0 ; count < 24 ; count++ ) | |
722 { | |
723 printf( "%2.2x ", chunk[ offset + count ] ); | |
724 } | |
725 printf( "\n" ); | |
726 #endif | |
727 demux_ty_FindESHeader( ty_VideoPacket, 4, &chunk[ offset ], | |
728 size, &esOffset1 ); | |
729 if ( esOffset1 != -1 ) | |
730 tivo->lastVideoPTS = get_ty_pts( | |
731 &chunk[ offset + esOffset1 + 9 ] ); | |
732 | |
733 // Do NOT Pass the PES Header onto the MPEG2 Decode | |
734 if( nybbleType != 0x06 ) | |
735 demux_ty_CopyToDemuxPacket( TY_V, tivo, demux->video, | |
24446 | 736 &chunk[ offset ], size, demux->filepos + offset, |
10263 | 737 tivo->lastVideoPTS ); |
738 offset += size; | |
739 } | |
740 else | |
741 errorHeader++; | |
742 } | |
743 // ================================================================ | |
744 // Audio Parsing | |
745 // ================================================================ | |
746 else if ( type == 0xc0 ) | |
747 { | |
24446 | 748 if ( size > 0 && size + offset <= CHUNKSIZE ) |
10263 | 749 { |
750 #if 0 | |
751 printf( "Audio Chunk Header " ); | |
752 for( count = 0 ; count < 24 ; count++ ) | |
753 { | |
754 printf( "%2.2x ", chunk[ offset + count ] ); | |
755 } | |
756 printf( "\n" ); | |
757 #endif | |
758 | |
759 if( demux->audio->id == -1 ) | |
760 { | |
761 if ( nybbleType == 0x02 ) | |
762 continue; // DTiVo inconclusive, wait for more | |
763 else if ( nybbleType == 0x09 ) | |
764 { | |
765 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Setting AC-3 Audio\n" ); | |
766 aid = 0x80; // AC-3 | |
767 } | |
768 else | |
769 { | |
770 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Setting MPEG Audio\n" ); | |
771 aid = 0x0; // MPEG Audio | |
772 } | |
773 | |
774 demux->audio->id = aid; | |
775 if( !demux->a_streams[ aid ] ) new_sh_audio( demux, aid ); | |
776 if( demux->audio->id == aid ) | |
777 { | |
778 ds = demux->audio; | |
15580 | 779 if( !ds->sh ) { |
780 sh_audio_t* sh_a; | |
781 ds->sh = demux->a_streams[ aid ]; | |
782 sh_a = (sh_audio_t*)ds->sh; | |
783 switch(aid & 0xE0){ // 1110 0000 b (high 3 bit: type low 5: id) | |
784 case 0x00: sh_a->format=0x50;break; // mpeg | |
785 case 0xA0: sh_a->format=0x10001;break; // dvd pcm | |
786 case 0x80: if((aid & 0xF8) == 0x88) sh_a->format=0x2001;//dts | |
787 else sh_a->format=0x2000;break; // ac3 | |
788 } | |
789 } | |
10263 | 790 } |
791 } | |
792 | |
793 aid = demux->audio->id; | |
794 | |
795 | |
796 // SA DTiVo Audio Data, no PES | |
797 // ================================================ | |
798 if ( nybbleType == 0x02 ) | |
799 { | |
800 if ( tivo->tivoType == 2 ) | |
801 demux_ty_AddToAudioBuffer( tivo, &chunk[ offset ], size ); | |
802 else | |
803 { | |
804 | |
805 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
806 "ty:Adding Audio Packet Size %d\n", size ); | |
807 demux_ty_CopyToDemuxPacket( TY_A, tivo, demux->audio, | |
808 &chunk[ offset ], size, ( demux->filepos + offset ), | |
809 tivo->lastAudioPTS ); | |
810 } | |
811 } | |
812 | |
813 // MPEG Audio with PES Header, either SA or DTiVo | |
814 // ================================================ | |
815 if ( nybbleType == 0x03 ) | |
816 { | |
817 demux_ty_FindESHeader( ty_MPEGAudioPacket, 4, &chunk[ offset ], | |
818 size, &esOffset1 ); | |
819 | |
820 // SA PES Header, No Audio Data | |
821 // ================================================ | |
24446 | 822 if ( esOffset1 == 0 && size == 16 ) |
10263 | 823 { |
824 tivo->tivoType = 1; | |
825 tivo->lastAudioPTS = get_ty_pts( &chunk[ offset + | |
826 SERIES2_PTS_OFFSET ] ); | |
827 } | |
828 else | |
829 // DTiVo Audio with PES Header | |
830 // ================================================ | |
831 { | |
832 tivo->tivoType = 2; | |
833 | |
834 demux_ty_AddToAudioBuffer( tivo, &chunk[ offset ], size ); | |
835 demux_ty_FindESPacket( ty_MPEGAudioPacket, 4, | |
836 tivo->lastAudio, tivo->lastAudioEnd, &esOffset1, | |
837 &esOffset2 ); | |
838 | |
24446 | 839 if ( esOffset1 != -1 && esOffset2 != -1 ) |
10263 | 840 { |
841 int packetSize = esOffset2 - esOffset1; | |
842 int headerSize; | |
843 int ptsOffset; | |
844 | |
845 if ( IsValidAudioPacket( packetSize, &ptsOffset, | |
846 &headerSize ) ) | |
847 { | |
848 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
849 "ty:Adding DTiVo Audio Packet Size %d\n", | |
850 packetSize ); | |
851 | |
852 tivo->lastAudioPTS = get_ty_pts( | |
853 &tivo->lastAudio[ esOffset1 + ptsOffset ] ); | |
854 | |
855 demux_ty_CopyToDemuxPacket | |
856 ( | |
857 TY_A, | |
858 tivo, | |
859 demux->audio, | |
860 &( tivo->lastAudio[ esOffset1 + headerSize ] ), | |
861 ( packetSize - headerSize ), | |
862 ( demux->filepos + offset ), | |
863 tivo->lastAudioPTS | |
864 ); | |
865 | |
866 } | |
867 | |
868 // Collapse the Audio Buffer | |
24446 | 869 memmove( &tivo->lastAudio[ 0 ], |
870 &tivo->lastAudio[ esOffset2 ], | |
871 tivo->lastAudioEnd - esOffset2 ); | |
10263 | 872 tivo->lastAudioEnd -= esOffset2; |
873 } | |
874 } | |
875 } | |
876 | |
877 // SA Audio with no PES Header | |
878 // ================================================ | |
879 if ( nybbleType == 0x04 ) | |
880 { | |
881 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
882 "ty:Adding Audio Packet Size %d\n", size ); | |
883 demux_ty_CopyToDemuxPacket( TY_A, tivo, demux->audio, | |
884 &chunk[ offset ], size, ( demux->filepos + offset ), | |
885 tivo->lastAudioPTS ); | |
886 } | |
887 | |
888 // DTiVo AC3 Audio Data with PES Header | |
889 // ================================================ | |
890 if ( nybbleType == 0x09 ) | |
891 { | |
892 tivo->tivoType = 2; | |
893 | |
894 demux_ty_AddToAudioBuffer( tivo, &chunk[ offset ], size ); | |
895 demux_ty_FindESPacket( ty_AC3AudioPacket, 4, | |
896 tivo->lastAudio, tivo->lastAudioEnd, &esOffset1, | |
897 &esOffset2 ); | |
898 | |
24446 | 899 if ( esOffset1 != -1 && esOffset2 != -1 ) |
10263 | 900 { |
901 int packetSize = esOffset2 - esOffset1; | |
902 int headerSize; | |
903 int ptsOffset; | |
904 | |
905 if ( IsValidAudioPacket( packetSize, &ptsOffset, | |
906 &headerSize ) ) | |
907 { | |
908 mp_msg( MSGT_DEMUX, MSGL_DBG3, | |
909 "ty:Adding DTiVo Audio Packet Size %d\n", | |
910 packetSize ); | |
911 | |
912 tivo->lastAudioPTS = get_ty_pts( | |
913 &tivo->lastAudio[ esOffset1 + ptsOffset ] ); | |
914 | |
915 // AC3 Decoder WANTS the PTS | |
916 demux_ty_CopyToDemuxPacket | |
917 ( | |
918 TY_A, | |
919 tivo, | |
920 demux->audio, | |
24446 | 921 &tivo->lastAudio[ esOffset1 ], |
922 packetSize, | |
923 demux->filepos + offset, | |
10263 | 924 tivo->lastAudioPTS |
925 ); | |
926 | |
927 } | |
928 | |
929 // Collapse the Audio Buffer | |
24446 | 930 memmove( &tivo->lastAudio[ 0 ], |
931 &tivo->lastAudio[ esOffset2 ], | |
932 tivo->lastAudioEnd - esOffset2 ); | |
10263 | 933 tivo->lastAudioEnd -= esOffset2; |
934 } | |
935 } | |
936 offset += size; | |
937 } | |
938 else | |
939 errorHeader++; | |
940 } | |
941 // ================================================================ | |
942 // Closed Caption | |
943 // ================================================================ | |
944 else if ( type == 0x01 ) | |
945 { | |
946 unsigned char b1; | |
947 unsigned char b2; | |
948 | |
949 b1 = ( ( ( recPtr[ 0 ] & 0x0f ) << 4 ) | | |
950 ( ( recPtr[ 1 ] & 0xf0 ) >> 4 ) ); | |
951 b1 &= 0x7f; | |
952 b2 = ( ( ( recPtr[ 1 ] & 0x0f ) << 4 ) | | |
953 ( ( recPtr[ 2 ] & 0xf0 ) >> 4 ) ); | |
954 b2 &= 0x7f; | |
955 | |
956 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:CC %x %x\n", b1, b2 ); | |
957 | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
958 lastCC[ 0x00 ] = 0x00; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
959 lastCC[ 0x01 ] = 0x00; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
960 lastCC[ 0x02 ] = 0x01; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
961 lastCC[ 0x03 ] = 0xb2; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
962 lastCC[ 0x04 ] = 'T'; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
963 lastCC[ 0x05 ] = 'Y'; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
964 lastCC[ 0x06 ] = 0x01; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
965 lastCC[ 0x07 ] = b1; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
966 lastCC[ 0x08 ] = b2; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
967 if ( subcc_enabled ) |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
968 demux_ty_CopyToDemuxPacket( TY_V, tivo, demux->video, lastCC, 0x09, |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
969 ( demux->filepos + offset ), tivo->lastVideoPTS ); |
10263 | 970 } |
971 // ================================================================ | |
972 // Extended Data Services | |
973 // ================================================================ | |
974 else if ( type == 0x02 ) | |
975 { | |
976 unsigned char b1; | |
977 unsigned char b2; | |
978 | |
979 b1 = ( ( ( recPtr[ 0 ] & 0x0f ) << 4 ) | | |
980 ( ( recPtr[ 1 ] & 0xf0 ) >> 4 ) ); | |
981 b1 &= 0x7f; | |
982 b2 = ( ( ( recPtr[ 1 ] & 0x0f ) << 4 ) | | |
983 ( ( recPtr[ 2 ] & 0xf0 ) >> 4 ) ); | |
984 b2 &= 0x7f; | |
985 | |
986 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:XDS %x %x\n", b1, b2 ); | |
987 | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
988 lastXDS[ 0x00 ] = 0x00; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
989 lastXDS[ 0x01 ] = 0x00; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
990 lastXDS[ 0x02 ] = 0x01; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
991 lastXDS[ 0x03 ] = 0xb2; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
992 lastXDS[ 0x04 ] = 'T'; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
993 lastXDS[ 0x05 ] = 'Y'; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
994 lastXDS[ 0x06 ] = 0x02; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
995 lastXDS[ 0x07 ] = b1; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
996 lastXDS[ 0x08 ] = b2; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
997 if ( subcc_enabled ) |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
998 demux_ty_CopyToDemuxPacket( TY_V, tivo, demux->video, lastXDS, 0x09, |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
999 ( demux->filepos + offset ), tivo->lastVideoPTS ); |
10263 | 1000 } |
1001 // ================================================================ | |
1002 // Found a 0x03 on Droid's TiVo, I have no idea what it is | |
1003 // ================================================================ | |
1004 else if ( type == 0x03 ) | |
1005 { | |
24446 | 1006 if ( size > 0 && size + offset <= CHUNKSIZE ) |
10263 | 1007 offset += size; |
1008 } | |
1009 // ================================================================ | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
1010 // Found a 0x03 on Hermit's TiVo, I have no idea what it is |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
1011 // ================================================================ |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
1012 else if ( type == 0x03 ) |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
1013 { |
24446 | 1014 if ( size > 0 && size + offset <= CHUNKSIZE ) |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
1015 offset += size; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
1016 } |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
1017 // ================================================================ |
10263 | 1018 // Unknown |
1019 // ================================================================ | |
1020 else if ( type == 0x05 ) | |
1021 { | |
24446 | 1022 if ( size > 0 && size + offset <= CHUNKSIZE ) |
10263 | 1023 offset += size; |
1024 } | |
1025 else | |
1026 { | |
24446 | 1027 if ( size > 0 && size + offset <= CHUNKSIZE ) |
10263 | 1028 offset += size; |
1029 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Invalid Type %x\n", type ); | |
1030 invalidType++; | |
1031 } | |
1032 recPtr += 16; | |
1033 } | |
1034 | |
20141
bd3afd5a2e48
Fix misdetection of http://samples.mplayerhq.hu/tta/tivo_misdetect.tta as TiVo file
reimar
parents:
19614
diff
changeset
|
1035 if ( errorHeader > 0 || invalidType > 0 ) |
10263 | 1036 { |
1037 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
|
1038 "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
|
1039 numberRecs, recordsDecoded, errorHeader, invalidType ); |
10263 | 1040 |
1041 // Invalid MPEG ES Size Check | |
24446 | 1042 if ( errorHeader > numberRecs / 2 ) |
1043 return 0; | |
10263 | 1044 |
1045 // Invalid MPEG Stream Type Check | |
24446 | 1046 if ( invalidType > numberRecs / 2 ) |
1047 return 0; | |
10263 | 1048 } |
1049 | |
1050 demux->filepos = stream_tell( demux->stream ); | |
1051 | |
24446 | 1052 return 1; |
10263 | 1053 } |
1054 | |
17636 | 1055 static void demux_seek_ty( demuxer_t *demuxer, float rel_seek_secs, float audio_delay, int flags ) |
10263 | 1056 { |
1057 demux_stream_t *d_audio = demuxer->audio; | |
1058 demux_stream_t *d_video = demuxer->video; | |
1059 sh_audio_t *sh_audio = d_audio->sh; | |
1060 sh_video_t *sh_video = d_video->sh; | |
1061 off_t newpos; | |
1062 off_t res; | |
1063 TiVoInfo *tivo = 0; | |
1064 | |
1065 mp_msg( MSGT_DEMUX, MSGL_DBG3, "ty:Seeking to %7.1f\n", rel_seek_secs ); | |
1066 | |
24446 | 1067 if ( demuxer->a_streams[ MAX_A_STREAMS - 1 ] != 0 ) |
10263 | 1068 { |
1069 tivo = demuxer->a_streams[ MAX_A_STREAMS - 1 ]; | |
1070 tivo->lastAudioEnd = 0; | |
24463 | 1071 tivo->lastAudioPTS = MP_NOPTS_VALUE; |
1072 tivo->lastVideoPTS = MP_NOPTS_VALUE; | |
10263 | 1073 } |
1074 // | |
1075 //================= seek in MPEG ========================== | |
1076 demuxer->filepos = stream_tell( demuxer->stream ); | |
1077 | |
1078 newpos = ( flags & 1 ) ? demuxer->movi_start : demuxer->filepos; | |
1079 | |
1080 if( flags & 2 ) | |
1081 // float seek 0..1 | |
1082 newpos += ( demuxer->movi_end - demuxer->movi_start ) * rel_seek_secs; | |
1083 else | |
1084 { | |
1085 // time seek (secs) | |
1086 if( ! sh_video->i_bps ) // unspecified or VBR | |
1087 newpos += 2324 * 75 * rel_seek_secs; // 174.3 kbyte/sec | |
1088 else | |
1089 newpos += sh_video->i_bps * rel_seek_secs; | |
1090 } | |
1091 | |
1092 if ( newpos < demuxer->movi_start ) | |
1093 { | |
1094 if( demuxer->stream->type != STREAMTYPE_VCD ) demuxer->movi_start = 0; | |
1095 if( newpos < demuxer->movi_start ) newpos = demuxer->movi_start; | |
1096 } | |
1097 | |
1098 res = newpos / CHUNKSIZE; | |
1099 if ( rel_seek_secs >= 0 ) | |
1100 newpos = ( res + 1 ) * CHUNKSIZE; | |
1101 else | |
1102 newpos = res * CHUNKSIZE; | |
1103 | |
1104 if ( newpos < 0 ) | |
1105 newpos = 0; | |
15581
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
1106 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
1107 tivo->whichChunk = newpos / CHUNKSIZE; |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
1108 |
2e621c99354d
a cleaned-up version of ty demuxer improvements found in tivo-mplayer fork.
joey
parents:
15580
diff
changeset
|
1109 stream_seek( demuxer->stream, newpos ); |
10263 | 1110 |
1111 // re-sync video: | |
1112 videobuf_code_len = 0; // reset ES stream buffer | |
1113 | |
1114 ds_fill_buffer( d_video ); | |
1115 if( sh_audio ) | |
1116 ds_fill_buffer( d_audio ); | |
1117 | |
1118 while( 1 ) | |
1119 { | |
1120 int i; | |
1121 if( sh_audio && !d_audio->eof && d_video->pts && d_audio->pts ) | |
1122 { | |
1123 float a_pts = d_audio->pts; | |
1124 a_pts += ( ds_tell_pts( d_audio ) - sh_audio->a_in_buffer_len ) / | |
1125 (float)sh_audio->i_bps; | |
1126 if( d_video->pts > a_pts ) | |
1127 { | |
1128 skip_audio_frame( sh_audio ); // sync audio | |
1129 continue; | |
1130 } | |
1131 } | |
1132 i = sync_video_packet( d_video ); | |
1133 if( i == 0x1B3 || i == 0x1B8 ) break; // found it! | |
1134 if( !i || !skip_video_packet( d_video ) ) break; // EOF? | |
1135 } | |
1136 if ( subcc_enabled ) | |
1137 ty_ClearOSD( 0 ); | |
1138 } | |
1139 | |
24443 | 1140 static int demux_ty_control( demuxer_t *demuxer,int cmd, void *arg ) |
10263 | 1141 { |
1142 demux_stream_t *d_video = demuxer->video; | |
1143 sh_video_t *sh_video = d_video->sh; | |
1144 | |
1145 switch(cmd) | |
1146 { | |
1147 case DEMUXER_CTRL_GET_TIME_LENGTH: | |
1148 if(!sh_video->i_bps) // unspecified or VBR | |
1149 return DEMUXER_CTRL_DONTKNOW; | |
24446 | 1150 *(double *)arg= |
1151 (double)demuxer->movi_end-demuxer->movi_start/sh_video->i_bps; | |
10263 | 1152 return DEMUXER_CTRL_GUESS; |
1153 | |
1154 case DEMUXER_CTRL_GET_PERCENT_POS: | |
1155 return DEMUXER_CTRL_DONTKNOW; | |
1156 default: | |
1157 return DEMUXER_CTRL_NOTIMPL; | |
1158 } | |
1159 } | |
1160 | |
1161 | |
17174
83a8c738be89
make demuxer seek and close functions return void, patch by Dominik Mierzejewski
wanderer
parents:
17012
diff
changeset
|
1162 static void demux_close_ty( demuxer_t *demux ) |
10263 | 1163 { |
1164 TiVoInfo *tivo = 0; | |
1165 | |
24446 | 1166 if ( demux->a_streams[ MAX_A_STREAMS - 1 ] != 0 ) |
10263 | 1167 { |
1168 tivo = demux->a_streams[ MAX_A_STREAMS - 1 ]; | |
1169 free( tivo ); | |
1170 demux->a_streams[ MAX_A_STREAMS - 1 ] = 0; | |
1171 sub_justify = 0; | |
1172 } | |
1173 } | |
1174 | |
1175 | |
16175 | 1176 static int ty_check_file(demuxer_t* demuxer) |
1177 { | |
1178 return ds_fill_buffer(demuxer->video) ? DEMUXER_TYPE_MPEG_TY : 0; | |
1179 } | |
1180 | |
1181 | |
1182 static demuxer_t* demux_open_ty(demuxer_t* demuxer) | |
1183 { | |
1184 sh_audio_t *sh_audio=NULL; | |
1185 sh_video_t *sh_video=NULL; | |
1186 | |
1187 sh_video=demuxer->video->sh;sh_video->ds=demuxer->video; | |
1188 | |
1189 if(demuxer->audio->id!=-2) { | |
1190 if(!ds_fill_buffer(demuxer->audio)){ | |
1191 mp_msg(MSGT_DEMUXER,MSGL_INFO,"MPEG: " MSGTR_MissingAudioStream); | |
1192 demuxer->audio->sh=NULL; | |
1193 } else { | |
1194 sh_audio=demuxer->audio->sh;sh_audio->ds=demuxer->audio; | |
1195 } | |
1196 } | |
1197 | |
1198 return demuxer; | |
1199 } | |
1200 | |
1201 | |
1202 demuxer_desc_t demuxer_desc_mpeg_ty = { | |
1203 "TiVo demuxer", | |
1204 "tivo", | |
1205 "TiVo", | |
1206 "Christopher R. Wingert", | |
1207 "Demux streams from TiVo", | |
1208 DEMUXER_TYPE_MPEG_TY, | |
1209 0, // unsafe autodetect | |
1210 ty_check_file, | |
1211 demux_ty_fill_buffer, | |
1212 demux_open_ty, | |
1213 demux_close_ty, | |
1214 demux_seek_ty, | |
1215 demux_ty_control | |
1216 }; |