annotate open.c @ 1596:fc0e9953bc2d

libDVDread support
author arpi
date Mon, 20 Aug 2001 21:20:03 +0000
parents e49b3927c793
children 84199d075839
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
1
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
2 #include <stdio.h>
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
3 #include <stdlib.h>
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
4 #include <string.h>
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
5 #include <unistd.h>
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
6 #include <fcntl.h>
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
7
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
8 #include "config.h"
1567
5c7760aa4f94 printf->mp_msg/mp_dbg
arpi
parents: 1482
diff changeset
9 #include "mp_msg.h"
1584
e49b3927c793 more messages for translator :)
arpi
parents: 1567
diff changeset
10 #include "help_mp.h"
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
11
1468
fbed9c34069c freebsd fix
arpi
parents: 1467
diff changeset
12 #ifdef __FreeBSD__
fbed9c34069c freebsd fix
arpi
parents: 1467
diff changeset
13 #include <sys/cdrio.h>
fbed9c34069c freebsd fix
arpi
parents: 1467
diff changeset
14 #endif
fbed9c34069c freebsd fix
arpi
parents: 1467
diff changeset
15
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
16 #include "stream.h"
1482
4800d1c58dab --enable-streaming fix
arpi
parents: 1468
diff changeset
17 #include "demuxer.h"
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
18
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
19 #ifdef STREAMING
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
20 #include "url.h"
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
21 #include "network.h"
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
22 static URL_t* url;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
23 #endif
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
24
1596
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
25 int dvd_title=0;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
26 int dvd_chapter=1;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
27 int dvd_angle=1;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
28
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
29 #ifdef USE_DVDREAD
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
30
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
31 #include <dvdread/dvd_reader.h>
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
32 #include <dvdread/ifo_types.h>
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
33 #include <dvdread/ifo_read.h>
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
34 #include <dvdread/dvd_udf.h>
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
35 #include <dvdread/nav_read.h>
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
36 //#include <dvdread/nav_print.h>
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
37
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
38 typedef struct {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
39 dvd_reader_t *dvd;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
40 dvd_file_t *title;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
41 ifo_handle_t *vmg_file;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
42 tt_srpt_t *tt_srpt;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
43 ifo_handle_t *vts_file;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
44 vts_ptt_srpt_t *vts_ptt_srpt;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
45 pgc_t *cur_pgc;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
46 //
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
47 int cur_cell;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
48 int cur_pack;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
49 int cell_last_pack;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
50 // Navi:
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
51 int packs_left;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
52 dsi_t dsi_pack;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
53 } dvd_priv_t;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
54
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
55 #endif
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
56
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
57 extern int vcd_get_track_end(int fd,int track);
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
58
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
59 // Open a new stream (stdin/file/vcd/url)
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
60
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
61 stream_t* open_stream(char* filename,int vcd_track,int* file_format){
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
62 stream_t* stream=NULL;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
63 int f=-1;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
64 off_t len;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
65 #ifdef VCD_CACHE
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
66 int vcd_cache_size=128;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
67 #endif
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
68 #ifdef __FreeBSD__
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
69 int bsize = VCD_SECTOR_SIZE;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
70 #endif
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
71
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
72 //============ Open VideoCD track ==============
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
73 if(vcd_track){
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
74 int ret,ret2;
1596
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
75 if(!filename) filename=DEFAULT_CDROM_DEVICE;
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
76 f=open(filename,O_RDONLY);
1584
e49b3927c793 more messages for translator :)
arpi
parents: 1567
diff changeset
77 if(f<0){ mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_CdDevNotfound,filename);return NULL; }
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
78 vcd_read_toc(f);
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
79 ret2=vcd_get_track_end(f,vcd_track);
1584
e49b3927c793 more messages for translator :)
arpi
parents: 1567
diff changeset
80 if(ret2<0){ mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_ErrTrackSelect " (get)\n");return NULL;}
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
81 ret=vcd_seek_to_track(f,vcd_track);
1584
e49b3927c793 more messages for translator :)
arpi
parents: 1567
diff changeset
82 if(ret<0){ mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_ErrTrackSelect " (seek)\n");return NULL;}
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
83 // seek_to_byte+=ret;
1567
5c7760aa4f94 printf->mp_msg/mp_dbg
arpi
parents: 1482
diff changeset
84 mp_msg(MSGT_OPEN,MSGL_V,"VCD start byte position: 0x%X end: 0x%X\n",ret,ret2);
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
85 #ifdef VCD_CACHE
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
86 vcd_cache_init(vcd_cache_size);
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
87 #endif
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
88 #ifdef __FreeBSD__
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
89 if (ioctl (f, CDRIOCSETBLOCKSIZE, &bsize) == -1) {
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
90 perror ( "Error in CDRIOCSETBLOCKSIZE");
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
91 }
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
92 #endif
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
93 stream=new_stream(f,STREAMTYPE_VCD);
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
94 stream->start_pos=ret;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
95 stream->end_pos=ret2;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
96 return stream;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
97 }
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
98
1596
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
99 //============ Open DVD title ==============
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
100 #ifdef USE_DVDREAD
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
101 if(dvd_title){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
102 int ret,ret2;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
103 dvd_priv_t *d;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
104 int ttn,pgc_id,pgn;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
105 dvd_reader_t *dvd;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
106 dvd_file_t *title;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
107 ifo_handle_t *vmg_file;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
108 tt_srpt_t *tt_srpt;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
109 ifo_handle_t *vts_file;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
110 /**
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
111 * Open the disc.
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
112 */
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
113 if(!filename) filename=DEFAULT_DVD_DEVICE;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
114 dvd = DVDOpen(filename);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
115 if( !dvd ) {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
116 mp_msg(MSGT_OPEN,MSGL_ERR, "Couldn't open DVD: %s\n",filename);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
117 return NULL;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
118 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
119
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
120 mp_msg(MSGT_OPEN,MSGL_INFO, "Reading disc structure, please wait...\n");
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
121
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
122 /**
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
123 * Load the video manager to find out the information about the titles on
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
124 * this disc.
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
125 */
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
126 vmg_file = ifoOpen( dvd, 0 );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
127 if( !vmg_file ) {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
128 mp_msg(MSGT_OPEN,MSGL_ERR, "Can't open VMG info!\n");
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
129 DVDClose( dvd );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
130 return NULL;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
131 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
132 tt_srpt = vmg_file->tt_srpt;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
133 /**
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
134 * Make sure our title number is valid.
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
135 */
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
136 mp_msg(MSGT_OPEN,MSGL_INFO, "There are %d titles on this DVD.\n",
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
137 tt_srpt->nr_of_srpts );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
138 if( dvd_title < 1 || dvd_title > tt_srpt->nr_of_srpts ) {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
139 mp_msg(MSGT_OPEN,MSGL_ERR, "Invalid DVD title number: %d\n", dvd_title);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
140 ifoClose( vmg_file );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
141 DVDClose( dvd );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
142 return NULL;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
143 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
144 --dvd_title; // remap 1.. -> 0..
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
145 /**
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
146 * Make sure the chapter number is valid for this title.
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
147 */
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
148 mp_msg(MSGT_OPEN,MSGL_INFO, "There are %d chapters in this DVD title.\n",
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
149 tt_srpt->title[dvd_title].nr_of_ptts );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
150 if( dvd_chapter<1 || dvd_chapter>tt_srpt->title[dvd_title].nr_of_ptts ) {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
151 mp_msg(MSGT_OPEN,MSGL_ERR, "Invalid DVD chapter number: %d\n", dvd_chapter);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
152 ifoClose( vmg_file );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
153 DVDClose( dvd );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
154 return NULL;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
155 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
156 --dvd_chapter; // remap 1.. -> 0..
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
157 /**
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
158 * Make sure the angle number is valid for this title.
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
159 */
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
160 mp_msg(MSGT_OPEN,MSGL_INFO, "There are %d angles in this DVD title.\n",
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
161 tt_srpt->title[dvd_title].nr_of_angles );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
162 if( dvd_angle<1 || dvd_angle>tt_srpt->title[dvd_title].nr_of_angles ) {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
163 mp_msg(MSGT_OPEN,MSGL_ERR, "Invalid DVD angle number: %d\n", dvd_angle);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
164 ifoClose( vmg_file );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
165 DVDClose( dvd );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
166 return NULL;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
167 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
168 /**
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
169 * Load the VTS information for the title set our title is in.
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
170 */
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
171 vts_file = ifoOpen( dvd, tt_srpt->title[dvd_title].title_set_nr );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
172 if( !vts_file ) {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
173 mp_msg(MSGT_OPEN,MSGL_ERR, "Can't open the IFO file for DVD title %d.\n",
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
174 tt_srpt->title[dvd_title].title_set_nr );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
175 ifoClose( vmg_file );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
176 DVDClose( dvd );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
177 return NULL;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
178 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
179 /**
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
180 * We've got enough info, time to open the title set data.
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
181 */
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
182 title = DVDOpenFile( dvd, tt_srpt->title[dvd_title].title_set_nr,
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
183 DVD_READ_TITLE_VOBS );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
184 if( !title ) {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
185 mp_msg(MSGT_OPEN,MSGL_ERR, "Can't open title VOBS (VTS_%02d_1.VOB).\n",
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
186 tt_srpt->title[dvd_title].title_set_nr );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
187 ifoClose( vts_file );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
188 ifoClose( vmg_file );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
189 DVDClose( dvd );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
190 return NULL;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
191 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
192
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
193 mp_msg(MSGT_OPEN,MSGL_INFO, "DVD successfully opened!\n");
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
194 // store data
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
195 d=malloc(sizeof(dvd_priv_t)); memset(d,0,sizeof(dvd_priv_t));
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
196 d->dvd=dvd;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
197 d->title=title;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
198 d->vmg_file=vmg_file;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
199 d->tt_srpt=tt_srpt;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
200 d->vts_file=vts_file;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
201
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
202 /**
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
203 * Determine which program chain we want to watch. This is based on the
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
204 * chapter number.
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
205 */
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
206 ttn = tt_srpt->title[ dvd_title ].vts_ttn; // local
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
207 pgc_id = vts_file->vts_ptt_srpt->title[ttn-1].ptt[dvd_chapter].pgcn; // local
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
208 pgn = vts_file->vts_ptt_srpt->title[ttn-1].ptt[dvd_chapter].pgn; // local
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
209 d->cur_pgc = vts_file->vts_pgcit->pgci_srp[pgc_id-1].pgc;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
210 d->cur_cell = d->cur_pgc->program_map[pgn-1] - 1; // start playback here
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
211 d->packs_left=-1; // for Navi stuff
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
212
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
213 if( d->cur_pgc->cell_playback[d->cur_cell].block_type
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
214 == BLOCK_TYPE_ANGLE_BLOCK ) d->cur_cell+=dvd_angle;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
215 d->cur_pack = d->cur_pgc->cell_playback[ d->cur_cell ].first_sector;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
216 d->cell_last_pack=d->cur_pgc->cell_playback[ d->cur_cell ].last_sector;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
217 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);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
218
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
219 // ... (unimplemented)
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
220 // return NULL;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
221 stream=new_stream(-1,STREAMTYPE_DVD);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
222 stream->start_pos=(off_t)d->cur_pack*2048;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
223 //stream->end_pos=0;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
224 stream->priv=(void*)d;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
225 return stream;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
226 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
227 #endif
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
228
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
229 //============ Open STDIN ============
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
230 if(!strcmp(filename,"-")){
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
231 // read from stdin
1584
e49b3927c793 more messages for translator :)
arpi
parents: 1567
diff changeset
232 mp_msg(MSGT_OPEN,MSGL_INFO,MSGTR_ReadSTDIN);
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
233 f=0; // 0=stdin
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
234 stream=new_stream(f,STREAMTYPE_STREAM);
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
235 return stream;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
236 }
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
237
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
238 #ifdef STREAMING
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
239 url = url_new(filename);
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
240 if(url) {
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
241 (*file_format)=autodetectProtocol( url, &f );
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
242 if( (*file_format)==DEMUXER_TYPE_UNKNOWN ) {
1584
e49b3927c793 more messages for translator :)
arpi
parents: 1567
diff changeset
243 mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_UnableOpenURL, filename);
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
244 url_free(url);
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
245 return NULL;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
246 }
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
247 f=streaming_start( &url, f, file_format );
1584
e49b3927c793 more messages for translator :)
arpi
parents: 1567
diff changeset
248 if(f<0){ mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_UnableOpenURL, url->url); return NULL; }
e49b3927c793 more messages for translator :)
arpi
parents: 1567
diff changeset
249 mp_msg(MSGT_OPEN,MSGL_INFO,MSGTR_ConnToServer, url->hostname );
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
250 stream=new_stream(f,STREAMTYPE_STREAM);
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
251 return NULL;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
252 }
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
253 #endif
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
254
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
255 //============ Open plain FILE ============
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
256 f=open(filename,O_RDONLY);
1584
e49b3927c793 more messages for translator :)
arpi
parents: 1567
diff changeset
257 if(f<0){ mp_msg(MSGT_OPEN,MSGL_ERR,MSGTR_FileNotFound,filename);return NULL; }
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
258 len=lseek(f,0,SEEK_END); lseek(f,0,SEEK_SET);
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
259 if (len == -1)
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
260 perror("Error: lseek failed to obtain video file size");
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
261 else
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
262 if(verbose)
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
263 #ifdef _LARGEFILE_SOURCE
1567
5c7760aa4f94 printf->mp_msg/mp_dbg
arpi
parents: 1482
diff changeset
264 mp_msg(MSGT_OPEN,MSGL_V,"File size is %lld bytes\n", (long long)len);
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
265 #else
1567
5c7760aa4f94 printf->mp_msg/mp_dbg
arpi
parents: 1482
diff changeset
266 mp_msg(MSGT_OPEN,MSGL_V,"File size is %u bytes\n", (unsigned int)len);
1467
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
267 #endif
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
268 stream=new_stream(f,STREAMTYPE_FILE);
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
269 stream->end_pos=len;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
270 return stream;
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
271
f352e1e951ba stream opening -> open.c, initialframes ignored
arpi
parents:
diff changeset
272 }
1596
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
273
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
274
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
275 #ifdef USE_DVDREAD
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
276
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
277 static int dvd_next_cell(dvd_priv_t *d){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
278 int next_cell=d->cur_cell;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
279
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
280 if( d->cur_pgc->cell_playback[ next_cell ].block_type
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
281 == BLOCK_TYPE_ANGLE_BLOCK ) {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
282 int i;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
283 while(next_cell<d->cur_pgc->nr_of_cells){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
284 if( d->cur_pgc->cell_playback[next_cell].block_mode
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
285 == BLOCK_MODE_LAST_CELL ) break;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
286 ++next_cell;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
287 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
288 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
289
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
290 ++next_cell;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
291 if(next_cell>=d->cur_pgc->nr_of_cells) return -1; // EOF
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
292 if( d->cur_pgc->cell_playback[next_cell].block_type == BLOCK_TYPE_ANGLE_BLOCK ){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
293 next_cell+=dvd_angle;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
294 if(next_cell>=d->cur_pgc->nr_of_cells) return -1; // EOF
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
295 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
296 return next_cell;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
297 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
298
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
299 int dvd_read_sector(dvd_priv_t *d,unsigned char* data){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
300 int len;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
301
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
302 if(d->packs_left==0){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
303 /**
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
304 * If we're not at the end of this cell, we can determine the next
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
305 * VOBU to display using the VOBU_SRI information section of the
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
306 * DSI. Using this value correctly follows the current angle,
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
307 * avoiding the doubled scenes in The Matrix, and makes our life
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
308 * really happy.
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
309 *
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
310 * Otherwise, we set our next address past the end of this cell to
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
311 * force the code above to go to the next cell in the program.
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
312 */
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
313 if( d->dsi_pack.vobu_sri.next_vobu != SRI_END_OF_CELL ) {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
314 d->cur_pack= d->dsi_pack.dsi_gi.nv_pck_lbn +
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
315 ( d->dsi_pack.vobu_sri.next_vobu & 0x7fffffff );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
316 mp_msg(MSGT_DVD,MSGL_DBG2, "Navi new pos=0x%X \n",d->cur_pack);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
317 } else {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
318 // end of cell! find next cell!
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
319 mp_msg(MSGT_DVD,MSGL_V, "--- END OF CELL !!! ---\n");
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
320 d->cur_pack=d->cell_last_pack+1;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
321 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
322 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
323
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
324 read_next:
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
325
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
326 if(d->cur_pack>d->cell_last_pack){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
327 // end of cell!
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
328 int next=dvd_next_cell(d);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
329 if(next>=0){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
330 d->cur_cell=next;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
331
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
332 if( d->cur_pgc->cell_playback[d->cur_cell].block_type
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
333 == BLOCK_TYPE_ANGLE_BLOCK ) d->cur_cell+=dvd_angle;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
334 d->cur_pack = d->cur_pgc->cell_playback[ d->cur_cell ].first_sector;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
335 d->cell_last_pack=d->cur_pgc->cell_playback[ d->cur_cell ].last_sector;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
336 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);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
337
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
338 } else return -1; // EOF
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
339 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
340
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
341 len = DVDReadBlocks( d->title, d->cur_pack, 1, data );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
342 if(!len) return -1; //error
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
343
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
344 if(data[38]==0 && data[39]==0 && data[40]==1 && data[41]==0xBF &&
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
345 data[1024]==0 && data[1025]==0 && data[1026]==1 && data[1027]==0xBF){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
346 // found a Navi packet!!!
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
347 navRead_DSI( &d->dsi_pack, &(data[ DSI_START_BYTE ]), sizeof(dsi_t) );
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
348 if(d->cur_pack != d->dsi_pack.dsi_gi.nv_pck_lbn ){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
349 mp_msg(MSGT_DVD,MSGL_V, "Invalid NAVI packet! lba=0x%X navi=0x%X \n",
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
350 d->cur_pack,d->dsi_pack.dsi_gi.nv_pck_lbn);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
351 } else {
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
352 // process!
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
353 d->packs_left = d->dsi_pack.dsi_gi.vobu_ea;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
354 mp_msg(MSGT_DVD,MSGL_DBG2, "Found NAVI packet! lba=0x%X len=%d \n",d->cur_pack,d->packs_left);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
355 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
356 ++d->cur_pack;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
357 goto read_next;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
358 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
359
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
360 ++d->cur_pack;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
361 if(d->packs_left>=0) --d->packs_left;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
362
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
363 return d->cur_pack-1;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
364 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
365
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
366 void dvd_seek(dvd_priv_t *d,int pos){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
367 d->packs_left=-1;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
368 d->cur_pack=pos;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
369
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
370 // check if we stay in current cell (speedup things, and avoid angle skip)
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
371 if(d->cur_pack>d->cell_last_pack &&
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
372 d->cur_pack<d->cur_pgc->cell_playback[ d->cur_cell ].first_sector){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
373
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
374 // ok, cell change, find the right cell!
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
375 d->cur_cell=0;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
376 if( d->cur_pgc->cell_playback[d->cur_cell].block_type
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
377 == BLOCK_TYPE_ANGLE_BLOCK ) d->cur_cell+=dvd_angle;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
378
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
379 while(1){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
380 int next;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
381 d->cell_last_pack=d->cur_pgc->cell_playback[ d->cur_cell ].last_sector;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
382 if(d->cur_pack<d->cur_pgc->cell_playback[ d->cur_cell ].first_sector){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
383 d->cur_pack=d->cur_pgc->cell_playback[ d->cur_cell ].first_sector;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
384 break;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
385 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
386 if(d->cur_pack<=d->cell_last_pack) break; // ok, we find it! :)
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
387 next=dvd_next_cell(d);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
388 if(next<0){
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
389 // d->cur_pack=d->cell_last_pack+1;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
390 break; // we're after the last cell
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
391 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
392 d->cur_cell=next;
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
393 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
394 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
395
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
396 mp_msg(MSGT_DVD,MSGL_V, "DVD Seek! lba=0x%X cell=%d packs: 0x%X-0x%X \n",
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
397 d->cur_pack,d->cur_cell,d->cur_pgc->cell_playback[ d->cur_cell ].first_sector,d->cell_last_pack);
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
398
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
399 // TODO: if we're in interleaved multi-angle cell, find the right angle chain!
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
400 // (read Navi block, and use the seamless angle jump table)
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
401
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
402 }
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
403
fc0e9953bc2d libDVDread support
arpi
parents: 1584
diff changeset
404 #endif