annotate searching.c @ 0:3ddf0eaece51 src

Initial revision
author richwareham
date Tue, 12 Mar 2002 19:45:53 +0000
parents
children 328eadb3f37e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1 /*
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
2 * Copyright (C) 2000 Rich Wareham <richwareham@users.sourceforge.net>
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
3 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
4 * This file is part of libdvdnav, a DVD navigation library.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
5 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
6 * libdvdnav is free software; you can redistribute it and/or modify
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
7 * it under the terms of the GNU General Public License as published by
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
8 * the Free Software Foundation; either version 2 of the License, or
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
9 * (at your option) any later version.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
10 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
11 * libdvdnav is distributed in the hope that it will be useful,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
14 * GNU General Public License for more details.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
15 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
16 * You should have received a copy of the GNU General Public License
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
17 * along with this program; if not, write to the Free Software
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
18 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
19 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
20 * $Id$
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
21 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
22 */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
23
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
24 #ifdef HAVE_CONFIG_H
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
25 #include "config.h"
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
26 #endif
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
27
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
28 #include <dvdnav.h>
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
29 #include "dvdnav_internal.h"
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
30
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
31 #include "vm.h"
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
32 #include <dvdread/nav_types.h>
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
33
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
34 /* Searching API calls */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
35
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
36 dvdnav_status_t dvdnav_time_search(dvdnav_t *self,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
37 unsigned long int time) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
38 /* Time search the current PGC based on the xxx table */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
39 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
40 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
41
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
42 dvdnav_status_t dvdnav_sector_search(dvdnav_t *self,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
43 unsigned long int offset, int origin) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
44 /* FIXME: Implement */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
45
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
46 uint32_t target = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
47 uint32_t length = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
48 uint32_t first_cell_nr, last_cell_nr, cell_nr, fnd_cell_nr;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
49 int found;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
50 cell_playback_t *cell, *fnd_cell;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
51 dvd_state_t *state;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
52 dvdnav_status_t result;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
53
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
54 if((!self) || (!self->vm) )
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
55 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
56
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
57 state = &(self->vm->state);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
58 if((!state) || (!state->pgc) )
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
59 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
60
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
61 if(offset == 0)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
62 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
63
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
64 if(self->still_frame != -1)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
65 /* Cannot do seeking in a still frame. */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
66 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
67
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
68 pthread_mutex_lock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
69 result = dvdnav_get_position(self, &target, &length);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
70 fprintf(stderr,"FIXME: seeking to offset=%lu pos=%u length=%u\n", offset, target, length);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
71 fprintf(stderr,"FIXME: Before cellN=%u blockN=%u\n" ,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
72 state->cellN,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
73 state->blockN);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
74 if(!result) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
75 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
76 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
77 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
78
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
79 switch(origin) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
80 case SEEK_SET:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
81 if(offset > length) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
82 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
83 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
84 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
85 target = offset;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
86 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
87 case SEEK_CUR:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
88 if(target + offset > length) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
89 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
90 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
91 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
92 target += offset;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
93 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
94 case SEEK_END:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
95 if(length - offset < 0) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
96 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
97 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
98 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
99 target = length - offset;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
100 default:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
101 /* Error occured */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
102 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
103 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
104 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
105
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
106 /* First find closest cell number in program */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
107 first_cell_nr = state->pgc->program_map[state->pgN-1];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
108 if(state->pgN < state->pgc->nr_of_programs) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
109 last_cell_nr = state->pgc->program_map[state->pgN] - 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
110 } else {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
111 last_cell_nr = state->pgc->nr_of_cells;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
112 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
113
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
114 found = 0; target += state->pgc->cell_playback[first_cell_nr-1].first_sector;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
115 fnd_cell_nr = last_cell_nr + 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
116 for(cell_nr = first_cell_nr; (cell_nr <= last_cell_nr) && !found; cell_nr ++) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
117 cell = &(state->pgc->cell_playback[cell_nr-1]);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
118 if((cell->first_sector <= target) && (cell->last_sector >= target)) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
119 state->cellN = cell_nr;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
120 state->blockN = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
121 found = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
122 fnd_cell_nr = cell_nr;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
123 fnd_cell = cell;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
124 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
125 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
126
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
127 if(fnd_cell_nr <= last_cell_nr) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
128 printf("Seeking to cell %i from choice of %i to %i\n",
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
129 fnd_cell_nr, first_cell_nr, last_cell_nr);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
130 self->seekto_block = target;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
131 self->seeking = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
132 /*
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
133 * Clut does not actually change,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
134 * but as the decoders have been closed then opened,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
135 * A new clut has to be sent.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
136 */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
137 self->spu_clut_changed = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
138 //ogle_do_post_jump(ogle);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
139 fprintf(stderr,"FIXME: After cellN=%u blockN=%u\n" ,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
140 state->cellN,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
141 state->blockN);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
142
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
143 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
144 return target;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
145 } else {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
146 fprintf(stderr, "Error when seeking, asked to seek outside program\n");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
147 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
148
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
149
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
150
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
151 printf("FIXME: Implement seeking to location %u\n", target);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
152
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
153 // self->seekto_block=target;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
154 // self->seeking = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
155
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
156 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
157 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
158 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
159
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
160 dvdnav_status_t dvdnav_part_search(dvdnav_t *self, int part) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
161 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
162 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
163
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
164 dvdnav_status_t dvdnav_prev_pg_search(dvdnav_t *self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
165 dvd_state_t *state;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
166 state = &(self->vm->state);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
167 /* Make sure this is not the first chapter */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
168
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
169 if(state->pgN <= 1 ) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
170 printf("dvdnav: at first chapter. prev chapter failed.\n");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
171 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
172 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
173 printf("dvdnav: previous chapter\n");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
174 vm_jump_prog(self->vm, state->pgN - 1);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
175 dvdnav_do_post_jump(self);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
176 printf("dvdnav: previous chapter done\n");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
177
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
178 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
179 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
180
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
181 dvdnav_status_t dvdnav_top_pg_search(dvdnav_t *self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
182
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
183 printf("dvdnav: top chapter. NOP.\n");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
184
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
185 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
186 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
187
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
188 dvdnav_status_t dvdnav_next_pg_search(dvdnav_t *self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
189 dvd_state_t *state;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
190 state = &(self->vm->state);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
191 /* Make sure this is not the last chapter */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
192 if(state->pgN >= state->pgc->nr_of_programs) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
193 printf("dvdnav: at last chapter. next chapter failed.\n");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
194 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
195 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
196 printf("dvdnav: next chapter\n");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
197 vm_jump_prog(self->vm, state->pgN + 1);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
198 dvdnav_do_post_jump(self);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
199 printf("dvdnav: next chapter done\n");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
200
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
201 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
202 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
203
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
204 dvdnav_status_t dvdnav_menu_call(dvdnav_t *self, DVDMenuID_t menu) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
205 dvd_state_t *state;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
206
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
207 pthread_mutex_lock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
208 state = &(self->vm->state);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
209 vm_menu_call(self->vm, menu, 0);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
210 dvdnav_do_post_jump(self);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
211 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
212 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
213 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
214
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
215 dvdnav_status_t dvdnav_current_title_info(dvdnav_t *self, int *tt, int *pr) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
216 int vts_ttn = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
217 int vts, i;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
218 domain_t domain;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
219 tt_srpt_t* srpt;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
220
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
221 if(!self)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
222 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
223
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
224 if(!tt || !pr) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
225 printerr("Passed a NULL pointer");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
226 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
227
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
228 if(tt)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
229 *tt = -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
230 if(*pr)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
231 *pr = -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
232
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
233 domain = self->vm->state.domain;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
234 if((domain == FP_DOMAIN) || (domain == VMGM_DOMAIN)) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
235 /* Not in a title */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
236 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
237 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
238
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
239 vts_ttn = self->vm->state.VTS_TTN_REG;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
240 vts = self->vm->state.vtsN;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
241
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
242 if(pr) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
243 *pr = self->vm->state.pgN;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
244 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
245
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
246 /* Search TT_SRPT for title */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
247 if(!(vm_get_vmgi(self->vm))) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
248 printerr("Oh poo, no SRPT");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
249 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
250 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
251
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
252 srpt = vm_get_vmgi(self->vm)->tt_srpt;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
253 for(i=0; i<srpt->nr_of_srpts; i++) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
254 title_info_t* info = &(srpt->title[i]);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
255 if((info->title_set_nr == vts) && (info->vts_ttn == vts_ttn)) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
256 if(tt)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
257 *tt = i+1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
258 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
259 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
260
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
261 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
262 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
263
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
264 static char __title_str[] = "DVDNAV";
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
265
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
266 dvdnav_status_t dvdnav_get_title_string(dvdnav_t *self, char **title_str) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
267 if(!self)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
268 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
269
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
270 if(!title_str) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
271 printerr("Passed a NULL pointer");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
272 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
273 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
274
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
275 (*title_str) = __title_str;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
276
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
277 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
278 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
279
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
280 dvdnav_status_t dvdnav_get_position(dvdnav_t *self, unsigned int* pos,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
281 unsigned int *len) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
282 uint32_t cur_sector;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
283 uint32_t first_cell_nr;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
284 uint32_t last_cell_nr;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
285 cell_playback_t *first_cell;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
286 cell_playback_t *last_cell;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
287 dvd_state_t *state;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
288 if((!self) || (!self->vm) )
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
289 return 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
290
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
291 state = &(self->vm->state);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
292 if((!state) || (!state->pgc) )
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
293 return 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
294
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
295 /* Sanity check */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
296 if(state->pgN > state->pgc->nr_of_programs) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
297 return 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
298 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
299
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
300 /* Get current sector */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
301 cur_sector = self->vobu_start + self->blockN;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
302
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
303 /* Find start cell of program. */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
304 first_cell_nr = state->pgc->program_map[state->pgN-1];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
305 first_cell = &(state->pgc->cell_playback[first_cell_nr-1]);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
306 if(state->pgN < state->pgc->nr_of_programs) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
307 last_cell_nr = state->pgc->program_map[state->pgN] - 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
308 } else {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
309 last_cell_nr = state->pgc->nr_of_cells;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
310 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
311 last_cell = &(state->pgc->cell_playback[last_cell_nr-1]);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
312
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
313 *pos= cur_sector - first_cell->first_sector;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
314 *len= last_cell->last_sector - first_cell->first_sector;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
315 /* printf("dvdnav:searching:current pos=%u length=%u\n",*pos,*len); */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
316
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
317
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
318 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
319 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
320