annotate dvdnav.c @ 4:99bed5d6db2f src

Added reset patch from Kees Cook <kees@outflux.net>
author richwareham
date Tue, 02 Apr 2002 18:22:27 +0000
parents 328eadb3f37e
children 5f319e02e333
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 <pthread.h>
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
29 #include <dvdnav.h>
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
30 #include "dvdnav_internal.h"
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
31 #include "read_cache.h"
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
32
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
33 #include <dvdread/nav_read.h>
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
34
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
35 #include <stdlib.h>
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
36 #include <stdio.h>
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
37
4
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
38 dvdnav_status_t dvdnav_clear(dvdnav_t * self) {
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
39 if (!self) {
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
40 printerr("Passed a NULL pointer");
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
41 return S_ERR;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
42 }
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
43 /* clear everything except path, file, vm, mutex, readahead */
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
44
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
45 // path
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
46 if (self->file) DVDCloseFile(self->file);
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
47 self->file = NULL;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
48 self->open_vtsN = -1;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
49 self->open_domain = -1;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
50 self->vobu_start=0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
51 self->vobu_length=0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
52 self->blockN=0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
53 self->next_vobu=0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
54 self->cell = NULL;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
55 self->jmp_blockN=0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
56 self->jmp_vobu_start=0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
57 self->seekto_block=0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
58
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
59 memset(&self->pci,0,sizeof(self->pci));
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
60 memset(&self->dsi,0,sizeof(self->dsi));
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
61
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
62 /* Set initial values of flags */
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
63 self->expecting_nav_packet = 1;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
64 self->at_soc = 1;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
65 self->still_frame = -1;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
66 self->jumping = 0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
67 self->seeking = 0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
68 self->stop = 0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
69 self->highlight_changed = 0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
70 self->spu_clut_changed = 0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
71 self->spu_stream_changed = 0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
72 self->audio_stream_changed = 0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
73 self->started=0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
74 // self->use_read_ahead
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
75
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
76 self->hli_state=0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
77
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
78 self->cache_start_sector = -1;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
79 self->cache_block_count = 0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
80 self->cache_valid = 0;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
81
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
82 return S_OK;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
83 }
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
84
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
85 dvdnav_status_t dvdnav_open(dvdnav_t** dest, char *path) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
86 dvdnav_t *self;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
87
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
88 /* Create a new structure */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
89 (*dest) = NULL;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
90 self = (dvdnav_t*)malloc(sizeof(dvdnav_t));
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
91 if(!self)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
92 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
93 memset(self, 0, (sizeof(dvdnav_t) ) ); /* Make sure self structure is clean */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
94
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
95 pthread_mutex_init(&self->vm_lock, NULL);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
96 /* Initialise the error string */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
97 printerr("");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
98
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
99 /* Initialise the VM */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
100 self->vm = vm_new_vm();
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
101 if(!self->vm) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
102 printerr("Error initialising the DVD VM");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
103 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
104 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
105 if(vm_reset(self->vm, path) == -1) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
106 printerr("Error starting the VM / opening the DVD device");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
107 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
108 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
109
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
110 /* Set the path. FIXME: Is a deep copy 'right' */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
111 strncpy(self->path, path, MAX_PATH_LEN);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
112
4
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
113 dvdnav_clear(self);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
114
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
115 /* Pre-open and close a file so that the CSS-keys are cached. */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
116 self->file = DVDOpenFile(vm_get_dvd_reader(self->vm), 0, DVD_READ_MENU_VOBS);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
117 if (self->file) DVDCloseFile(self->file);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
118 self->file = NULL;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
119
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
120 if(!self->started) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
121 /* Start the VM */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
122 vm_start(self->vm);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
123 self->started = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
124 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
125
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
126 (*dest) = self;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
127 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
128 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
129
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
130 dvdnav_status_t dvdnav_close(dvdnav_t *self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
131 if(!self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
132 printerr("Passed a NULL pointer");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
133 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
134 }
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
135 fprintf(stderr,"dvdnav:close:called\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
136 if (self->file) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
137 DVDCloseFile(self->file);
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
138 fprintf(stderr,"dvdnav:close:file closing\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
139 self->file = NULL;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
140 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
141
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
142 /* Free the VM */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
143 if(self->vm) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
144 vm_free_vm(self->vm);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
145 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
146 if (self->file) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
147 DVDCloseFile(self->file);
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
148 fprintf(stderr,"dvdnav:close2:file closing\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
149 self->file = NULL;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
150 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
151 pthread_mutex_destroy(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
152 /* Finally free the entire structure */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
153 free(self);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
154
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
155 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
156 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
157
4
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
158 dvdnav_status_t dvdnav_reset(dvdnav_t *self) {
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
159 dvdnav_status_t result;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
160
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
161 printf("dvdnav:reset:called\n");
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
162 if(!self) {
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
163 printerr("Passed a NULL pointer");
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
164 return S_ERR;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
165 }
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
166 printf("getting lock\n");
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
167 pthread_mutex_lock(&self->vm_lock);
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
168 printf("reseting vm\n");
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
169 if(vm_reset(self->vm, NULL) == -1) {
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
170 printerr("Error restarting the VM");
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
171 pthread_mutex_unlock(&self->vm_lock);
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
172 return S_ERR;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
173 }
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
174 printf("clearing dvdnav\n");
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
175 result=dvdnav_clear(self);
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
176 printf("starting vm\n");
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
177 if(!self->started) {
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
178 /* Start the VM */
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
179 vm_start(self->vm);
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
180 self->started = 1;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
181 }
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
182 printf("unlocking\n");
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
183 pthread_mutex_unlock(&self->vm_lock);
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
184 return result;
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
185 }
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
186
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
187 dvdnav_status_t dvdnav_path(dvdnav_t *self, char** path) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
188 if(!self || !path || !(*path)) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
189 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
190 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
191
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
192 /* FIXME: Is shallow copy 'right'? */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
193 (*path) = self->path;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
194
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
195 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
196 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
197
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
198 char* dvdnav_err_to_string(dvdnav_t *self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
199 if(!self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
200 /* Shold this be "passed a NULL pointer?" */
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
201 return "Hey! You gave me a NULL pointer you naughty person!";
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
202 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
203
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
204 return self->err_str;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
205 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
206
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
207 /**
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
208 * Returns 1 if block contains NAV packet, 0 otherwise.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
209 * Precesses said NAV packet if present.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
210 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
211 * Most of the code in here is copied from xine's MPEG demuxer
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
212 * so any bugs which are found in that should be corrected here also.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
213 */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
214 int dvdnav_check_packet(dvdnav_t *self, uint8_t *p) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
215 int bMpeg1=0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
216 uint32_t nHeaderLen;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
217 uint32_t nPacketLen;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
218 uint32_t nStreamID;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
219 /* uint8_t *p_start=p; */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
220
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
221
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
222 if (p==NULL) {
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
223 fprintf(stderr,"Passed a NULL pointer.\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
224 return 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
225 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
226
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
227 /* dprint("Checking packet...\n"); */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
228
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
229 if (p[3] == 0xBA) { /* program stream pack header */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
230
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
231 int nStuffingBytes;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
232
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
233 /* xprintf (VERBOSE|DEMUX, "program stream pack header\n"); */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
234
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
235 bMpeg1 = (p[4] & 0x40) == 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
236
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
237 if (bMpeg1) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
238 p += 12;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
239 } else { /* mpeg2 */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
240 nStuffingBytes = p[0xD] & 0x07;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
241 p += 14 + nStuffingBytes;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
242 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
243 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
244
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
245
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
246 if (p[3] == 0xbb) { /* program stream system header */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
247 int nHeaderLen;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
248
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
249 nHeaderLen = (p[4] << 8) | p[5];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
250 p += 6 + nHeaderLen;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
251 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
252
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
253 /* we should now have a PES packet here */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
254
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
255 if (p[0] || p[1] || (p[2] != 1)) {
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
256 fprintf(stderr,"demux error! %02x %02x %02x (should be 0x000001) \n",p[0],p[1],p[2]);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
257 return 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
258 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
259
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
260 nPacketLen = p[4] << 8 | p[5];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
261 nStreamID = p[3];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
262
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
263 nHeaderLen = 6;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
264 p += nHeaderLen;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
265
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
266 if (nStreamID == 0xbf) { /* Private stream 2 */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
267 /*
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
268 * int i;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
269 * printf("dvdnav:nav packet=%u\n",p-p_start-6);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
270 * for(i=0;i<80;i++) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
271 * printf("%02x ",p[i-6]);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
272 * }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
273 * printf("\n");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
274 */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
275 if(p[0] == 0x00) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
276 #ifdef HAVE_DVDREAD9
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
277 navRead_PCI(&(self->pci), p+1);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
278 #else
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
279 navRead_PCI(&(self->pci), p+1, nPacketLen - 1);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
280 #endif
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
281 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
282
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
283 p += nPacketLen;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
284
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
285 /* We should now have a DSI packet. */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
286 if(p[6] == 0x01) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
287 int num=0, current=0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
288
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
289 nPacketLen = p[4] << 8 | p[5];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
290 p += 6;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
291 /* dprint("NAV DSI packet\n"); */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
292 #ifdef HAVE_DVDREAD9
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
293 navRead_DSI(&(self->dsi), p+1);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
294 #else
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
295 navRead_DSI(&(self->dsi), p+1, sizeof(dsi_t));
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
296 #endif
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
297
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
298 self->vobu_start = self->dsi.dsi_gi.nv_pck_lbn;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
299 self->vobu_length = self->dsi.dsi_gi.vobu_ea;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
300
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
301 /**
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
302 * If we're not at the end of this cell, we can determine the next
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
303 * VOBU to display using the VOBU_SRI information section of the
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
304 * DSI. Using this value correctly follows the current angle,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
305 * avoiding the doubled scenes in The Matrix, and makes our life
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
306 * really happy.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
307 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
308 * Otherwise, we set our next address past the end of this cell to
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
309 * force the code above to go to the next cell in the program.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
310 */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
311 if( self->dsi.vobu_sri.next_vobu != SRI_END_OF_CELL ) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
312 self->next_vobu = self->dsi.dsi_gi.nv_pck_lbn
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
313 + ( self->dsi.vobu_sri.next_vobu & 0x7fffffff );
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
314 } else {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
315 self->next_vobu = self->vobu_start + self->vobu_length;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
316 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
317
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
318 dvdnav_get_angle_info(self, &current, &num);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
319 if(num == 1) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
320 /* This is to switch back to angle one when we
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
321 * finish */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
322 dvdnav_angle_change(self, 1);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
323 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
324
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
325 if(num != 0) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
326 uint32_t next = self->pci.nsml_agli.nsml_agl_dsta[current-1];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
327
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
328 if(next != 0) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
329 int dir = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
330 if(next & 0x80000000) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
331 dir = -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
332 next = next & 0x3fffffff;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
333 } else {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
334 dir = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
335 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
336
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
337 if(next != 0) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
338 self->next_vobu = self->vobu_start + dir * next;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
339 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
340 } else if( self->dsi.sml_agli.data[current-1].address != 0 ) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
341 next = self->dsi.sml_agli.data[current-1].address;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
342 self->vobu_length = self->dsi.sml_pbi.ilvu_ea;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
343
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
344 if((next & 0x80000000) && (next != 0x7fffffff)) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
345 self->next_vobu = self->dsi.dsi_gi.nv_pck_lbn - (next & 0x7fffffff);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
346 } else {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
347 self->next_vobu = self->dsi.dsi_gi.nv_pck_lbn + next;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
348 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
349 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
350 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
351 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
352 return 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
353 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
354
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
355 return 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
356 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
357
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
358 dvdnav_status_t dvdnav_get_next_block(dvdnav_t *self, unsigned char *buf,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
359 int *event, int *len) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
360 dvd_state_t *state;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
361 int result;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
362 if(!self || !event || !len || !buf) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
363 printerr("Passed a NULL pointer");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
364 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
365 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
366 pthread_mutex_lock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
367
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
368 if(!self->started) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
369 /* Start the VM */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
370 vm_start(self->vm);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
371 self->started = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
372 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
373
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
374 state = &(self->vm->state);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
375 (*event) = DVDNAV_NOP;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
376 (*len) = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
377
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
378 /* Check the STOP flag */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
379 if(self->stop) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
380 (*event) = DVDNAV_STOP;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
381 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
382 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
383 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
384
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
385 if(self->spu_clut_changed) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
386 (*event) = DVDNAV_SPU_CLUT_CHANGE;
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
387 fprintf(stderr,"libdvdnav:SPU_CLUT_CHANGE\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
388 (*len) = sizeof(dvdnav_still_event_t);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
389 memcpy(buf, &(state->pgc->palette), 16 * sizeof(uint32_t));
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
390 self->spu_clut_changed = 0;
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
391 fprintf(stderr,"libdvdnav:SPU_CLUT_CHANGE returning S_OK\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
392 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
393 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
394 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
395
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
396 if(self->spu_stream_changed) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
397 dvdnav_stream_change_event_t stream_change;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
398 (*event) = DVDNAV_SPU_STREAM_CHANGE;
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
399 fprintf(stderr,"libdvdnav:SPU_STREAM_CHANGE\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
400 (*len) = sizeof(dvdnav_stream_change_event_t);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
401 stream_change.physical= vm_get_subp_active_stream( self->vm );
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
402 memcpy(buf, &(stream_change), sizeof( dvdnav_stream_change_event_t));
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
403 self->spu_stream_changed = 0;
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
404 fprintf(stderr,"libdvdnav:SPU_STREAM_CHANGE stream_id=%d returning S_OK\n",stream_change.physical);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
405 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
406 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
407 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
408
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
409 if(self->audio_stream_changed) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
410 dvdnav_stream_change_event_t stream_change;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
411 (*event) = DVDNAV_AUDIO_STREAM_CHANGE;
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
412 fprintf(stderr,"libdvdnav:AUDIO_STREAM_CHANGE\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
413 (*len) = sizeof(dvdnav_stream_change_event_t);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
414 stream_change.physical= vm_get_audio_active_stream( self->vm );
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
415 memcpy(buf, &(stream_change), sizeof( dvdnav_stream_change_event_t));
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
416 self->audio_stream_changed = 0;
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
417 fprintf(stderr,"libdvdnav:AUDIO_STREAM_CHANGE stream_id=%d returning S_OK\n",stream_change.physical);
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
418 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
419 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
420 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
421
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
422 /* Check the HIGHLIGHT flag */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
423 if(self->highlight_changed) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
424 dvdnav_highlight_event_t hevent;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
425
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
426 /* Fill in highlight struct with appropriate values */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
427 if(self->hli_state != 0) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
428 hevent.display = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
429
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
430 /* Copy current button bounding box. */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
431 hevent.sx = self->hli_bbox[0];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
432 hevent.sy = self->hli_bbox[1];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
433 hevent.ex = self->hli_bbox[2];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
434 hevent.ey = self->hli_bbox[3];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
435
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
436 hevent.palette = self->hli_clut;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
437 hevent.pts = self->hli_pts;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
438 hevent.buttonN = self->hli_buttonN;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
439
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
440 } else {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
441 hevent.display = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
442 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
443
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
444 (*event) = DVDNAV_HIGHLIGHT;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
445 memcpy(buf, &(hevent), sizeof(hevent));
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
446 (*len) = sizeof(hevent);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
447
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
448 self->highlight_changed = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
449
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
450 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
451 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
452 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
453
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
454 /* Check to see if we need to change the curently opened VOB */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
455 if((self->open_vtsN != state->vtsN) ||
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
456 (self->open_domain != state->domain)) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
457 dvd_read_domain_t domain;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
458 int vtsN;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
459 dvdnav_vts_change_event_t vts_event;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
460
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
461 if(self->file) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
462 dvdnav_read_cache_clear(self);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
463 DVDCloseFile(self->file);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
464 self->file = NULL;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
465 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
466
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
467 vts_event.old_vtsN = self->open_vtsN;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
468 vts_event.old_domain = self->open_domain;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
469
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
470 /* Use the current DOMAIN to find whether to open menu or title VOBs */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
471 switch(state->domain) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
472 case FP_DOMAIN:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
473 case VMGM_DOMAIN:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
474 domain = DVD_READ_MENU_VOBS;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
475 vtsN = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
476 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
477 case VTSM_DOMAIN:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
478 domain = DVD_READ_MENU_VOBS;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
479 vtsN = state->vtsN;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
480 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
481 case VTS_DOMAIN:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
482 domain = DVD_READ_TITLE_VOBS;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
483 vtsN = state->vtsN;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
484 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
485 default:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
486 printerr("Unknown domain when changing VTS.");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
487 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
488 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
489 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
490
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
491 self->open_domain = state->domain;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
492 self->open_vtsN = state->vtsN;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
493 dvdnav_read_cache_clear(self);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
494 self->file = DVDOpenFile(vm_get_dvd_reader(self->vm), vtsN, domain);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
495 vts_event.new_vtsN = self->open_vtsN;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
496 vts_event.new_domain = self->open_domain;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
497
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
498 /* If couldn't open the file for some reason, moan */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
499 if(self->file == NULL) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
500 printerrf("Error opening vtsN=%i, domain=%i.", vtsN, domain);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
501 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
502 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
503 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
504
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
505 /* File opened successfully so return a VTS change event */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
506 (*event) = DVDNAV_VTS_CHANGE;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
507 memcpy(buf, &(vts_event), sizeof(vts_event));
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
508 (*len) = sizeof(vts_event);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
509
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
510 /* On a VTS change, we want to disable any highlights which
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
511 * may have been shown (FIXME: is this valid?) */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
512 self->highlight_changed = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
513 self->spu_clut_changed = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
514 self->spu_stream_changed = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
515 self->audio_stream_changed = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
516 self->hli_state = 0; /* Hide */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
517 self->expecting_nav_packet = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
518
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
519 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
520 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
521 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
522
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
523 /* Check the STILLFRAME flag */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
524 if(self->still_frame != -1) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
525 dvdnav_still_event_t still_event;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
526
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
527 still_event.length = self->still_frame;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
528
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
529 (*event) = DVDNAV_STILL_FRAME;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
530 (*len) = sizeof(dvdnav_still_event_t);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
531 memcpy(buf, &(still_event), sizeof(dvdnav_still_event_t));
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
532
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
533 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
534 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
535 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
536
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
537 if(self->at_soc) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
538 dvdnav_cell_change_event_t cell_event;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
539 cell_playback_t *cell = &(state->pgc->cell_playback[state->cellN - 1]);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
540
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
541 cell_event.old_cell = self->cell;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
542 self->vobu_start = cell->first_sector;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
543 self->cell = cell;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
544 cell_event.new_cell = self->cell;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
545
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
546 self->at_soc = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
547
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
548 (*event) = DVDNAV_CELL_CHANGE;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
549 (*len) = sizeof(dvdnav_cell_change_event_t);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
550 memcpy(buf, &(cell_event), sizeof(dvdnav_cell_change_event_t));
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
551
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
552 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
553 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
554 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
555
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
556 if(self->expecting_nav_packet) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
557 dvdnav_nav_packet_event_t nav_event;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
558
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
559 /* Perform the jump if necessary (this is always a
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
560 * VOBU boundary). */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
561
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
562 if(self->seeking) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
563 /* FIXME:Need to handle seeking outside current cell. */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
564 vobu_admap_t *admap = NULL;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
565
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
566 fprintf(stderr,"Seeking to target %u ...\n",
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
567 self->seekto_block);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
568
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
569 /* Search through the VOBU_ADMAP for the nearest VOBU
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
570 * to the target block */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
571 switch(state->domain) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
572 case FP_DOMAIN:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
573 case VMGM_DOMAIN:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
574 //ifo = vm_get_vmgi();
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
575 //ifoRead_VOBU_ADMAP(ifo);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
576 admap = self->vm->vmgi->menu_vobu_admap;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
577 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
578 case VTSM_DOMAIN:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
579 //ifo = vm_get_vtsi();
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
580 //ifoRead_VOBU_ADMAP(ifo);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
581 admap = self->vm->vtsi->menu_vobu_admap;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
582 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
583 case VTS_DOMAIN:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
584 //ifo = vm_get_vtsi();
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
585 //ifoRead_TITLE_VOBU_ADMAP(ifo);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
586 admap = self->vm->vtsi->vts_vobu_admap;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
587 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
588 default:
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
589 fprintf(stderr,"Error: Unknown domain for seeking seek.\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
590 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
591
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
592 if(admap) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
593 uint32_t address = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
594 uint32_t vobu_start, next_vobu;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
595 int found = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
596
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
597 /* Search through ADMAP for best sector */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
598 vobu_start = 0x3fffffff;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
599
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
600 while((!found) && ((address<<2) < admap->last_byte)) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
601 next_vobu = admap->vobu_start_sectors[address];
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
602
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
603 /* printf("Found block %u\n", next_vobu); */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
604
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
605 if(vobu_start <= self->seekto_block &&
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
606 next_vobu > self->seekto_block) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
607 found = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
608 } else {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
609 vobu_start = next_vobu;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
610 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
611
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
612 address ++;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
613 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
614 if(found) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
615 self->vobu_start = vobu_start;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
616 self->blockN = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
617 self->seeking = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
618 //self->at_soc = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
619 (*event) = DVDNAV_SEEK_DONE;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
620 (*len) = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
621 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
622 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
623 } else {
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
624 fprintf(stderr,"Could not locate block\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
625 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
626 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
627 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
628 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
629 if(self->jumping) {
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
630 fprintf(stderr,"doing jumping\n");
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
631 self->vobu_start = self->jmp_vobu_start;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
632 self->blockN = self->jmp_blockN;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
633 self->jumping = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
634 self->at_soc = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
635 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
636
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
637 result = DVDReadBlocks(self->file, self->vobu_start + self->blockN, 1, buf);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
638
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
639 if(result <= 0) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
640 printerr("Error reading NAV packet.");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
641 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
642 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
643 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
644
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
645 if(dvdnav_check_packet(self, buf) == 0) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
646 printerr("Expected NAV packet but none found.");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
647 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
648 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
649 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
650
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
651 self->blockN++;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
652 self->expecting_nav_packet = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
653
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
654 dvdnav_pre_cache_blocks(self, self->vobu_start, self->vobu_length+1);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
655
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
656 /* Successfully got a NAV packet */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
657 nav_event.pci = &(self->pci);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
658 nav_event.dsi = &(self->dsi);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
659
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
660 (*event) = DVDNAV_NAV_PACKET;
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
661 /* memcpy(buf, &(nav_event), sizeof(dvdnav_nav_packet_event_t));
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
662 (*len) = sizeof(dvdnav_nav_packet_event_t); */
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
663 (*len) = 2048;
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
664 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
665 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
666 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
667
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
668 /* If we've got here, it must just be a normal block. */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
669 if(!self->file) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
670 printerr("Attempting to read without opening file");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
671 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
672 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
673 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
674
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
675 result = dvdnav_read_cache_block(self, self->vobu_start + self->blockN, 1, buf);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
676 if(result <= 0) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
677 printerr("Error reading from DVD.");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
678 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
679 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
680 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
681 self->blockN++;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
682 (*len) = 2048;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
683 (*event) = DVDNAV_BLOCK_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
684
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
685 if(self->blockN > self->vobu_length) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
686 self->vobu_start = self->next_vobu;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
687 self->blockN = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
688 self->expecting_nav_packet = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
689
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
690 if(self->dsi.vobu_sri.next_vobu == SRI_END_OF_CELL) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
691 cell_playback_t *cell = &(state->pgc->cell_playback[state->cellN - 1]);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
692
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
693 if(cell->still_time != 0xff) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
694 vm_get_next_cell(self->vm);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
695 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
696
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
697 if(cell->still_time != 0) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
698 self->still_frame = cell->still_time;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
699 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
700
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
701 self->at_soc = 1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
702 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
703 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
704
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
705 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
706 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
707 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
708
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
709 uint16_t dvdnav_audio_stream_to_lang(dvdnav_t *self, uint8_t stream) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
710 ifo_handle_t *vtsi;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
711 dvd_state_t *state;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
712
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
713 if(!self)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
714 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
715
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
716 pthread_mutex_lock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
717
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
718 vtsi = self->vm->vtsi;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
719 state = &(self->vm->state);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
720
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
721 if((vtsi == NULL) || (state == NULL) || (state->domain != VTS_DOMAIN))
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
722 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
723
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
724 if(stream >= vtsi->vtsi_mat->nr_of_vts_audio_streams)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
725 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
726
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
727 if(vtsi->vtsi_mat->vts_audio_attr[stream].lang_type != 1)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
728 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
729
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
730 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
731 return vtsi->vtsi_mat->vts_audio_attr[stream].lang_code;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
732
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
733 __failed:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
734 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
735 return 0xffff;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
736 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
737
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
738 int8_t dvdnav_audio_logical_to_physical(dvdnav_t *self, uint8_t logical) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
739 audio_status_t *audio_status;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
740 dvd_state_t *state;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
741 int i = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
742
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
743 if(!self)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
744 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
745
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
746 pthread_mutex_lock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
747
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
748 state = &(self->vm->state);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
749
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
750 if((!state) || (!state->pgc) || (!state->pgc->audio_control))
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
751 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
752
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
753 if(logical > 7) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
754 fprintf(stderr, "Invalid logical audio channel: %i\n", logical);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
755 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
756 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
757
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
758 while (i < 8) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
759 audio_status = (audio_status_t*) &(state->pgc->audio_control[i]);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
760
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
761 if(!audio_status)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
762 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
763
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
764 if(audio_status->available)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
765 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
766
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
767 i++;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
768 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
769
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
770 if (i > 7)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
771 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
772
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
773 if ((logical+i) > 7)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
774 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
775
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
776 audio_status = (audio_status_t*) &(state->pgc->audio_control[logical+i]);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
777
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
778 if(!audio_status)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
779 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
780
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
781 if(audio_status->available) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
782 /* Stream is available */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
783 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
784 return audio_status->stream_number;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
785 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
786
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
787 __failed:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
788 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
789 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
790 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
791
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
792 int8_t dvdnav_audio_physical_to_logical(dvdnav_t *self, uint8_t physical) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
793 int8_t logical = -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
794 int i = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
795
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
796 if((!self) || (physical > 7))
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
797 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
798
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
799 do {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
800 if(dvdnav_audio_logical_to_physical(self, i) == physical)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
801 logical = i;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
802
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
803 i++;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
804 } while((i<8) && (logical == -1));
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
805
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
806 return logical;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
807 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
808
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
809 uint16_t dvdnav_spu_stream_to_lang(dvdnav_t *self, uint8_t stream) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
810 ifo_handle_t *vtsi;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
811 dvd_state_t *state;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
812
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
813 if(!self)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
814 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
815
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
816 pthread_mutex_lock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
817
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
818 vtsi = self->vm->vtsi;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
819 state = &(self->vm->state);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
820
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
821 if((vtsi == NULL) || (state == NULL) || (state->domain != VTS_DOMAIN)) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
822 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
823 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
824
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
825 if(stream >= vtsi->vtsi_mat->nr_of_vts_subp_streams) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
826 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
827 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
828
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
829 if(vtsi->vtsi_mat->vts_subp_attr[stream].type != 1) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
830 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
831 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
832
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
833 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
834 return vtsi->vtsi_mat->vts_subp_attr[stream].lang_code;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
835
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
836 __failed:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
837 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
838 return 0xffff;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
839 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
840
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
841 int8_t dvdnav_spu_logical_to_physical(dvdnav_t *self, uint8_t logical) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
842 spu_status_t *spu_status;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
843 dvd_state_t *state;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
844 ifo_handle_t *vtsi;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
845
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
846 if(!self)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
847 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
848
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
849 pthread_mutex_lock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
850
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
851 vtsi = self->vm->vtsi;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
852 state = &(self->vm->state);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
853
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
854 if((!state) || (!vtsi))
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
855 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
856
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
857 if(logical > 31) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
858 fprintf(stderr, "Invalid logical spu channel: %i\n", logical);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
859 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
860 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
861
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
862 spu_status = (spu_status_t*) &(state->pgc->subp_control[logical]);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
863
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
864 if(!spu_status)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
865 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
866
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
867 if(spu_status->available) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
868 int8_t logical = -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
869 video_attr_t *attr;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
870
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
871 attr = &(vtsi->vtsi_mat->vtsm_video_attr);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
872
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
873 if(!attr)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
874 goto __failed;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
875
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
876 /* Stream is available */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
877 switch(attr->display_aspect_ratio) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
878 case 0: /* 4:3 */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
879 logical = spu_status->stream_number_4_3;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
880 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
881 case 3: /* 16:9 */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
882 logical = spu_status->stream_number_letterbox;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
883 break;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
884 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
885 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
886 return logical;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
887 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
888
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
889 __failed:
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
890 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
891 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
892 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
893
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
894 int8_t dvdnav_spu_physical_to_logical(dvdnav_t *self, uint8_t physical) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
895 int8_t logical = -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
896 int i = 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
897
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
898 if(physical > 31)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
899 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
900
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
901 do {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
902 if(dvdnav_spu_logical_to_physical(self, i) == physical)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
903 logical = i;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
904
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
905 i++;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
906 } while((i<32) && (logical == -1));
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
907
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
908 return logical;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
909 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
910
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
911 /* Current domain (backend to dvdnav_is_domain_() funcs) */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
912 static int8_t _dvdnav_is_domain(dvdnav_t *self, domain_t domain) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
913 dvd_state_t *state;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
914
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
915 if((!self) || (!self->started) || (!self->vm))
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
916 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
917
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
918 pthread_mutex_lock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
919 state = &(self->vm->state);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
920 pthread_mutex_unlock(&self->vm_lock);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
921
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
922 if(!state)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
923 return -1;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
924
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
925 return (state->domain == domain) ? 1 : 0;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
926 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
927
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
928 /* First Play domain. (Menu) */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
929 int8_t dvdnav_is_domain_fp(dvdnav_t *self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
930 return _dvdnav_is_domain(self, FP_DOMAIN);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
931 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
932 /* Video management Menu domain. (Menu) */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
933 int8_t dvdnav_is_domain_vmgm(dvdnav_t *self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
934 return _dvdnav_is_domain(self, VMGM_DOMAIN);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
935 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
936 /* Video Title Menu domain (Menu) */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
937 int8_t dvdnav_is_domain_vtsm(dvdnav_t *self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
938 return _dvdnav_is_domain(self, VTSM_DOMAIN);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
939 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
940 /* Video Title domain (playing movie). */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
941 int8_t dvdnav_is_domain_vts(dvdnav_t *self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
942 return _dvdnav_is_domain(self, VTS_DOMAIN);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
943 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
944
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
945 /* Generally delegate angle information handling to
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
946 * VM */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
947 dvdnav_status_t dvdnav_angle_change(dvdnav_t *self, int angle) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
948 int num, current;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
949
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
950 if(!self) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
951 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
952 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
953
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
954 if(dvdnav_get_angle_info(self, &current, &num) != S_OK) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
955 printerr("Error getting angle info");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
956 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
957 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
958
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
959 /* Set angle SPRM if valid */
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
960 if((angle > 0) && (angle <= num)) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
961 self->vm->state.AGL_REG = angle;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
962 } else {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
963 printerr("Passed an invalid angle number");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
964 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
965 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
966
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
967 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
968 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
969
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
970 dvdnav_status_t dvdnav_get_angle_info(dvdnav_t *self, int* current_angle,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
971 int *number_of_angles) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
972 if(!self || !self->vm) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
973 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
974 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
975
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
976 if(!current_angle || !number_of_angles) {
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
977 printerr("Passed a NULL pointer");
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
978 return S_ERR;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
979 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
980
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
981 vm_get_angle_info(self->vm, number_of_angles, current_angle);
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
982
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
983 return S_OK;
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
984 }
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
985
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
986
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
987 /*
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
988 * $Log$
4
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
989 * Revision 1.3 2002/04/02 18:22:27 richwareham
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
990 * Added reset patch from Kees Cook <kees@outflux.net>
99bed5d6db2f Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents: 3
diff changeset
991 *
3
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
992 * Revision 1.2 2002/04/01 18:56:28 richwareham
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
993 * Added initial example programs directory and make sure all debug/error output goes to stderr.
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
994 *
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
995 * Revision 1.1.1.1 2002/03/12 19:45:57 richwareham
328eadb3f37e Added initial example programs directory and make sure all debug/error output goes to stderr.
richwareham
parents: 0
diff changeset
996 * Initial import
0
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
997 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
998 * Revision 1.28 2002/02/02 23:26:20 richwareham
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
999 * Restored title selection
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1000 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1001 * Revision 1.27 2002/02/01 15:48:10 richwareham
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1002 * Re-implemented angle selection and title/chapter display
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1003 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1004 * Revision 1.26 2002/01/31 16:53:49 richwareham
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1005 * Big patch from Daniel Caujolle-Bert to (re)implement SPU/Audio language display
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1006 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1007 * Revision 1.25 2002/01/24 20:53:50 richwareham
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1008 * Added option to _not_ use DVD read-ahead to options
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1009 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1010 * Revision 1.24 2002/01/20 15:54:59 jcdutton
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1011 * Implement seeking.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1012 * It is still a bit buggy, but works sometimes.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1013 * I need to find out how to make the jump clean.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1014 * At the moment, some corruption of the mpeg2 stream occurs,
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1015 * which causes libmpeg2 to crash.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1016 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1017 * Revision 1.23 2002/01/18 00:23:52 jcdutton
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1018 * Support Ejecting of DVD.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1019 * It will first un-mount the DVD, then eject it.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1020 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1021 * Revision 1.22 2002/01/17 14:50:32 jcdutton
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1022 * Fix corruption of stream during menu transitions.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1023 * Menu transitions are now clean.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1024 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1025 * Revision 1.21 2002/01/15 00:37:03 jcdutton
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1026 * Just a few cleanups, and a assert fix. (memset fixed it)
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1027 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1028 * Revision 1.20 2002/01/13 22:17:57 jcdutton
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1029 * Change logging.
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1030 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1031 *
3ddf0eaece51 Initial revision
richwareham
parents:
diff changeset
1032 */