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