Mercurial > mplayer.hg
annotate libmpdemux/open.c @ 5431:013458752947
disabling direct rendering by default (too buggy and conflicts with osd/sub)
author | arpi |
---|---|
date | Sun, 31 Mar 2002 20:38:56 +0000 |
parents | 9451df83c04b |
children | 4bd766a5632b |
rev | line source |
---|---|
1467 | 1 |
4343
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
2 #include <ctype.h> |
1467 | 3 #include <stdio.h> |
4 #include <stdlib.h> | |
5 #include <string.h> | |
6 #include <unistd.h> | |
7 #include <fcntl.h> | |
8 | |
9 #include "config.h" | |
1567 | 10 #include "mp_msg.h" |
1584 | 11 #include "help_mp.h" |
1467 | 12 |
1468 | 13 #ifdef __FreeBSD__ |
14 #include <sys/cdrio.h> | |
15 #endif | |
16 | |
4343
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
17 #include "../cfgparser.h" |
1467 | 18 #include "stream.h" |
1482 | 19 #include "demuxer.h" |
4551 | 20 #include "mf.h" |
1467 | 21 |
22 #ifdef STREAMING | |
23 #include "url.h" | |
24 #include "network.h" | |
25 static URL_t* url; | |
26 #endif | |
27 | |
1596 | 28 int dvd_title=0; |
29 int dvd_chapter=1; | |
4291
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
30 int dvd_last_chapter=0; |
1596 | 31 int dvd_angle=1; |
4222
de7eddb3fd70
Change to use cdrom-device and dvd-device options needed for DVD/TV/VCD
albeu
parents:
4146
diff
changeset
|
32 char* dvd_device=NULL; |
de7eddb3fd70
Change to use cdrom-device and dvd-device options needed for DVD/TV/VCD
albeu
parents:
4146
diff
changeset
|
33 char* cdrom_device=NULL; |
5380
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
34 int dvd_nav=0; |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
35 |
5381 | 36 #ifdef USE_DVDNAV |
5380
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
37 #include <dvdnav.h> |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
38 #endif |
1596 | 39 |
40 #ifdef USE_DVDREAD | |
41 | |
42 #include <dvdread/dvd_reader.h> | |
43 #include <dvdread/ifo_types.h> | |
44 #include <dvdread/ifo_read.h> | |
45 #include <dvdread/nav_read.h> | |
1875 | 46 |
47 #define DVDREAD_VERSION(maj,min,micro) ((maj)*10000 + (min)*100 + (micro)) | |
48 | |
49 /* | |
50 * Try to autodetect the libdvd-0.9.0 library | |
51 * (0.9.0 removed the <dvdread/dvd_udf.h> header, and moved the two defines | |
52 * DVD_VIDEO_LB_LEN and MAX_UDF_FILE_NAME_LEN from it to | |
53 * <dvdread/dvd_reader.h>) | |
54 */ | |
55 #if defined(DVD_VIDEO_LB_LEN) && defined(MAX_UDF_FILE_NAME_LEN) | |
56 #define LIBDVDREAD_VERSION DVDREAD_VERSION(0,9,0) | |
57 #else | |
58 #define LIBDVDREAD_VERSION DVDREAD_VERSION(0,8,0) | |
59 #endif | |
60 | |
2935 | 61 char * dvd_audio_stream_types[8] = |
62 { "ac3","unknown","mpeg1","mpeg2ext","lpcm","unknown","dts" }; | |
1596 | 63 |
64 #endif | |
65 | |
1467 | 66 extern int vcd_get_track_end(int fd,int track); |
67 | |
2790 | 68 #ifdef USE_TV |
69 #include "tv.h" | |
2802 | 70 tvi_handle_t *tv_handler; |
2931 | 71 |
72 extern int stream_open_tv(stream_t *stream, tvi_handle_t *tvh); | |
2790 | 73 #endif |
74 | |
1467 | 75 // Open a new stream (stdin/file/vcd/url) |
76 | |
77 stream_t* open_stream(char* filename,int vcd_track,int* file_format){ | |
78 stream_t* stream=NULL; | |
79 int f=-1; | |
80 off_t len; | |
81 #ifdef VCD_CACHE | |
82 int vcd_cache_size=128; | |
83 #endif | |
84 #ifdef __FreeBSD__ | |
85 int bsize = VCD_SECTOR_SIZE; | |
86 #endif | |
87 | |
88 //============ Open VideoCD track ============== | |
3261 | 89 #ifdef HAVE_VCD |
1467 | 90 if(vcd_track){ |
91 int ret,ret2; | |
4222
de7eddb3fd70
Change to use cdrom-device and dvd-device options needed for DVD/TV/VCD
albeu
parents:
4146
diff
changeset
|
92 if(!cdrom_device) cdrom_device=DEFAULT_CDROM_DEVICE; |
de7eddb3fd70
Change to use cdrom-device and dvd-device options needed for DVD/TV/VCD
albeu
parents:
4146
diff
changeset
|
93 f=open(cdrom_device,O_RDONLY); |
de7eddb3fd70
Change to use cdrom-device and dvd-device options needed for DVD/TV/VCD
albeu
parents:
4146
diff
changeset
|
94 if(f<0){ mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_CdDevNotfound,cdrom_device);return NULL; } |
1467 | 95 vcd_read_toc(f); |
96 ret2=vcd_get_track_end(f,vcd_track); | |
1584 | 97 if(ret2<0){ mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_ErrTrackSelect " (get)\n");return NULL;} |
1467 | 98 ret=vcd_seek_to_track(f,vcd_track); |
1584 | 99 if(ret<0){ mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_ErrTrackSelect " (seek)\n");return NULL;} |
1467 | 100 // seek_to_byte+=ret; |
1567 | 101 mp_msg(MSGT_OPEN,MSGL_V,"VCD start byte position: 0x%X end: 0x%X\n",ret,ret2); |
1467 | 102 #ifdef VCD_CACHE |
103 vcd_cache_init(vcd_cache_size); | |
104 #endif | |
105 #ifdef __FreeBSD__ | |
106 if (ioctl (f, CDRIOCSETBLOCKSIZE, &bsize) == -1) { | |
107 perror ( "Error in CDRIOCSETBLOCKSIZE"); | |
108 } | |
109 #endif | |
110 stream=new_stream(f,STREAMTYPE_VCD); | |
111 stream->start_pos=ret; | |
112 stream->end_pos=ret2; | |
113 return stream; | |
114 } | |
3261 | 115 #endif |
1467 | 116 |
1596 | 117 //============ Open DVD title ============== |
5380
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
118 #ifdef USE_DVDNAV |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
119 if(dvd_nav){ |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
120 dvdnav_t *dvdnav; |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
121 int event,len,tmplen=0; |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
122 if(!filename) filename=DEFAULT_DVD_DEVICE; |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
123 if(dvdnav_open(&dvdnav,filename)!=DVDNAV_STATUS_OK) { |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
124 mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_CantOpenDVD,filename); |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
125 return NULL; |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
126 } |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
127 |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
128 stream=new_stream(-1,STREAMTYPE_DVDNAV); |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
129 if (!stream) { |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
130 mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_Exit_error); |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
131 return NULL; |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
132 } |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
133 stream->priv=(void*)dvdnav; |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
134 return stream; |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
135 } |
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
136 #endif |
1596 | 137 #ifdef USE_DVDREAD |
138 if(dvd_title){ | |
2050 | 139 // int ret,ret2; |
5380
8a01cde9cf39
DVDnav support patch by David Holm and Kees Cook <mplayer@outflux.net>
arpi
parents:
4729
diff
changeset
|
140 dvd_priv_t *d; |
1596 | 141 int ttn,pgc_id,pgn; |
142 dvd_reader_t *dvd; | |
143 dvd_file_t *title; | |
144 ifo_handle_t *vmg_file; | |
145 tt_srpt_t *tt_srpt; | |
146 ifo_handle_t *vts_file; | |
147 /** | |
148 * Open the disc. | |
149 */ | |
4222
de7eddb3fd70
Change to use cdrom-device and dvd-device options needed for DVD/TV/VCD
albeu
parents:
4146
diff
changeset
|
150 if(!dvd_device) dvd_device=DEFAULT_DVD_DEVICE; |
de7eddb3fd70
Change to use cdrom-device and dvd-device options needed for DVD/TV/VCD
albeu
parents:
4146
diff
changeset
|
151 dvd = DVDOpen(dvd_device); |
1596 | 152 if( !dvd ) { |
4222
de7eddb3fd70
Change to use cdrom-device and dvd-device options needed for DVD/TV/VCD
albeu
parents:
4146
diff
changeset
|
153 mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_CantOpenDVD,dvd_device); |
1596 | 154 return NULL; |
155 } | |
156 | |
1973
5216f108cb4f
all error/warn/info messages moved to help_mp-en.h for translation
arpi
parents:
1899
diff
changeset
|
157 mp_msg(MSGT_OPEN,MSGL_INFO,MSGTR_DVDwait); |
1596 | 158 |
159 /** | |
160 * Load the video manager to find out the information about the titles on | |
161 * this disc. | |
162 */ | |
163 vmg_file = ifoOpen( dvd, 0 ); | |
164 if( !vmg_file ) { | |
165 mp_msg(MSGT_OPEN,MSGL_ERR, "Can't open VMG info!\n"); | |
166 DVDClose( dvd ); | |
167 return NULL; | |
168 } | |
169 tt_srpt = vmg_file->tt_srpt; | |
170 /** | |
171 * Make sure our title number is valid. | |
172 */ | |
1973
5216f108cb4f
all error/warn/info messages moved to help_mp-en.h for translation
arpi
parents:
1899
diff
changeset
|
173 mp_msg(MSGT_OPEN,MSGL_INFO, MSGTR_DVDnumTitles, |
1596 | 174 tt_srpt->nr_of_srpts ); |
175 if( dvd_title < 1 || dvd_title > tt_srpt->nr_of_srpts ) { | |
1973
5216f108cb4f
all error/warn/info messages moved to help_mp-en.h for translation
arpi
parents:
1899
diff
changeset
|
176 mp_msg(MSGT_OPEN,MSGL_ERR, MSGTR_DVDinvalidTitle, dvd_title); |
1596 | 177 ifoClose( vmg_file ); |
178 DVDClose( dvd ); | |
179 return NULL; | |
180 } | |
181 --dvd_title; // remap 1.. -> 0.. | |
182 /** | |
183 * Make sure the chapter number is valid for this title. | |
184 */ | |
1973
5216f108cb4f
all error/warn/info messages moved to help_mp-en.h for translation
arpi
parents:
1899
diff
changeset
|
185 mp_msg(MSGT_OPEN,MSGL_INFO, MSGTR_DVDnumChapters, |
1596 | 186 tt_srpt->title[dvd_title].nr_of_ptts ); |
187 if( dvd_chapter<1 || dvd_chapter>tt_srpt->title[dvd_title].nr_of_ptts ) { | |
1973
5216f108cb4f
all error/warn/info messages moved to help_mp-en.h for translation
arpi
parents:
1899
diff
changeset
|
188 mp_msg(MSGT_OPEN,MSGL_ERR, MSGTR_DVDinvalidChapter, dvd_chapter); |
1596 | 189 ifoClose( vmg_file ); |
190 DVDClose( dvd ); | |
191 return NULL; | |
192 } | |
4291
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
193 if( dvd_last_chapter>0 ) { |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
194 if ( dvd_last_chapter<dvd_chapter || dvd_last_chapter>tt_srpt->title[dvd_title].nr_of_ptts ) { |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
195 mp_msg(MSGT_OPEN,MSGL_ERR, "Invalid DVD last chapter number: %d\n", dvd_last_chapter); |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
196 ifoClose( vmg_file ); |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
197 DVDClose( dvd ); |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
198 return NULL; |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
199 } |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
200 } |
1596 | 201 --dvd_chapter; // remap 1.. -> 0.. |
4291
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
202 /* XXX No need to remap dvd_last_chapter */ |
1596 | 203 /** |
204 * Make sure the angle number is valid for this title. | |
205 */ | |
1973
5216f108cb4f
all error/warn/info messages moved to help_mp-en.h for translation
arpi
parents:
1899
diff
changeset
|
206 mp_msg(MSGT_OPEN,MSGL_INFO, MSGTR_DVDnumAngles, |
1596 | 207 tt_srpt->title[dvd_title].nr_of_angles ); |
208 if( dvd_angle<1 || dvd_angle>tt_srpt->title[dvd_title].nr_of_angles ) { | |
1977 | 209 mp_msg(MSGT_OPEN,MSGL_ERR, MSGTR_DVDinvalidAngle, dvd_angle); |
1596 | 210 ifoClose( vmg_file ); |
211 DVDClose( dvd ); | |
212 return NULL; | |
213 } | |
1617 | 214 --dvd_angle; // remap 1.. -> 0.. |
1596 | 215 /** |
216 * Load the VTS information for the title set our title is in. | |
217 */ | |
218 vts_file = ifoOpen( dvd, tt_srpt->title[dvd_title].title_set_nr ); | |
219 if( !vts_file ) { | |
1973
5216f108cb4f
all error/warn/info messages moved to help_mp-en.h for translation
arpi
parents:
1899
diff
changeset
|
220 mp_msg(MSGT_OPEN,MSGL_ERR, MSGTR_DVDnoIFO, |
1596 | 221 tt_srpt->title[dvd_title].title_set_nr ); |
222 ifoClose( vmg_file ); | |
223 DVDClose( dvd ); | |
224 return NULL; | |
225 } | |
226 /** | |
227 * We've got enough info, time to open the title set data. | |
228 */ | |
229 title = DVDOpenFile( dvd, tt_srpt->title[dvd_title].title_set_nr, | |
230 DVD_READ_TITLE_VOBS ); | |
231 if( !title ) { | |
1973
5216f108cb4f
all error/warn/info messages moved to help_mp-en.h for translation
arpi
parents:
1899
diff
changeset
|
232 mp_msg(MSGT_OPEN,MSGL_ERR, MSGTR_DVDnoVOBs, |
1596 | 233 tt_srpt->title[dvd_title].title_set_nr ); |
234 ifoClose( vts_file ); | |
235 ifoClose( vmg_file ); | |
236 DVDClose( dvd ); | |
237 return NULL; | |
238 } | |
239 | |
1973
5216f108cb4f
all error/warn/info messages moved to help_mp-en.h for translation
arpi
parents:
1899
diff
changeset
|
240 mp_msg(MSGT_OPEN,MSGL_INFO, MSGTR_DVDopenOk); |
1596 | 241 // store data |
242 d=malloc(sizeof(dvd_priv_t)); memset(d,0,sizeof(dvd_priv_t)); | |
243 d->dvd=dvd; | |
244 d->title=title; | |
245 d->vmg_file=vmg_file; | |
246 d->tt_srpt=tt_srpt; | |
247 d->vts_file=vts_file; | |
248 | |
249 /** | |
2935 | 250 * Check number of audio channels and types |
251 */ | |
252 { | |
253 int ac3aid = 128; | |
254 int mpegaid = 0; | |
255 int pcmaid = 160; | |
256 | |
257 d->nr_of_channels=0; | |
258 | |
259 if ( vts_file->vts_pgcit ) | |
260 { | |
261 int i; | |
262 for ( i=0;i<8;i++ ) | |
263 if ( vts_file->vts_pgcit->pgci_srp[0].pgc->audio_control[i] & 0x8000 ) | |
264 { | |
265 audio_attr_t * audio = &vts_file->vtsi_mat->vts_audio_attr[i]; | |
266 int language = 0; | |
267 char tmp[] = "unknown"; | |
268 | |
269 if ( audio->lang_type == 1 ) | |
270 { | |
271 language=audio->lang_code; | |
272 tmp[0]=language>>8; | |
273 tmp[1]=language&0xff; | |
274 tmp[2]=0; | |
275 } | |
276 | |
277 d->audio_streams[d->nr_of_channels].language=language; | |
278 d->audio_streams[d->nr_of_channels].id=0; | |
279 switch ( audio->audio_format ) | |
280 { | |
281 case 0: // ac3 | |
282 case 6: // dts | |
283 d->audio_streams[d->nr_of_channels].id=ac3aid; | |
284 ac3aid++; | |
285 break; | |
286 case 2: // mpeg layer 1/2/3 | |
287 case 3: // mpeg2 ext | |
288 d->audio_streams[d->nr_of_channels].id=mpegaid; | |
289 mpegaid++; | |
290 break; | |
291 case 4: // lpcm | |
292 d->audio_streams[d->nr_of_channels].id=pcmaid; | |
293 pcmaid++; | |
294 break; | |
295 } | |
296 | |
297 mp_msg(MSGT_OPEN,MSGL_V,"[open] audio stream: %d audio format: %s language: %s aid: %d\n", | |
298 d->nr_of_channels, | |
299 dvd_audio_stream_types[ audio->audio_format ], | |
300 tmp, | |
301 d->audio_streams[d->nr_of_channels].id | |
302 ); | |
3753 | 303 |
2935 | 304 d->nr_of_channels++; |
305 } | |
306 } | |
3048 | 307 mp_msg(MSGT_OPEN,MSGL_V,"[open] number of audio channels on disk: %d.\n",d->nr_of_channels ); |
308 } | |
309 | |
310 /** | |
311 * Check number of subtitles and language | |
312 */ | |
313 { | |
314 int i; | |
315 | |
316 d->nr_of_subtitles=0; | |
317 for ( i=0;i<32;i++ ) | |
318 if ( vts_file->vts_pgcit->pgci_srp[0].pgc->subp_control[i] & 0x80000000 ) | |
319 { | |
320 subp_attr_t * subtitle = &vts_file->vtsi_mat->vts_subp_attr[i]; | |
321 int language = 0; | |
322 char tmp[] = "unknown"; | |
323 | |
324 if ( subtitle->type == 1 ) | |
325 { | |
326 language=subtitle->lang_code; | |
327 tmp[0]=language>>8; | |
328 tmp[1]=language&0xff; | |
329 tmp[2]=0; | |
330 } | |
331 | |
332 d->subtitles[ d->nr_of_subtitles ].language=language; | |
333 d->subtitles[ d->nr_of_subtitles ].id=d->nr_of_subtitles; | |
334 | |
335 mp_msg(MSGT_OPEN,MSGL_V,"[open] subtitle ( sid ): %d language: %s\n", | |
336 d->nr_of_subtitles, | |
337 tmp | |
338 ); | |
339 d->nr_of_subtitles++; | |
340 } | |
341 mp_msg(MSGT_OPEN,MSGL_V,"[open] number of subtitles on disk: %d\n",d->nr_of_subtitles ); | |
2935 | 342 } |
343 | |
344 /** | |
1596 | 345 * Determine which program chain we want to watch. This is based on the |
346 * chapter number. | |
347 */ | |
348 ttn = tt_srpt->title[ dvd_title ].vts_ttn; // local | |
349 pgc_id = vts_file->vts_ptt_srpt->title[ttn-1].ptt[dvd_chapter].pgcn; // local | |
350 pgn = vts_file->vts_ptt_srpt->title[ttn-1].ptt[dvd_chapter].pgn; // local | |
351 d->cur_pgc = vts_file->vts_pgcit->pgci_srp[pgc_id-1].pgc; | |
352 d->cur_cell = d->cur_pgc->program_map[pgn-1] - 1; // start playback here | |
353 d->packs_left=-1; // for Navi stuff | |
1609
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
354 d->angle_seek=0; |
4291
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
355 /* XXX dvd_last_chapter is in the range 1..nr_of_ptts */ |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
356 if ( dvd_last_chapter > 0 && dvd_last_chapter < tt_srpt->title[ttn-1].nr_of_ptts ) { |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
357 pgn=vts_file->vts_ptt_srpt->title[ttn-1].ptt[dvd_last_chapter].pgn; |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
358 d->last_cell=d->cur_pgc->program_map[pgn-1] - 1; |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
359 } |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
360 else |
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
361 d->last_cell=d->cur_pgc->nr_of_cells; |
1596 | 362 |
363 if( d->cur_pgc->cell_playback[d->cur_cell].block_type | |
364 == BLOCK_TYPE_ANGLE_BLOCK ) d->cur_cell+=dvd_angle; | |
365 d->cur_pack = d->cur_pgc->cell_playback[ d->cur_cell ].first_sector; | |
366 d->cell_last_pack=d->cur_pgc->cell_playback[ d->cur_cell ].last_sector; | |
367 mp_msg(MSGT_DVD,MSGL_V, "DVD start cell: %d pack: 0x%X-0x%X \n",d->cur_cell,d->cur_pack,d->cell_last_pack); | |
368 | |
369 // ... (unimplemented) | |
370 // return NULL; | |
371 stream=new_stream(-1,STREAMTYPE_DVD); | |
372 stream->start_pos=(off_t)d->cur_pack*2048; | |
4390 | 373 stream->end_pos=(off_t)(d->cur_pgc->cell_playback[d->last_cell-1].last_sector)*2048; |
374 printf("DVD start=%d end=%d \n",d->cur_pack,d->cur_pgc->cell_playback[d->last_cell-1].last_sector); | |
1596 | 375 stream->priv=(void*)d; |
376 return stream; | |
377 } | |
378 #endif | |
379 | |
2790 | 380 #ifdef USE_TV |
381 //============ Check for TV-input ==== | |
2931 | 382 if (tv_param_on == 1) |
2790 | 383 { |
2931 | 384 /* create stream */ |
385 stream = new_stream(-1, STREAMTYPE_TV); | |
386 if (!stream) | |
387 return(NULL); | |
388 | |
389 /* create tvi handler */ | |
2790 | 390 tv_handler = tv_begin(); |
391 if (!tv_handler) | |
392 return(NULL); | |
2931 | 393 |
394 /* preinit */ | |
395 if (!tv_init(tv_handler)) | |
396 goto tv_err; | |
397 | |
398 if (!stream_open_tv(stream, tv_handler)) | |
399 goto tv_err; | |
400 | |
401 return(stream); | |
402 | |
403 /* something went wrong - uninit */ | |
404 tv_err: | |
2837 | 405 tv_uninit(tv_handler); |
2802 | 406 return(NULL); |
2790 | 407 } |
408 #endif | |
409 | |
4551 | 410 //============ Check for multi file-input ==== |
411 if (mf_support == 1) | |
412 { | |
413 /* create stream */ | |
414 stream = new_stream(-1, STREAMTYPE_MF); | |
415 if (!stream) | |
416 return(NULL); | |
417 | |
418 if (!stream_open_mf(filename, stream)) | |
419 return(NULL); | |
420 | |
421 return(stream); | |
422 } | |
423 | |
1467 | 424 //============ Open STDIN ============ |
425 if(!strcmp(filename,"-")){ | |
426 // read from stdin | |
1584 | 427 mp_msg(MSGT_OPEN,MSGL_INFO,MSGTR_ReadSTDIN); |
1467 | 428 f=0; // 0=stdin |
429 stream=new_stream(f,STREAMTYPE_STREAM); | |
430 return stream; | |
431 } | |
432 | |
433 #ifdef STREAMING | |
434 url = url_new(filename); | |
435 if(url) { | |
4251
05affdf4bdcd
Moved network related code from open.c to network.c
bertrand
parents:
4222
diff
changeset
|
436 stream=new_stream(f,STREAMTYPE_STREAM); |
4729
f51bd827ed1c
fixed MP3 ICY detection, return detected file format for open_stream
alex
parents:
4551
diff
changeset
|
437 if( streaming_start( stream, file_format, url )<0){ |
4251
05affdf4bdcd
Moved network related code from open.c to network.c
bertrand
parents:
4222
diff
changeset
|
438 mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_UnableOpenURL, filename); |
05affdf4bdcd
Moved network related code from open.c to network.c
bertrand
parents:
4222
diff
changeset
|
439 url_free(url); |
05affdf4bdcd
Moved network related code from open.c to network.c
bertrand
parents:
4222
diff
changeset
|
440 return NULL; |
4046
f732854e3d16
Kept the HTTP connection open after autodetect, so
bertrand
parents:
3753
diff
changeset
|
441 } |
1584 | 442 mp_msg(MSGT_OPEN,MSGL_INFO,MSGTR_ConnToServer, url->hostname ); |
3045
6c14fd789ba5
Changed the order of processing the network opening.
bertrand
parents:
2935
diff
changeset
|
443 url_free(url); |
2315 | 444 return stream; |
1467 | 445 } |
446 #endif | |
447 | |
448 //============ Open plain FILE ============ | |
449 f=open(filename,O_RDONLY); | |
1584 | 450 if(f<0){ mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_FileNotFound,filename);return NULL; } |
1467 | 451 len=lseek(f,0,SEEK_END); lseek(f,0,SEEK_SET); |
452 if (len == -1) | |
453 perror("Error: lseek failed to obtain video file size"); | |
454 else | |
455 #ifdef _LARGEFILE_SOURCE | |
1567 | 456 mp_msg(MSGT_OPEN,MSGL_V,"File size is %lld bytes\n", (long long)len); |
1467 | 457 #else |
1567 | 458 mp_msg(MSGT_OPEN,MSGL_V,"File size is %u bytes\n", (unsigned int)len); |
1467 | 459 #endif |
460 stream=new_stream(f,STREAMTYPE_FILE); | |
461 stream->end_pos=len; | |
462 return stream; | |
463 | |
464 } | |
1596 | 465 |
4343
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
466 int dvd_parse_chapter_range(struct config *conf, const char *range){ |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
467 char *s, *t; |
4344 | 468 conf; /* prevent warning from GCC */ |
469 s = range; | |
4343
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
470 dvd_chapter = 1; |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
471 dvd_last_chapter = 0; |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
472 if (*range && isdigit(*range)) { |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
473 dvd_chapter = strtol(range, &s, 10); |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
474 if (range == s) { |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
475 mp_msg(MSGT_OPEN, MSGL_ERR, "Invalid chapter range specification %s\n", range); |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
476 return -1; |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
477 } |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
478 } |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
479 if (*s == 0) |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
480 return 0; |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
481 else if (*s != '-') { |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
482 mp_msg(MSGT_OPEN, MSGL_ERR, "Invalid chapter range specification %s\n", range); |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
483 return -1; |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
484 } |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
485 ++s; |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
486 if (*s == 0) |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
487 return 0; |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
488 if (! isdigit(*s)) { |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
489 mp_msg(MSGT_OPEN, MSGL_ERR, "Invalid chapter range specification %s\n", range); |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
490 return -1; |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
491 } |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
492 dvd_last_chapter = strtol(s, &t, 10); |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
493 if (s == t || *t) { |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
494 mp_msg(MSGT_OPEN, MSGL_ERR, "Invalid chapter range specification %s\n", range); |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
495 return -1; |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
496 } |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
497 return 0; |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
498 } |
b0c8eed7473c
Extended DVD chapter specification. Remove -last-chapter option.
kmkaplan
parents:
4291
diff
changeset
|
499 |
3753 | 500 #ifdef USE_DVDREAD |
1596 | 501 |
3753 | 502 int dvd_aid_from_lang(stream_t *stream, unsigned char* lang){ |
503 dvd_priv_t *d=stream->priv; | |
504 int code,i; | |
505 while(lang && strlen(lang)>=2){ | |
506 code=lang[1]|(lang[0]<<8); | |
507 for(i=0;i<d->nr_of_channels;i++){ | |
508 if(d->audio_streams[i].language==code){ | |
509 mp_msg(MSGT_OPEN,MSGL_INFO,"Selected DVD audio channel: %d language: %c%c\n", | |
510 d->audio_streams[i].id, lang[0],lang[1]); | |
511 return d->audio_streams[i].id; | |
512 } | |
513 // printf("%X != %X (%c%c)\n",code,d->audio_streams[i].language,lang[0],lang[1]); | |
514 } | |
515 lang+=2; while (lang[0]==',' || lang[0]==' ') ++lang; | |
516 } | |
517 mp_msg(MSGT_OPEN,MSGL_INFO,"No matching DVD audio language found!\n"); | |
518 return -1; | |
519 } | |
520 | |
521 int dvd_sid_from_lang(stream_t *stream, unsigned char* lang){ | |
522 dvd_priv_t *d=stream->priv; | |
523 int code,i; | |
524 while(lang && strlen(lang)>=2){ | |
525 code=lang[1]|(lang[0]<<8); | |
526 for(i=0;i<d->nr_of_subtitles;i++){ | |
527 if(d->subtitles[i].language==code){ | |
528 mp_msg(MSGT_OPEN,MSGL_INFO,"Selected DVD subtitle channel: %d language: %c%c\n", | |
529 d->subtitles[i].id, lang[0],lang[1]); | |
530 return d->subtitles[i].id; | |
531 } | |
532 } | |
533 lang+=2; while (lang[0]==',' || lang[0]==' ') ++lang; | |
534 } | |
535 mp_msg(MSGT_OPEN,MSGL_INFO,"No matching DVD subtitle language found!\n"); | |
536 return -1; | |
537 } | |
1596 | 538 |
539 static int dvd_next_cell(dvd_priv_t *d){ | |
540 int next_cell=d->cur_cell; | |
1616 | 541 |
542 mp_msg(MSGT_DVD,MSGL_V, "dvd_next_cell: next1=0x%X \n",next_cell); | |
1596 | 543 |
544 if( d->cur_pgc->cell_playback[ next_cell ].block_type | |
545 == BLOCK_TYPE_ANGLE_BLOCK ) { | |
4291
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
546 while(next_cell<d->last_cell){ |
1596 | 547 if( d->cur_pgc->cell_playback[next_cell].block_mode |
548 == BLOCK_MODE_LAST_CELL ) break; | |
549 ++next_cell; | |
550 } | |
551 } | |
1616 | 552 mp_msg(MSGT_DVD,MSGL_V, "dvd_next_cell: next2=0x%X \n",next_cell); |
1596 | 553 |
554 ++next_cell; | |
4291
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
555 if(next_cell>=d->last_cell) return -1; // EOF |
1596 | 556 if( d->cur_pgc->cell_playback[next_cell].block_type == BLOCK_TYPE_ANGLE_BLOCK ){ |
557 next_cell+=dvd_angle; | |
4291
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4251
diff
changeset
|
558 if(next_cell>=d->last_cell) return -1; // EOF |
1596 | 559 } |
1616 | 560 mp_msg(MSGT_DVD,MSGL_V, "dvd_next_cell: next3=0x%X \n",next_cell); |
1596 | 561 return next_cell; |
562 } | |
563 | |
564 int dvd_read_sector(dvd_priv_t *d,unsigned char* data){ | |
565 int len; | |
566 | |
567 if(d->packs_left==0){ | |
568 /** | |
569 * If we're not at the end of this cell, we can determine the next | |
570 * VOBU to display using the VOBU_SRI information section of the | |
571 * DSI. Using this value correctly follows the current angle, | |
572 * avoiding the doubled scenes in The Matrix, and makes our life | |
573 * really happy. | |
574 * | |
575 * Otherwise, we set our next address past the end of this cell to | |
576 * force the code above to go to the next cell in the program. | |
577 */ | |
578 if( d->dsi_pack.vobu_sri.next_vobu != SRI_END_OF_CELL ) { | |
579 d->cur_pack= d->dsi_pack.dsi_gi.nv_pck_lbn + | |
580 ( d->dsi_pack.vobu_sri.next_vobu & 0x7fffffff ); | |
581 mp_msg(MSGT_DVD,MSGL_DBG2, "Navi new pos=0x%X \n",d->cur_pack); | |
582 } else { | |
583 // end of cell! find next cell! | |
584 mp_msg(MSGT_DVD,MSGL_V, "--- END OF CELL !!! ---\n"); | |
585 d->cur_pack=d->cell_last_pack+1; | |
586 } | |
587 } | |
588 | |
589 read_next: | |
590 | |
591 if(d->cur_pack>d->cell_last_pack){ | |
592 // end of cell! | |
593 int next=dvd_next_cell(d); | |
594 if(next>=0){ | |
595 d->cur_cell=next; | |
596 | |
1615 | 597 // if( d->cur_pgc->cell_playback[d->cur_cell].block_type |
598 // == BLOCK_TYPE_ANGLE_BLOCK ) d->cur_cell+=dvd_angle; | |
1596 | 599 d->cur_pack = d->cur_pgc->cell_playback[ d->cur_cell ].first_sector; |
600 d->cell_last_pack=d->cur_pgc->cell_playback[ d->cur_cell ].last_sector; | |
601 mp_msg(MSGT_DVD,MSGL_V, "DVD next cell: %d pack: 0x%X-0x%X \n",d->cur_cell,d->cur_pack,d->cell_last_pack); | |
602 | |
603 } else return -1; // EOF | |
604 } | |
605 | |
606 len = DVDReadBlocks( d->title, d->cur_pack, 1, data ); | |
607 if(!len) return -1; //error | |
608 | |
609 if(data[38]==0 && data[39]==0 && data[40]==1 && data[41]==0xBF && | |
610 data[1024]==0 && data[1025]==0 && data[1026]==1 && data[1027]==0xBF){ | |
611 // found a Navi packet!!! | |
1875 | 612 #if LIBDVDREAD_VERSION >= DVDREAD_VERSION(0,9,0) |
613 navRead_DSI( &d->dsi_pack, &(data[ DSI_START_BYTE ]) ); | |
614 #else | |
1596 | 615 navRead_DSI( &d->dsi_pack, &(data[ DSI_START_BYTE ]), sizeof(dsi_t) ); |
1875 | 616 #endif |
1596 | 617 if(d->cur_pack != d->dsi_pack.dsi_gi.nv_pck_lbn ){ |
618 mp_msg(MSGT_DVD,MSGL_V, "Invalid NAVI packet! lba=0x%X navi=0x%X \n", | |
619 d->cur_pack,d->dsi_pack.dsi_gi.nv_pck_lbn); | |
620 } else { | |
621 // process! | |
622 d->packs_left = d->dsi_pack.dsi_gi.vobu_ea; | |
623 mp_msg(MSGT_DVD,MSGL_DBG2, "Found NAVI packet! lba=0x%X len=%d \n",d->cur_pack,d->packs_left); | |
1609
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
624 if(d->angle_seek){ |
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
625 int skip=d->dsi_pack.sml_agli.data[dvd_angle].address; |
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
626 if(skip) d->cur_pack=d->dsi_pack.dsi_gi.nv_pck_lbn+skip; |
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
627 d->angle_seek=0; |
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
628 mp_msg(MSGT_DVD,MSGL_V, "Angle-seek synced! skip=%d new_lba=0x%X \n",skip,d->cur_pack); |
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
629 } |
1596 | 630 } |
631 ++d->cur_pack; | |
632 goto read_next; | |
633 } | |
634 | |
635 ++d->cur_pack; | |
636 if(d->packs_left>=0) --d->packs_left; | |
1609
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
637 |
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
638 if(d->angle_seek) goto read_next; // searching for Navi packet |
1596 | 639 |
640 return d->cur_pack-1; | |
641 } | |
642 | |
643 void dvd_seek(dvd_priv_t *d,int pos){ | |
644 d->packs_left=-1; | |
645 d->cur_pack=pos; | |
646 | |
647 // check if we stay in current cell (speedup things, and avoid angle skip) | |
1609
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
648 if(d->cur_pack>d->cell_last_pack || |
1596 | 649 d->cur_pack<d->cur_pgc->cell_playback[ d->cur_cell ].first_sector){ |
650 | |
651 // ok, cell change, find the right cell! | |
652 d->cur_cell=0; | |
653 if( d->cur_pgc->cell_playback[d->cur_cell].block_type | |
654 == BLOCK_TYPE_ANGLE_BLOCK ) d->cur_cell+=dvd_angle; | |
655 | |
656 while(1){ | |
657 int next; | |
658 d->cell_last_pack=d->cur_pgc->cell_playback[ d->cur_cell ].last_sector; | |
659 if(d->cur_pack<d->cur_pgc->cell_playback[ d->cur_cell ].first_sector){ | |
660 d->cur_pack=d->cur_pgc->cell_playback[ d->cur_cell ].first_sector; | |
661 break; | |
662 } | |
663 if(d->cur_pack<=d->cell_last_pack) break; // ok, we find it! :) | |
664 next=dvd_next_cell(d); | |
665 if(next<0){ | |
666 // d->cur_pack=d->cell_last_pack+1; | |
667 break; // we're after the last cell | |
668 } | |
669 d->cur_cell=next; | |
670 } | |
1609
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
671 |
1596 | 672 } |
673 | |
674 mp_msg(MSGT_DVD,MSGL_V, "DVD Seek! lba=0x%X cell=%d packs: 0x%X-0x%X \n", | |
675 d->cur_pack,d->cur_cell,d->cur_pgc->cell_playback[ d->cur_cell ].first_sector,d->cell_last_pack); | |
676 | |
1609
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
677 // if we're in interleaved multi-angle cell, find the right angle chain! |
1596 | 678 // (read Navi block, and use the seamless angle jump table) |
1609
84199d075839
ugly seeking bug fixed, correct multiangle seek implemented
arpi
parents:
1596
diff
changeset
|
679 d->angle_seek=1; |
1596 | 680 |
681 } | |
682 | |
683 #endif |