Mercurial > libdvdnav.hg
annotate dvdnav.c @ 389:d3c273ced49c src
Use consistent license headers everywhere: Fix wrong FSF address.
| author | diego |
|---|---|
| date | Sun, 14 Sep 2008 15:40:51 +0000 |
| parents | 90ca650854e0 |
| children | 0a5a6f03b029 |
| rev | line source |
|---|---|
| 388 | 1 /* |
| 0 | 2 * Copyright (C) 2000 Rich Wareham <richwareham@users.sourceforge.net> |
| 388 | 3 * |
| 0 | 4 * This file is part of libdvdnav, a DVD navigation library. |
| 388 | 5 * |
| 0 | 6 * libdvdnav is free software; you can redistribute it and/or modify |
| 7 * it under the terms of the GNU General Public License as published by | |
| 8 * the Free Software Foundation; either version 2 of the License, or | |
| 9 * (at your option) any later version. | |
| 388 | 10 * |
| 0 | 11 * libdvdnav is distributed in the hope that it will be useful, |
| 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 * GNU General Public License for more details. | |
| 388 | 15 * |
|
389
d3c273ced49c
Use consistent license headers everywhere: Fix wrong FSF address.
diego
parents:
388
diff
changeset
|
16 * You should have received a copy of the GNU General Public License along |
|
d3c273ced49c
Use consistent license headers everywhere: Fix wrong FSF address.
diego
parents:
388
diff
changeset
|
17 * with libdvdnav; if not, write to the Free Software Foundation, Inc., |
|
d3c273ced49c
Use consistent license headers everywhere: Fix wrong FSF address.
diego
parents:
388
diff
changeset
|
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. |
| 0 | 19 * |
| 20 * $Id$ | |
| 21 * | |
| 22 */ | |
| 23 | |
| 24 #ifdef HAVE_CONFIG_H | |
| 25 #include "config.h" | |
| 26 #endif | |
| 27 | |
| 31 | 28 /* |
| 29 #define LOG_DEBUG | |
| 30 */ | |
| 31 | |
| 278 | 32 #include <inttypes.h> |
|
288
ce4230602517
moved away from dvdnav_internal.h inclusion of various system headers
nicodvb
parents:
285
diff
changeset
|
33 #include <stdlib.h> |
|
ce4230602517
moved away from dvdnav_internal.h inclusion of various system headers
nicodvb
parents:
285
diff
changeset
|
34 #include <stdio.h> |
|
ce4230602517
moved away from dvdnav_internal.h inclusion of various system headers
nicodvb
parents:
285
diff
changeset
|
35 #include <unistd.h> |
|
ce4230602517
moved away from dvdnav_internal.h inclusion of various system headers
nicodvb
parents:
285
diff
changeset
|
36 #include <limits.h> |
|
ce4230602517
moved away from dvdnav_internal.h inclusion of various system headers
nicodvb
parents:
285
diff
changeset
|
37 #include <string.h> |
| 291 | 38 #include <sys/time.h> |
|
285
52877d182e96
moved all header inclusions from .h to .c files; my word, I've never seen such a horrible entanglement as in this mess
nicodvb
parents:
278
diff
changeset
|
39 #include "dvd_types.h" |
| 386 | 40 #include <dvdread/dvd_reader.h> |
| 41 #include <dvdread/nav_types.h> | |
| 42 #include <dvdread/ifo_types.h> /* For vm_cmd_t */ | |
|
285
52877d182e96
moved all header inclusions from .h to .c files; my word, I've never seen such a horrible entanglement as in this mess
nicodvb
parents:
278
diff
changeset
|
43 #include "remap.h" |
|
52877d182e96
moved all header inclusions from .h to .c files; my word, I've never seen such a horrible entanglement as in this mess
nicodvb
parents:
278
diff
changeset
|
44 #include "vm/decoder.h" |
|
52877d182e96
moved all header inclusions from .h to .c files; my word, I've never seen such a horrible entanglement as in this mess
nicodvb
parents:
278
diff
changeset
|
45 #include "vm/vm.h" |
|
52877d182e96
moved all header inclusions from .h to .c files; my word, I've never seen such a horrible entanglement as in this mess
nicodvb
parents:
278
diff
changeset
|
46 #include "dvdnav.h" |
|
52877d182e96
moved all header inclusions from .h to .c files; my word, I've never seen such a horrible entanglement as in this mess
nicodvb
parents:
278
diff
changeset
|
47 #include "dvdnav_events.h" |
| 0 | 48 #include "dvdnav_internal.h" |
| 49 #include "read_cache.h" | |
| 386 | 50 #include <dvdread/nav_read.h> |
|
97
c1dff1899bda
First patch for personalized dvd viewing. I have not tested it yet.
jcdutton
parents:
92
diff
changeset
|
51 #include "remap.h" |
|
c1dff1899bda
First patch for personalized dvd viewing. I have not tested it yet.
jcdutton
parents:
92
diff
changeset
|
52 |
| 114 | 53 static dvdnav_status_t dvdnav_clear(dvdnav_t * this) { |
| 54 /* clear everything except file, vm, mutex, readahead */ | |
|
21
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
55 |
|
338
0dc09442ff9c
added missing mutex around the code in dvdnav_clear() ; patch by Erik Hovland - erik hovland org
nicodvb
parents:
337
diff
changeset
|
56 pthread_mutex_lock(&this->vm_lock); |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
57 if (this->file) DVDCloseFile(this->file); |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
58 this->file = NULL; |
|
4
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
3
diff
changeset
|
59 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
60 memset(&this->pci,0,sizeof(this->pci)); |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
61 memset(&this->dsi,0,sizeof(this->dsi)); |
|
197
a20a5976a207
last_cmd_nav_lbn has to be initialized with an invalid value, so that the first
mroi
parents:
195
diff
changeset
|
62 this->last_cmd_nav_lbn = SRI_END_OF_CELL; |
|
4
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
3
diff
changeset
|
63 |
|
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
3
diff
changeset
|
64 /* Set initial values of flags */ |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
65 this->position_current.still = 0; |
| 23 | 66 this->skip_still = 0; |
| 116 | 67 this->sync_wait = 0; |
| 68 this->sync_wait_skip = 0; | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
69 this->spu_clut_changed = 0; |
| 114 | 70 this->started = 0; |
|
269
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
71 this->cur_cell_time = 0; |
|
4
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
3
diff
changeset
|
72 |
|
34
1f29402ef2ef
'Objectified' the read-ahead cache in preparation to implement a 'proper' threaded cache a-la that recommended in the DVD Demystified book.
richwareham
parents:
33
diff
changeset
|
73 dvdnav_read_cache_clear(this->cache); |
|
338
0dc09442ff9c
added missing mutex around the code in dvdnav_clear() ; patch by Erik Hovland - erik hovland org
nicodvb
parents:
337
diff
changeset
|
74 pthread_mutex_unlock(&this->vm_lock); |
| 388 | 75 |
| 193 | 76 return DVDNAV_STATUS_OK; |
|
4
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 |
| 114 | 79 dvdnav_status_t dvdnav_open(dvdnav_t** dest, const char *path) { |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
80 dvdnav_t *this; |
| 84 | 81 struct timeval time; |
| 388 | 82 |
| 0 | 83 /* Create a new structure */ |
|
380
3e3119415275
remove obsolete URL from info message (until we get a proper homepage)
rathann
parents:
378
diff
changeset
|
84 fprintf(MSG_OUT, "libdvdnav: Using dvdnav version %s\n", VERSION); |
| 82 | 85 |
| 0 | 86 (*dest) = NULL; |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
87 this = (dvdnav_t*)malloc(sizeof(dvdnav_t)); |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
88 if(!this) |
| 193 | 89 return DVDNAV_STATUS_ERR; |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
90 memset(this, 0, (sizeof(dvdnav_t) ) ); /* Make sure this structure is clean */ |
| 388 | 91 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
92 pthread_mutex_init(&this->vm_lock, NULL); |
| 0 | 93 /* Initialise the error string */ |
| 94 printerr(""); | |
| 95 | |
| 96 /* Initialise the VM */ | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
97 this->vm = vm_new_vm(); |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
98 if(!this->vm) { |
| 114 | 99 printerr("Error initialising the DVD VM."); |
| 92 | 100 pthread_mutex_destroy(&this->vm_lock); |
| 101 free(this); | |
| 193 | 102 return DVDNAV_STATUS_ERR; |
| 0 | 103 } |
| 114 | 104 if(!vm_reset(this->vm, path)) { |
| 105 printerr("Error starting the VM / opening the DVD device."); | |
| 92 | 106 pthread_mutex_destroy(&this->vm_lock); |
| 107 vm_free_vm(this->vm); | |
| 108 free(this); | |
| 193 | 109 return DVDNAV_STATUS_ERR; |
| 0 | 110 } |
| 111 | |
| 112 /* Set the path. FIXME: Is a deep copy 'right' */ | |
|
337
f08dbb15ece1
in dvdnav_open() make sure to NULL-terminate this->path and to not overrun its length; patch by Erik Hovland - erik hovland org
nicodvb
parents:
300
diff
changeset
|
113 strncpy(this->path, path, MAX_PATH_LEN - 1); |
|
f08dbb15ece1
in dvdnav_open() make sure to NULL-terminate this->path and to not overrun its length; patch by Erik Hovland - erik hovland org
nicodvb
parents:
300
diff
changeset
|
114 this->path[MAX_PATH_LEN - 1] = '\0'; |
| 0 | 115 |
| 116 /* Pre-open and close a file so that the CSS-keys are cached. */ | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
117 this->file = DVDOpenFile(vm_get_dvd_reader(this->vm), 0, DVD_READ_MENU_VOBS); |
| 388 | 118 |
|
34
1f29402ef2ef
'Objectified' the read-ahead cache in preparation to implement a 'proper' threaded cache a-la that recommended in the DVD Demystified book.
richwareham
parents:
33
diff
changeset
|
119 /* Start the read-ahead cache. */ |
|
1f29402ef2ef
'Objectified' the read-ahead cache in preparation to implement a 'proper' threaded cache a-la that recommended in the DVD Demystified book.
richwareham
parents:
33
diff
changeset
|
120 this->cache = dvdnav_read_cache_new(this); |
| 84 | 121 |
| 114 | 122 /* Seed the random numbers. So that the DVD VM Command rand() |
| 123 * gives a different start value each time a DVD is played. */ | |
| 124 gettimeofday(&time, NULL); | |
| 84 | 125 srand(time.tv_usec); |
| 388 | 126 |
| 114 | 127 dvdnav_clear(this); |
| 388 | 128 |
| 114 | 129 (*dest) = this; |
| 193 | 130 return DVDNAV_STATUS_OK; |
| 0 | 131 } |
| 132 | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
133 dvdnav_status_t dvdnav_close(dvdnav_t *this) { |
| 114 | 134 |
| 31 | 135 #ifdef LOG_DEBUG |
| 76 | 136 fprintf(MSG_OUT, "libdvdnav: close:called\n"); |
| 31 | 137 #endif |
|
34
1f29402ef2ef
'Objectified' the read-ahead cache in preparation to implement a 'proper' threaded cache a-la that recommended in the DVD Demystified book.
richwareham
parents:
33
diff
changeset
|
138 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
139 if (this->file) { |
| 388 | 140 pthread_mutex_lock(&this->vm_lock); |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
141 DVDCloseFile(this->file); |
| 31 | 142 #ifdef LOG_DEBUG |
| 76 | 143 fprintf(MSG_OUT, "libdvdnav: close:file closing\n"); |
| 31 | 144 #endif |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
145 this->file = NULL; |
| 388 | 146 pthread_mutex_unlock(&this->vm_lock); |
| 0 | 147 } |
| 148 | |
| 149 /* Free the VM */ | |
| 114 | 150 if(this->vm) |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
151 vm_free_vm(this->vm); |
| 114 | 152 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
153 pthread_mutex_destroy(&this->vm_lock); |
| 60 | 154 |
| 155 /* We leave the final freeing of the entire structure to the cache, | |
| 156 * because we don't know, if there are still buffers out in the wild, | |
| 157 * that must return first. */ | |
| 114 | 158 if(this->cache) |
| 60 | 159 dvdnav_read_cache_free(this->cache); |
| 114 | 160 else |
| 161 free(this); | |
| 388 | 162 |
| 193 | 163 return DVDNAV_STATUS_OK; |
| 0 | 164 } |
| 165 | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
166 dvdnav_status_t dvdnav_reset(dvdnav_t *this) { |
|
4
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
3
diff
changeset
|
167 dvdnav_status_t result; |
|
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
3
diff
changeset
|
168 |
| 31 | 169 #ifdef LOG_DEBUG |
| 76 | 170 fprintf(MSG_OUT, "libdvdnav: reset:called\n"); |
| 31 | 171 #endif |
| 114 | 172 |
| 388 | 173 pthread_mutex_lock(&this->vm_lock); |
| 114 | 174 |
| 31 | 175 #ifdef LOG_DEBUG |
| 76 | 176 fprintf(MSG_OUT, "libdvdnav: reseting vm\n"); |
| 31 | 177 #endif |
| 114 | 178 if(!vm_reset(this->vm, NULL)) { |
| 179 printerr("Error restarting the VM."); | |
| 388 | 180 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 181 return DVDNAV_STATUS_ERR; |
|
4
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
3
diff
changeset
|
182 } |
| 31 | 183 #ifdef LOG_DEBUG |
| 76 | 184 fprintf(MSG_OUT, "libdvdnav: clearing dvdnav\n"); |
| 31 | 185 #endif |
| 114 | 186 result = dvdnav_clear(this); |
| 187 | |
| 388 | 188 pthread_mutex_unlock(&this->vm_lock); |
|
4
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
3
diff
changeset
|
189 return result; |
|
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
3
diff
changeset
|
190 } |
|
99bed5d6db2f
Added reset patch from Kees Cook <kees@outflux.net>
richwareham
parents:
3
diff
changeset
|
191 |
| 114 | 192 dvdnav_status_t dvdnav_path(dvdnav_t *this, const char** path) { |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
193 (*path) = this->path; |
| 0 | 194 |
| 193 | 195 return DVDNAV_STATUS_OK; |
| 0 | 196 } |
| 197 | |
| 114 | 198 const char* dvdnav_err_to_string(dvdnav_t *this) { |
| 388 | 199 |
| 114 | 200 if(!this) |
|
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!"; |
| 388 | 202 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
203 return this->err_str; |
| 0 | 204 } |
| 205 | |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
206 /* converts a dvd_time_t to PTS ticks */ |
| 265 | 207 int64_t dvdnav_convert_time(dvd_time_t *time) { |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
208 int64_t result; |
| 195 | 209 int64_t frames; |
| 388 | 210 |
| 135 | 211 result = (time->hour >> 4 ) * 10 * 60 * 60 * 90000; |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
212 result += (time->hour & 0x0f) * 60 * 60 * 90000; |
| 135 | 213 result += (time->minute >> 4 ) * 10 * 60 * 90000; |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
214 result += (time->minute & 0x0f) * 60 * 90000; |
| 135 | 215 result += (time->second >> 4 ) * 10 * 90000; |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
216 result += (time->second & 0x0f) * 90000; |
| 388 | 217 |
| 135 | 218 frames = ((time->frame_u & 0x30) >> 4) * 10; |
| 219 frames += ((time->frame_u & 0x0f) ) ; | |
| 388 | 220 |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
221 if (time->frame_u & 0x80) |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
222 result += frames * 3000; |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
223 else |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
224 result += frames * 3600; |
| 388 | 225 |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
226 return result; |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
227 } |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
228 |
| 114 | 229 /* |
| 0 | 230 * Returns 1 if block contains NAV packet, 0 otherwise. |
| 217 | 231 * Processes said NAV packet if present. |
| 0 | 232 * |
| 233 * Most of the code in here is copied from xine's MPEG demuxer | |
| 234 * so any bugs which are found in that should be corrected here also. | |
| 235 */ | |
| 195 | 236 static int32_t dvdnav_decode_packet(dvdnav_t *this, uint8_t *p, dsi_t *nav_dsi, pci_t *nav_pci) { |
| 237 int32_t bMpeg1 = 0; | |
| 0 | 238 uint32_t nHeaderLen; |
| 239 uint32_t nPacketLen; | |
| 240 uint32_t nStreamID; | |
| 241 | |
| 242 if (p[3] == 0xBA) { /* program stream pack header */ | |
| 195 | 243 int32_t nStuffingBytes; |
| 0 | 244 |
| 245 bMpeg1 = (p[4] & 0x40) == 0; | |
| 246 | |
| 247 if (bMpeg1) { | |
| 114 | 248 p += 12; |
| 0 | 249 } else { /* mpeg2 */ |
| 250 nStuffingBytes = p[0xD] & 0x07; | |
| 251 p += 14 + nStuffingBytes; | |
| 252 } | |
| 253 } | |
| 254 | |
| 255 if (p[3] == 0xbb) { /* program stream system header */ | |
| 256 nHeaderLen = (p[4] << 8) | p[5]; | |
| 257 p += 6 + nHeaderLen; | |
| 258 } | |
| 259 | |
| 260 /* we should now have a PES packet here */ | |
| 261 if (p[0] || p[1] || (p[2] != 1)) { | |
| 76 | 262 fprintf(MSG_OUT, "libdvdnav: demux error! %02x %02x %02x (should be 0x000001) \n",p[0],p[1],p[2]); |
| 0 | 263 return 0; |
| 264 } | |
| 265 | |
| 266 nPacketLen = p[4] << 8 | p[5]; | |
| 267 nStreamID = p[3]; | |
| 268 | |
| 269 nHeaderLen = 6; | |
| 270 p += nHeaderLen; | |
| 271 | |
| 272 if (nStreamID == 0xbf) { /* Private stream 2 */ | |
| 114 | 273 #if 0 |
| 195 | 274 int32_t i; |
| 114 | 275 fprintf(MSG_OUT, "libdvdnav: nav packet=%u\n",p-p_start-6); |
| 276 for(i=0;i<80;i++) | |
| 277 fprintf(MSG_OUT, "%02x ",p[i-6]); | |
| 278 fprintf(MSG_OUT, "\n"); | |
| 279 #endif | |
| 280 | |
| 0 | 281 if(p[0] == 0x00) { |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
282 navRead_PCI(nav_pci, p+1); |
| 0 | 283 } |
| 284 | |
| 285 p += nPacketLen; | |
| 286 | |
| 287 /* We should now have a DSI packet. */ | |
| 288 if(p[6] == 0x01) { | |
| 289 nPacketLen = p[4] << 8 | p[5]; | |
| 290 p += 6; | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
291 navRead_DSI(nav_dsi, p+1); |
| 388 | 292 } |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
293 return 1; |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
294 } |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
295 return 0; |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
296 } |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
297 |
| 388 | 298 /* DSI is used for most angle stuff. |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
299 * PCI is used for only non-seemless angle stuff |
| 388 | 300 */ |
| 195 | 301 static int32_t dvdnav_get_vobu(dvdnav_t *this, dsi_t *nav_dsi, pci_t *nav_pci, dvdnav_vobu_t *vobu) { |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
302 uint32_t next; |
| 195 | 303 int32_t angle, num_angle; |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
304 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
305 vobu->vobu_start = nav_dsi->dsi_gi.nv_pck_lbn; /* Absolute offset from start of disk */ |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
306 vobu->vobu_length = nav_dsi->dsi_gi.vobu_ea; /* Relative offset from vobu_start */ |
| 388 | 307 |
|
43
0ba15bf3dc25
Biiiiiiig change to let doxygen generate some docs for the library. Note that I'm in no way sure that the autoconf stuff plays nice.
richwareham
parents:
42
diff
changeset
|
308 /* |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
309 * If we're not at the end of this cell, we can determine the next |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
310 * VOBU to display using the VOBU_SRI information section of the |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
311 * DSI. Using this value correctly follows the current angle, |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
312 * avoiding the doubled scenes in The Matrix, and makes our life |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
313 * really happy. |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
314 * |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
315 * vobu_next is an offset value, 0x3fffffff = SRI_END_OF_CELL |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
316 * DVDs are about 6 Gigs, which is only up to 0x300000 blocks |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
317 * Should really assert if bit 31 != 1 |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
318 */ |
| 388 | 319 |
| 114 | 320 #if 0 |
| 321 /* Old code -- may still be useful one day */ | |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
322 if(nav_dsi->vobu_sri.next_vobu != SRI_END_OF_CELL ) { |
|
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
323 vobu->vobu_next = ( nav_dsi->vobu_sri.next_vobu & 0x3fffffff ); |
|
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
324 } else { |
|
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
325 vobu->vobu_next = vobu->vobu_length; |
| 114 | 326 } |
| 327 #else | |
| 328 /* Relative offset from vobu_start */ | |
| 329 vobu->vobu_next = ( nav_dsi->vobu_sri.next_vobu & 0x3fffffff ); | |
| 330 #endif | |
| 388 | 331 |
| 114 | 332 vm_get_angle_info(this->vm, &angle, &num_angle); |
| 333 | |
| 334 /* FIMXE: The angle reset doesn't work for some reason for the moment */ | |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
335 #if 0 |
|
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
336 if((num_angle < angle) && (angle != 1)) { |
| 114 | 337 fprintf(MSG_OUT, "libdvdnav: angle ends!\n"); |
| 388 | 338 |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
339 /* This is to switch back to angle one when we |
|
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
340 * finish with angles. */ |
| 114 | 341 dvdnav_angle_change(this, 1); |
| 388 | 342 } |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
343 #endif |
| 0 | 344 |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
345 if(num_angle != 0) { |
| 388 | 346 |
| 114 | 347 if((next = nav_pci->nsml_agli.nsml_agl_dsta[angle-1]) != 0) { |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
348 if((next & 0x3fffffff) != 0) { |
| 114 | 349 if(next & 0x80000000) |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
350 vobu->vobu_next = - (int32_t)(next & 0x3fffffff); |
| 114 | 351 else |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
352 vobu->vobu_next = + (int32_t)(next & 0x3fffffff); |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
353 } |
| 114 | 354 } else if((next = nav_dsi->sml_agli.data[angle-1].address) != 0) { |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
355 vobu->vobu_length = nav_dsi->sml_pbi.ilvu_ea; |
| 388 | 356 |
| 114 | 357 if((next & 0x80000000) && (next != 0x7fffffff)) |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
358 vobu->vobu_next = - (int32_t)(next & 0x3fffffff); |
| 114 | 359 else |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
360 vobu->vobu_next = + (int32_t)(next & 0x3fffffff); |
| 0 | 361 } |
| 362 } | |
|
33
ef2136c4e7b2
Angles now work (still a few wrinkles though -- e.g. angle does not reset to '1' when returning to menus)
richwareham
parents:
31
diff
changeset
|
363 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
364 return 1; |
| 0 | 365 } |
| 60 | 366 |
| 114 | 367 /* |
| 368 * These are the main get_next_block function which actually get the media stream video and audio etc. | |
| 369 * | |
| 370 * There are two versions: The second one is using the zero-copy read ahead cache and therefore | |
| 371 * hands out pointers targetting directly into the cache. | |
| 372 * The first one uses a memcopy to fill this cache block into the application provided memory. | |
| 373 * The benefit of this first one is that no special memory management is needed. The application is | |
| 374 * the only one responsible of allocating and freeing the memory associated with the pointer. | |
| 375 * The drawback is the additional memcopy. | |
| 28 | 376 */ |
| 60 | 377 |
| 195 | 378 dvdnav_status_t dvdnav_get_next_block(dvdnav_t *this, uint8_t *buf, |
| 379 int32_t *event, int32_t *len) { | |
| 60 | 380 unsigned char *block; |
| 381 dvdnav_status_t status; | |
| 388 | 382 |
| 60 | 383 block = buf; |
| 384 status = dvdnav_get_next_cache_block(this, &block, event, len); | |
| 193 | 385 if (status == DVDNAV_STATUS_OK && block != buf) { |
| 60 | 386 /* we received a block from the cache, copy it, so we can give it back */ |
| 387 memcpy(buf, block, DVD_VIDEO_LB_LEN); | |
| 388 dvdnav_free_cache_block(this, block); | |
| 389 } | |
| 390 return status; | |
| 391 } | |
|
269
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
392 |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
393 int64_t dvdnav_get_current_time(dvdnav_t *this) { |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
394 int i; |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
395 int64_t tm=0; |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
396 dvd_state_t *state = &this->vm->state; |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
397 |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
398 for(i=0; i<state->cellN-1; i++) { |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
399 if(! |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
400 (state->pgc->cell_playback[i].block_type == BLOCK_TYPE_ANGLE_BLOCK && |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
401 state->pgc->cell_playback[i].block_mode != BLOCK_MODE_FIRST_CELL) |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
402 ) |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
403 tm += dvdnav_convert_time(&state->pgc->cell_playback[i].playback_time); |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
404 } |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
405 tm += this->cur_cell_time; |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
406 |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
407 return tm; |
|
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
408 } |
| 388 | 409 |
| 195 | 410 dvdnav_status_t dvdnav_get_next_cache_block(dvdnav_t *this, uint8_t **buf, |
| 411 int32_t *event, int32_t *len) { | |
| 0 | 412 dvd_state_t *state; |
| 195 | 413 int32_t result; |
| 114 | 414 |
| 415 pthread_mutex_lock(&this->vm_lock); | |
| 388 | 416 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
417 if(!this->started) { |
| 0 | 418 /* Start the VM */ |
|
256
6299ccea8a38
killing a lot of asserts and turning them into forced executions of Exit,
mroi
parents:
249
diff
changeset
|
419 if (!vm_start(this->vm)) { |
|
6299ccea8a38
killing a lot of asserts and turning them into forced executions of Exit,
mroi
parents:
249
diff
changeset
|
420 printerr("Encrypted or faulty DVD"); |
|
339
d0bfcfa565b0
in dvdnav_get_next_cache_block() release the mutex if vm_start() failed ; patch by Erik Hovland - erik hovland org
nicodvb
parents:
338
diff
changeset
|
421 pthread_mutex_unlock(&this->vm_lock); |
|
256
6299ccea8a38
killing a lot of asserts and turning them into forced executions of Exit,
mroi
parents:
249
diff
changeset
|
422 return DVDNAV_STATUS_ERR; |
|
6299ccea8a38
killing a lot of asserts and turning them into forced executions of Exit,
mroi
parents:
249
diff
changeset
|
423 } |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
424 this->started = 1; |
| 0 | 425 } |
| 426 | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
427 state = &(this->vm->state); |
| 0 | 428 (*event) = DVDNAV_NOP; |
| 429 (*len) = 0; | |
| 388 | 430 |
| 0 | 431 /* Check the STOP flag */ |
| 114 | 432 if(this->vm->stopped) { |
| 121 | 433 vm_stop(this->vm); |
| 0 | 434 (*event) = DVDNAV_STOP; |
| 114 | 435 this->started = 0; |
| 388 | 436 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 437 return DVDNAV_STATUS_OK; |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
438 } |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
439 |
| 114 | 440 vm_position_get(this->vm, &this->position_next); |
| 388 | 441 |
| 126 | 442 #ifdef LOG_DEBUG |
| 114 | 443 fprintf(MSG_OUT, "libdvdnav: POS-NEXT "); |
| 444 vm_position_print(this->vm, &this->position_next); | |
| 116 | 445 fprintf(MSG_OUT, "libdvdnav: POS-CUR "); |
| 114 | 446 vm_position_print(this->vm, &this->position_current); |
| 31 | 447 #endif |
| 114 | 448 |
| 449 /* did we hop? */ | |
| 450 if(this->position_current.hop_channel != this->position_next.hop_channel) { | |
| 451 (*event) = DVDNAV_HOP_CHANNEL; | |
| 58 | 452 #ifdef LOG_DEBUG |
| 114 | 453 fprintf(MSG_OUT, "libdvdnav: HOP_CHANNEL\n"); |
| 31 | 454 #endif |
| 115 | 455 if (this->position_next.hop_channel - this->position_current.hop_channel >= HOP_SEEK) { |
| 195 | 456 int32_t num_angles = 0, current; |
| 388 | 457 |
| 114 | 458 /* we seeked -> check for multiple angles */ |
| 459 vm_get_angle_info(this->vm, ¤t, &num_angles); | |
| 460 if (num_angles > 1) { | |
| 195 | 461 int32_t result, block; |
| 114 | 462 /* we have to skip the first VOBU when seeking in a multiangle feature, |
| 463 * because it might belong to the wrong angle */ | |
| 464 block = this->position_next.cell_start + this->position_next.block; | |
| 465 result = dvdnav_read_cache_block(this->cache, block, 1, buf); | |
| 466 if(result <= 0) { | |
| 467 printerr("Error reading NAV packet."); | |
| 388 | 468 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 469 return DVDNAV_STATUS_ERR; |
| 114 | 470 } |
| 471 /* Decode nav into pci and dsi. Then get next VOBU info. */ | |
| 472 if(!dvdnav_decode_packet(this, *buf, &this->dsi, &this->pci)) { | |
| 473 printerr("Expected NAV packet but none found."); | |
| 388 | 474 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 475 return DVDNAV_STATUS_ERR; |
| 114 | 476 } |
| 477 dvdnav_get_vobu(this, &this->dsi, &this->pci, &this->vobu); | |
| 478 /* skip to next, if there is a next */ | |
| 479 if (this->vobu.vobu_next != SRI_END_OF_CELL) { | |
| 480 this->vobu.vobu_start += this->vobu.vobu_next; | |
| 481 this->vobu.vobu_next = 0; | |
| 482 } | |
| 483 /* update VM state */ | |
| 484 this->vm->state.blockN = this->vobu.vobu_start - this->position_next.cell_start; | |
| 485 } | |
| 486 } | |
| 487 this->position_current.hop_channel = this->position_next.hop_channel; | |
|
141
8f63f4c25f2f
update position on HOP_CHANNEL, do not rely on a following CELL_CHANGE
mroi
parents:
135
diff
changeset
|
488 /* update VOBU info */ |
|
8f63f4c25f2f
update position on HOP_CHANNEL, do not rely on a following CELL_CHANGE
mroi
parents:
135
diff
changeset
|
489 this->vobu.vobu_start = this->position_next.cell_start + this->position_next.block; |
|
8f63f4c25f2f
update position on HOP_CHANNEL, do not rely on a following CELL_CHANGE
mroi
parents:
135
diff
changeset
|
490 this->vobu.vobu_next = 0; |
| 127 | 491 /* Make blockN == vobu_length to do expected_nav */ |
| 114 | 492 this->vobu.vobu_length = 0; |
| 127 | 493 this->vobu.blockN = 0; |
| 116 | 494 this->sync_wait = 0; |
| 388 | 495 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 496 return DVDNAV_STATUS_OK; |
| 0 | 497 } |
| 498 | |
| 116 | 499 /* Check the HIGHLIGHT flag */ |
| 500 if(this->position_current.button != this->position_next.button) { | |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
501 dvdnav_highlight_event_t *hevent = (dvdnav_highlight_event_t *)*buf; |
| 116 | 502 |
| 503 (*event) = DVDNAV_HIGHLIGHT; | |
| 504 #ifdef LOG_DEBUG | |
| 505 fprintf(MSG_OUT, "libdvdnav: HIGHLIGHT\n"); | |
| 506 #endif | |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
507 (*len) = sizeof(dvdnav_highlight_event_t); |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
508 hevent->display = 1; |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
509 hevent->buttonN = this->position_next.button; |
| 116 | 510 this->position_current.button = this->position_next.button; |
| 388 | 511 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 512 return DVDNAV_STATUS_OK; |
| 116 | 513 } |
| 388 | 514 |
| 116 | 515 /* Check the WAIT flag */ |
| 516 if(this->sync_wait) { | |
| 517 (*event) = DVDNAV_WAIT; | |
| 518 #ifdef LOG_DEBUG | |
| 519 fprintf(MSG_OUT, "libdvdnav: WAIT\n"); | |
| 520 #endif | |
| 521 (*len) = 0; | |
| 522 pthread_mutex_unlock(&this->vm_lock); | |
| 193 | 523 return DVDNAV_STATUS_OK; |
| 116 | 524 } |
| 525 | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
526 /* Check to see if we need to change the currently opened VOB */ |
| 388 | 527 if((this->position_current.vts != this->position_next.vts) || |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
528 (this->position_current.domain != this->position_next.domain)) { |
| 0 | 529 dvd_read_domain_t domain; |
| 195 | 530 int32_t vtsN; |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
531 dvdnav_vts_change_event_t *vts_event = (dvdnav_vts_change_event_t *)*buf; |
| 388 | 532 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
533 if(this->file) { |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
534 DVDCloseFile(this->file); |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
535 this->file = NULL; |
| 0 | 536 } |
| 537 | |
| 217 | 538 vts_event->old_vtsN = this->position_current.vts; |
| 539 vts_event->old_domain = this->position_current.domain; | |
| 388 | 540 |
| 114 | 541 /* Use the DOMAIN to find whether to open menu or title VOBs */ |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
542 switch(this->position_next.domain) { |
| 114 | 543 case FP_DOMAIN: |
| 544 case VMGM_DOMAIN: | |
| 0 | 545 domain = DVD_READ_MENU_VOBS; |
| 546 vtsN = 0; | |
| 547 break; | |
| 114 | 548 case VTSM_DOMAIN: |
| 0 | 549 domain = DVD_READ_MENU_VOBS; |
| 388 | 550 vtsN = this->position_next.vts; |
| 0 | 551 break; |
| 114 | 552 case VTS_DOMAIN: |
| 0 | 553 domain = DVD_READ_TITLE_VOBS; |
| 388 | 554 vtsN = this->position_next.vts; |
| 0 | 555 break; |
| 114 | 556 default: |
| 0 | 557 printerr("Unknown domain when changing VTS."); |
| 388 | 558 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 559 return DVDNAV_STATUS_ERR; |
| 0 | 560 } |
| 388 | 561 |
| 562 this->position_current.vts = this->position_next.vts; | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
563 this->position_current.domain = this->position_next.domain; |
|
34
1f29402ef2ef
'Objectified' the read-ahead cache in preparation to implement a 'proper' threaded cache a-la that recommended in the DVD Demystified book.
richwareham
parents:
33
diff
changeset
|
564 dvdnav_read_cache_clear(this->cache); |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
565 this->file = DVDOpenFile(vm_get_dvd_reader(this->vm), vtsN, domain); |
| 388 | 566 vts_event->new_vtsN = this->position_next.vts; |
| 567 vts_event->new_domain = this->position_next.domain; | |
| 0 | 568 |
| 569 /* If couldn't open the file for some reason, moan */ | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
570 if(this->file == NULL) { |
| 0 | 571 printerrf("Error opening vtsN=%i, domain=%i.", vtsN, domain); |
| 388 | 572 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 573 return DVDNAV_STATUS_ERR; |
| 0 | 574 } |
| 575 | |
| 576 /* File opened successfully so return a VTS change event */ | |
| 577 (*event) = DVDNAV_VTS_CHANGE; | |
| 114 | 578 #ifdef LOG_DEBUG |
| 579 fprintf(MSG_OUT, "libdvdnav: VTS_CHANGE\n"); | |
| 580 #endif | |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
581 (*len) = sizeof(dvdnav_vts_change_event_t); |
| 0 | 582 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
583 this->spu_clut_changed = 1; |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
584 this->position_current.cell = -1; /* Force an update */ |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
585 this->position_current.spu_channel = -1; /* Force an update */ |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
586 this->position_current.audio_channel = -1; /* Force an update */; |
| 388 | 587 |
| 588 pthread_mutex_unlock(&this->vm_lock); | |
| 193 | 589 return DVDNAV_STATUS_OK; |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
590 } |
| 114 | 591 |
| 388 | 592 /* Check if the cell changed */ |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
593 if( (this->position_current.cell != this->position_next.cell) || |
|
50
578ce1d41479
Rename some of the functions in vm.c to help readability.
jcdutton
parents:
45
diff
changeset
|
594 (this->position_current.cell_restart != this->position_next.cell_restart) || |
| 114 | 595 (this->position_current.cell_start != this->position_next.cell_start) ) { |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
596 dvdnav_cell_change_event_t *cell_event = (dvdnav_cell_change_event_t *)*buf; |
| 195 | 597 int32_t first_cell_nr, last_cell_nr, i; |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
598 dvd_state_t *state = &this->vm->state; |
| 388 | 599 |
|
269
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
600 this->cur_cell_time = 0; |
| 114 | 601 (*event) = DVDNAV_CELL_CHANGE; |
| 602 #ifdef LOG_DEBUG | |
| 603 fprintf(MSG_OUT, "libdvdnav: CELL_CHANGE\n"); | |
| 604 #endif | |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
605 (*len) = sizeof(dvdnav_cell_change_event_t); |
| 388 | 606 |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
607 cell_event->cellN = state->cellN; |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
608 cell_event->pgN = state->pgN; |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
609 cell_event->cell_length = |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
610 dvdnav_convert_time(&state->pgc->cell_playback[state->cellN-1].playback_time); |
| 161 | 611 |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
612 cell_event->pg_length = 0; |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
613 /* Find start cell of program. */ |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
614 first_cell_nr = state->pgc->program_map[state->pgN-1]; |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
615 /* Find end cell of program */ |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
616 if(state->pgN < state->pgc->nr_of_programs) |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
617 last_cell_nr = state->pgc->program_map[state->pgN] - 1; |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
618 else |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
619 last_cell_nr = state->pgc->nr_of_cells; |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
620 for (i = first_cell_nr; i <= last_cell_nr; i++) |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
621 cell_event->pg_length += |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
622 dvdnav_convert_time(&state->pgc->cell_playback[i - 1].playback_time); |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
623 cell_event->pgc_length = dvdnav_convert_time(&state->pgc->playback_time); |
| 151 | 624 |
| 625 cell_event->cell_start = 0; | |
| 626 for (i = 1; i < state->cellN; i++) | |
| 627 cell_event->cell_start += | |
| 628 dvdnav_convert_time(&state->pgc->cell_playback[i - 1].playback_time); | |
| 161 | 629 |
| 630 cell_event->pg_start = 0; | |
| 631 for (i = 1; i < state->pgc->program_map[state->pgN-1]; i++) | |
| 632 cell_event->pg_start += | |
| 633 dvdnav_convert_time(&state->pgc->cell_playback[i - 1].playback_time); | |
| 634 | |
| 114 | 635 this->position_current.cell = this->position_next.cell; |
|
50
578ce1d41479
Rename some of the functions in vm.c to help readability.
jcdutton
parents:
45
diff
changeset
|
636 this->position_current.cell_restart = this->position_next.cell_restart; |
| 114 | 637 this->position_current.cell_start = this->position_next.cell_start; |
| 638 this->position_current.block = this->position_next.block; | |
| 388 | 639 |
| 114 | 640 /* vobu info is used for mid cell resumes */ |
| 641 this->vobu.vobu_start = this->position_next.cell_start + this->position_next.block; | |
| 642 this->vobu.vobu_next = 0; | |
| 127 | 643 /* Make blockN == vobu_length to do expected_nav */ |
| 114 | 644 this->vobu.vobu_length = 0; |
| 127 | 645 this->vobu.blockN = 0; |
| 388 | 646 |
| 114 | 647 /* update the spu palette at least on PGC changes */ |
| 648 this->spu_clut_changed = 1; | |
| 649 this->position_current.spu_channel = -1; /* Force an update */ | |
| 650 this->position_current.audio_channel = -1; /* Force an update */ | |
| 651 | |
| 388 | 652 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 653 return DVDNAV_STATUS_OK; |
| 0 | 654 } |
| 388 | 655 |
| 114 | 656 /* has the CLUT changed? */ |
| 657 if(this->spu_clut_changed) { | |
| 658 (*event) = DVDNAV_SPU_CLUT_CHANGE; | |
| 659 #ifdef LOG_DEBUG | |
| 660 fprintf(MSG_OUT, "libdvdnav: SPU_CLUT_CHANGE\n"); | |
| 661 #endif | |
| 662 (*len) = 16 * sizeof(uint32_t); | |
| 663 memcpy(*buf, &(state->pgc->palette), 16 * sizeof(uint32_t)); | |
| 664 this->spu_clut_changed = 0; | |
| 388 | 665 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 666 return DVDNAV_STATUS_OK; |
| 114 | 667 } |
| 668 | |
| 388 | 669 /* has the SPU channel changed? */ |
| 114 | 670 if(this->position_current.spu_channel != this->position_next.spu_channel) { |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
671 dvdnav_spu_stream_change_event_t *stream_change = (dvdnav_spu_stream_change_event_t *)*buf; |
| 114 | 672 |
| 673 (*event) = DVDNAV_SPU_STREAM_CHANGE; | |
| 674 #ifdef LOG_DEBUG | |
| 675 fprintf(MSG_OUT, "libdvdnav: SPU_STREAM_CHANGE\n"); | |
| 676 #endif | |
| 677 (*len) = sizeof(dvdnav_spu_stream_change_event_t); | |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
678 stream_change->physical_wide = vm_get_subp_active_stream(this->vm, 0); |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
679 stream_change->physical_letterbox = vm_get_subp_active_stream(this->vm, 1); |
|
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
680 stream_change->physical_pan_scan = vm_get_subp_active_stream(this->vm, 2); |
| 114 | 681 this->position_current.spu_channel = this->position_next.spu_channel; |
| 682 #ifdef LOG_DEBUG | |
|
143
0b302ca31859
merge James fixes from xine-lib cvs back into libdvdnav cvs so they will not be lost
mroi
parents:
142
diff
changeset
|
683 fprintf(MSG_OUT, "libdvdnav: SPU_STREAM_CHANGE stream_id_wide=%d\n",stream_change->physical_wide); |
|
0b302ca31859
merge James fixes from xine-lib cvs back into libdvdnav cvs so they will not be lost
mroi
parents:
142
diff
changeset
|
684 fprintf(MSG_OUT, "libdvdnav: SPU_STREAM_CHANGE stream_id_letterbox=%d\n",stream_change->physical_letterbox); |
|
0b302ca31859
merge James fixes from xine-lib cvs back into libdvdnav cvs so they will not be lost
mroi
parents:
142
diff
changeset
|
685 fprintf(MSG_OUT, "libdvdnav: SPU_STREAM_CHANGE stream_id_pan_scan=%d\n",stream_change->physical_pan_scan); |
|
249
5d643668f1e3
I added this code myself a long time ago, but now I am quite convinced that
mroi
parents:
231
diff
changeset
|
686 fprintf(MSG_OUT, "libdvdnav: SPU_STREAM_CHANGE returning DVDNAV_STATUS_OK\n"); |
| 114 | 687 #endif |
| 388 | 688 pthread_mutex_unlock(&this->vm_lock); |
|
249
5d643668f1e3
I added this code myself a long time ago, but now I am quite convinced that
mroi
parents:
231
diff
changeset
|
689 return DVDNAV_STATUS_OK; |
| 114 | 690 } |
| 0 | 691 |
| 388 | 692 /* has the audio channel changed? */ |
| 114 | 693 if(this->position_current.audio_channel != this->position_next.audio_channel) { |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
694 dvdnav_audio_stream_change_event_t *stream_change = (dvdnav_audio_stream_change_event_t *)*buf; |
| 388 | 695 |
| 114 | 696 (*event) = DVDNAV_AUDIO_STREAM_CHANGE; |
| 697 #ifdef LOG_DEBUG | |
| 698 fprintf(MSG_OUT, "libdvdnav: AUDIO_STREAM_CHANGE\n"); | |
| 699 #endif | |
| 700 (*len) = sizeof(dvdnav_audio_stream_change_event_t); | |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
701 stream_change->physical = vm_get_audio_active_stream( this->vm ); |
|
383
275f15342ea3
after an AUDIO change event assign the logical stream to the returned event,
nicodvb
parents:
380
diff
changeset
|
702 stream_change->logical = this->position_next.audio_channel; |
| 114 | 703 this->position_current.audio_channel = this->position_next.audio_channel; |
| 704 #ifdef LOG_DEBUG | |
| 193 | 705 fprintf(MSG_OUT, "libdvdnav: AUDIO_STREAM_CHANGE stream_id=%d returning DVDNAV_STATUS_OK\n",stream_change->physical); |
| 114 | 706 #endif |
| 388 | 707 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 708 return DVDNAV_STATUS_OK; |
| 114 | 709 } |
| 388 | 710 |
| 114 | 711 /* Check the STILLFRAME flag */ |
| 712 if(this->position_current.still != 0) { | |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
713 dvdnav_still_event_t *still_event = (dvdnav_still_event_t *)*buf; |
| 114 | 714 |
| 715 (*event) = DVDNAV_STILL_FRAME; | |
| 716 #ifdef LOG_DEBUG | |
| 717 fprintf(MSG_OUT, "libdvdnav: STILL_FRAME\n"); | |
| 718 #endif | |
| 719 (*len) = sizeof(dvdnav_still_event_t); | |
|
134
d9d75a22a061
- new event on cell changes to report program and cell number and some time info
mroi
parents:
127
diff
changeset
|
720 still_event->length = this->position_current.still; |
| 388 | 721 pthread_mutex_unlock(&this->vm_lock); |
| 194 | 722 return DVDNAV_STATUS_OK; |
| 114 | 723 } |
| 724 | |
| 725 /* Have we reached the end of a VOBU? */ | |
| 726 if (this->vobu.blockN >= this->vobu.vobu_length) { | |
| 727 | |
| 728 /* Have we reached the end of a cell? */ | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
729 if(this->vobu.vobu_next == SRI_END_OF_CELL) { |
|
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
730 /* End of Cell from NAV DSI info */ |
| 31 | 731 #ifdef LOG_DEBUG |
| 76 | 732 fprintf(MSG_OUT, "libdvdnav: Still set to %x\n", this->position_next.still); |
| 31 | 733 #endif |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
734 this->position_current.still = this->position_next.still; |
| 0 | 735 |
| 116 | 736 /* we are about to leave a cell, so a lot of state changes could occur; |
| 737 * under certain conditions, the application should get in sync with us before this, | |
| 738 * otherwise it might show stills or menus too shortly */ | |
| 739 if ((this->position_current.still || this->pci.hli.hl_gi.hli_ss) && !this->sync_wait_skip) { | |
| 740 this->sync_wait = 1; | |
| 741 } else { | |
| 742 if( this->position_current.still == 0 || this->skip_still ) { | |
| 743 /* no active cell still -> get us to the next cell */ | |
| 744 vm_get_next_cell(this->vm); | |
| 745 this->position_current.still = 0; /* still gets activated at end of cell */ | |
| 746 this->skip_still = 0; | |
| 747 this->sync_wait_skip = 0; | |
| 748 } | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
749 } |
| 114 | 750 /* handle related state changes in next iteration */ |
| 751 (*event) = DVDNAV_NOP; | |
| 752 (*len) = 0; | |
| 388 | 753 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 754 return DVDNAV_STATUS_OK; |
| 114 | 755 } |
| 0 | 756 |
| 388 | 757 /* Perform remapping jump if necessary (this is always a |
| 0 | 758 * VOBU boundary). */ |
| 114 | 759 if (this->vm->map) { |
| 760 this->vobu.vobu_next = remap_block( this->vm->map, | |
| 761 this->vm->state.domain, this->vm->state.TTN_REG, | |
| 762 this->vm->state.pgN, | |
| 763 this->vobu.vobu_start, this->vobu.vobu_next); | |
| 764 } | |
| 0 | 765 |
| 114 | 766 /* at the start of the next VOBU -> expecting NAV packet */ |
| 45 | 767 result = dvdnav_read_cache_block(this->cache, this->vobu.vobu_start + this->vobu.vobu_next, 1, buf); |
| 0 | 768 |
| 769 if(result <= 0) { | |
| 770 printerr("Error reading NAV packet."); | |
| 388 | 771 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 772 return DVDNAV_STATUS_ERR; |
| 0 | 773 } |
| 114 | 774 /* Decode nav into pci and dsi. Then get next VOBU info. */ |
| 775 if(!dvdnav_decode_packet(this, *buf, &this->dsi, &this->pci)) { | |
| 0 | 776 printerr("Expected NAV packet but none found."); |
| 388 | 777 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 778 return DVDNAV_STATUS_ERR; |
| 0 | 779 } |
| 114 | 780 /* We need to update the vm state->blockN with which VOBU we are in. |
| 781 * This is so RSM resumes to the VOBU level and not just the CELL level. | |
| 28 | 782 */ |
| 114 | 783 this->vm->state.blockN = this->vobu.vobu_start - this->position_current.cell_start; |
| 784 | |
| 388 | 785 dvdnav_get_vobu(this, &this->dsi, &this->pci, &this->vobu); |
| 114 | 786 this->vobu.blockN = 0; |
| 787 /* Give the cache a hint about the size of next VOBU. | |
| 788 * This improves pre-caching, because the VOBU will almost certainly be read entirely. | |
| 45 | 789 */ |
| 790 dvdnav_pre_cache_blocks(this->cache, this->vobu.vobu_start+1, this->vobu.vobu_length+1); | |
| 388 | 791 |
|
191
dbea22936623
when a command has been issued to leave a menu, filter all further commands
mroi
parents:
179
diff
changeset
|
792 /* release NAV menu filter, when we reach the same NAV packet again */ |
|
dbea22936623
when a command has been issued to leave a menu, filter all further commands
mroi
parents:
179
diff
changeset
|
793 if (this->last_cmd_nav_lbn == this->pci.pci_gi.nv_pck_lbn) |
|
198
373f27da196b
This one should also be reset to an invalid value, but 0 is not invalid.
mroi
parents:
197
diff
changeset
|
794 this->last_cmd_nav_lbn = SRI_END_OF_CELL; |
| 388 | 795 |
| 0 | 796 /* Successfully got a NAV packet */ |
| 797 (*event) = DVDNAV_NAV_PACKET; | |
| 114 | 798 #ifdef LOG_DEBUG |
| 799 fprintf(MSG_OUT, "libdvdnav: NAV_PACKET\n"); | |
| 800 #endif | |
| 388 | 801 (*len) = 2048; |
|
269
77e472cef5f8
implemented dvdnav_get_current_time() with obvious meaning
nicodvb
parents:
266
diff
changeset
|
802 this->cur_cell_time = dvdnav_convert_time(&this->dsi.dsi_gi.c_eltm); |
| 388 | 803 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 804 return DVDNAV_STATUS_OK; |
| 0 | 805 } |
| 388 | 806 |
| 0 | 807 /* If we've got here, it must just be a normal block. */ |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
808 if(!this->file) { |
| 114 | 809 printerr("Attempting to read without opening file."); |
| 388 | 810 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 811 return DVDNAV_STATUS_ERR; |
| 0 | 812 } |
| 813 | |
| 114 | 814 this->vobu.blockN++; |
|
34
1f29402ef2ef
'Objectified' the read-ahead cache in preparation to implement a 'proper' threaded cache a-la that recommended in the DVD Demystified book.
richwareham
parents:
33
diff
changeset
|
815 result = dvdnav_read_cache_block(this->cache, this->vobu.vobu_start + this->vobu.blockN, 1, buf); |
| 0 | 816 if(result <= 0) { |
| 817 printerr("Error reading from DVD."); | |
| 388 | 818 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 819 return DVDNAV_STATUS_ERR; |
| 0 | 820 } |
| 114 | 821 (*event) = DVDNAV_BLOCK_OK; |
| 0 | 822 (*len) = 2048; |
| 823 | |
| 388 | 824 pthread_mutex_unlock(&this->vm_lock); |
| 193 | 825 return DVDNAV_STATUS_OK; |
| 0 | 826 } |
| 827 | |
| 114 | 828 dvdnav_status_t dvdnav_get_title_string(dvdnav_t *this, const char **title_str) { |
| 829 (*title_str) = this->vm->dvd_name; | |
| 193 | 830 return DVDNAV_STATUS_OK; |
| 114 | 831 } |
| 832 | |
| 833 uint8_t dvdnav_get_video_aspect(dvdnav_t *this) { | |
| 834 uint8_t retval; | |
|
273
bd734ab914d0
removed nonsensical checks on the sanity of dvdnav_t *this
nicodvb
parents:
272
diff
changeset
|
835 |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
836 if(!this->started) { |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
837 printerr("Virtual DVD machine not started."); |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
838 return -1; |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
839 } |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
840 |
| 114 | 841 pthread_mutex_lock(&this->vm_lock); |
| 842 retval = (uint8_t)vm_get_video_aspect(this->vm); | |
| 843 pthread_mutex_unlock(&this->vm_lock); | |
| 388 | 844 |
| 114 | 845 return retval; |
| 846 } | |
| 847 | |
| 848 uint8_t dvdnav_get_video_scale_permission(dvdnav_t *this) { | |
| 849 uint8_t retval; | |
| 388 | 850 |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
851 if(!this->started) { |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
852 printerr("Virtual DVD machine not started."); |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
853 return -1; |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
854 } |
| 388 | 855 |
| 114 | 856 pthread_mutex_lock(&this->vm_lock); |
| 857 retval = (uint8_t)vm_get_video_scale_permission(this->vm); | |
| 858 pthread_mutex_unlock(&this->vm_lock); | |
| 388 | 859 |
| 114 | 860 return retval; |
| 861 } | |
| 862 | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
863 uint16_t dvdnav_audio_stream_to_lang(dvdnav_t *this, uint8_t stream) { |
|
25
df024077cbc1
Why rewrite vm function, use it instead (this remark is for me, of course ;-) ).
f1rmb
parents:
24
diff
changeset
|
864 audio_attr_t attr; |
| 388 | 865 |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
866 if(!this->started) { |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
867 printerr("Virtual DVD machine not started."); |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
868 return -1; |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
869 } |
| 388 | 870 |
| 871 pthread_mutex_lock(&this->vm_lock); | |
|
25
df024077cbc1
Why rewrite vm function, use it instead (this remark is for me, of course ;-) ).
f1rmb
parents:
24
diff
changeset
|
872 attr = vm_get_audio_attr(this->vm, stream); |
| 388 | 873 pthread_mutex_unlock(&this->vm_lock); |
| 874 | |
|
25
df024077cbc1
Why rewrite vm function, use it instead (this remark is for me, of course ;-) ).
f1rmb
parents:
24
diff
changeset
|
875 if(attr.lang_type != 1) |
|
21
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
876 return 0xffff; |
| 388 | 877 |
|
25
df024077cbc1
Why rewrite vm function, use it instead (this remark is for me, of course ;-) ).
f1rmb
parents:
24
diff
changeset
|
878 return attr.lang_code; |
| 0 | 879 } |
| 880 | |
| 266 | 881 uint16_t dvdnav_audio_stream_format(dvdnav_t *this, uint8_t stream) { |
| 882 audio_attr_t attr; | |
| 883 uint16_t format; | |
| 388 | 884 |
| 266 | 885 if(!this->started) { |
| 886 printerr("Virtual DVD machine not started."); | |
| 887 return -1; /* 0xffff */ | |
| 888 } | |
| 388 | 889 |
| 890 pthread_mutex_lock(&this->vm_lock); | |
| 266 | 891 attr = vm_get_audio_attr(this->vm, stream); |
| 388 | 892 pthread_mutex_unlock(&this->vm_lock); |
| 893 | |
| 266 | 894 switch(attr.audio_format) { |
| 895 case 0: | |
| 896 format = DVDNAV_FORMAT_AC3; | |
| 897 break; | |
| 898 case 2: /* MPEG-1 or MPEG-2 without extension bitstream. */ | |
| 899 case 3: /* MPEG-2 with extension bitstream. */ | |
| 900 format = DVDNAV_FORMAT_MPEGAUDIO; | |
| 901 break; | |
| 902 case 4: | |
| 903 format = DVDNAV_FORMAT_LPCM; | |
| 904 break; | |
| 905 case 6: | |
| 906 format = DVDNAV_FORMAT_DTS; | |
| 907 break; | |
| 908 case 7: | |
| 909 format = DVDNAV_FORMAT_SDDS; | |
| 910 break; | |
| 388 | 911 default: |
| 266 | 912 format = 0xffff; |
| 913 break; | |
| 914 } | |
| 388 | 915 |
| 266 | 916 return format; |
| 917 } | |
| 918 | |
|
272
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
919 uint16_t dvdnav_audio_stream_channels(dvdnav_t *this, uint8_t stream) { |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
920 audio_attr_t attr; |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
921 |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
922 if(!this->started) { |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
923 printerr("Virtual DVD machine not started."); |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
924 return -1; /* 0xffff */ |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
925 } |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
926 |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
927 pthread_mutex_lock(&this->vm_lock); |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
928 attr = vm_get_audio_attr(this->vm, stream); |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
929 pthread_mutex_unlock(&this->vm_lock); |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
930 |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
931 return attr.channels + 1; |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
932 } |
|
baec6f29fb76
added dvdnav_audio_stream_channels(); patch by Andreas Oman (andreas olebyn nu)
nicodvb
parents:
269
diff
changeset
|
933 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
934 uint16_t dvdnav_spu_stream_to_lang(dvdnav_t *this, uint8_t stream) { |
|
25
df024077cbc1
Why rewrite vm function, use it instead (this remark is for me, of course ;-) ).
f1rmb
parents:
24
diff
changeset
|
935 subp_attr_t attr; |
| 388 | 936 |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
937 if(!this->started) { |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
938 printerr("Virtual DVD machine not started."); |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
939 return -1; |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
940 } |
| 388 | 941 |
| 942 pthread_mutex_lock(&this->vm_lock); | |
|
25
df024077cbc1
Why rewrite vm function, use it instead (this remark is for me, of course ;-) ).
f1rmb
parents:
24
diff
changeset
|
943 attr = vm_get_subp_attr(this->vm, stream); |
| 388 | 944 pthread_mutex_unlock(&this->vm_lock); |
| 945 | |
|
25
df024077cbc1
Why rewrite vm function, use it instead (this remark is for me, of course ;-) ).
f1rmb
parents:
24
diff
changeset
|
946 if(attr.type != 1) |
|
21
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
947 return 0xffff; |
| 388 | 948 |
|
25
df024077cbc1
Why rewrite vm function, use it instead (this remark is for me, of course ;-) ).
f1rmb
parents:
24
diff
changeset
|
949 return attr.lang_code; |
|
21
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
950 } |
|
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
951 |
| 114 | 952 int8_t dvdnav_get_audio_logical_stream(dvdnav_t *this, uint8_t audio_num) { |
| 953 int8_t retval; | |
| 388 | 954 |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
955 if(!this->started) { |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
956 printerr("Virtual DVD machine not started."); |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
957 return -1; |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
958 } |
| 388 | 959 |
| 114 | 960 pthread_mutex_lock(&this->vm_lock); |
| 961 if (!this->vm->state.pgc) { | |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
962 printerr("No current PGC."); |
| 388 | 963 pthread_mutex_unlock(&this->vm_lock); |
| 114 | 964 return -1; |
| 965 } | |
| 966 retval = vm_get_audio_stream(this->vm, audio_num); | |
| 388 | 967 pthread_mutex_unlock(&this->vm_lock); |
| 114 | 968 |
| 969 return retval; | |
| 970 } | |
| 971 | |
|
300
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
972 dvdnav_status_t dvdnav_get_audio_attr(dvdnav_t *this, uint8_t audio_num, audio_attr_t *audio_attr) { |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
973 if(!this->started) { |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
974 printerr("Virtual DVD machine not started."); |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
975 return -1; |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
976 } |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
977 pthread_mutex_lock(&this->vm_lock); |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
978 if (!this->vm->state.pgc) { |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
979 printerr("No current PGC."); |
| 388 | 980 pthread_mutex_unlock(&this->vm_lock); |
|
300
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
981 return -1; |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
982 } |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
983 *audio_attr=vm_get_audio_attr(this->vm, audio_num); |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
984 pthread_mutex_unlock(&this->vm_lock); |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
985 |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
986 return DVDNAV_STATUS_OK; |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
987 } |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
988 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
989 int8_t dvdnav_get_spu_logical_stream(dvdnav_t *this, uint8_t subp_num) { |
|
21
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
990 int8_t retval; |
|
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
991 |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
992 if(!this->started) { |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
993 printerr("Virtual DVD machine not started."); |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
994 return -1; |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
995 } |
|
21
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
996 |
| 114 | 997 pthread_mutex_lock(&this->vm_lock); |
| 998 if (!this->vm->state.pgc) { | |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
999 printerr("No current PGC."); |
| 388 | 1000 pthread_mutex_unlock(&this->vm_lock); |
| 114 | 1001 return -1; |
| 1002 } | |
| 1003 retval = vm_get_subp_stream(this->vm, subp_num, 0); | |
| 1004 pthread_mutex_unlock(&this->vm_lock); | |
| 1005 | |
| 1006 return retval; | |
| 1007 } | |
| 1008 | |
|
300
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1009 dvdnav_status_t dvdnav_get_spu_attr(dvdnav_t *this, uint8_t audio_num, subp_attr_t *subp_attr) { |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1010 if(!this->started) { |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1011 printerr("Virtual DVD machine not started."); |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1012 return -1; |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1013 } |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1014 pthread_mutex_lock(&this->vm_lock); |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1015 if (!this->vm->state.pgc) { |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1016 printerr("No current PGC."); |
| 388 | 1017 pthread_mutex_unlock(&this->vm_lock); |
|
300
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1018 return -1; |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1019 } |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1020 *subp_attr=vm_get_subp_attr(this->vm, audio_num); |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1021 pthread_mutex_unlock(&this->vm_lock); |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1022 return DVDNAV_STATUS_OK; |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1023 } |
|
cbd2b606f343
implemented dvdnav_get_audio_attr and dvdnav_get_spu_attr; patch by Attila Otvos
nicodvb
parents:
291
diff
changeset
|
1024 |
| 114 | 1025 int8_t dvdnav_get_active_audio_stream(dvdnav_t *this) { |
| 1026 int8_t retval; | |
| 1027 | |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1028 if(!this->started) { |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1029 printerr("Virtual DVD machine not started."); |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1030 return -1; |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1031 } |
| 388 | 1032 |
| 1033 pthread_mutex_lock(&this->vm_lock); | |
| 114 | 1034 if (!this->vm->state.pgc) { |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1035 printerr("No current PGC."); |
| 388 | 1036 pthread_mutex_unlock(&this->vm_lock); |
| 114 | 1037 return -1; |
| 1038 } | |
| 1039 retval = vm_get_audio_active_stream(this->vm); | |
| 388 | 1040 pthread_mutex_unlock(&this->vm_lock); |
| 1041 | |
|
21
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
1042 return retval; |
|
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
1043 } |
|
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
1044 |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
1045 int8_t dvdnav_get_active_spu_stream(dvdnav_t *this) { |
|
21
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
1046 int8_t retval; |
| 0 | 1047 |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1048 if(!this->started) { |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1049 printerr("Virtual DVD machine not started."); |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1050 return -1; |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1051 } |
| 388 | 1052 |
| 1053 pthread_mutex_lock(&this->vm_lock); | |
| 114 | 1054 if (!this->vm->state.pgc) { |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1055 printerr("No current PGC."); |
| 388 | 1056 pthread_mutex_unlock(&this->vm_lock); |
| 114 | 1057 return -1; |
| 1058 } | |
| 1059 retval = vm_get_subp_active_stream(this->vm, 0); | |
| 388 | 1060 pthread_mutex_unlock(&this->vm_lock); |
| 1061 | |
|
21
d2d73f2ad8d3
Change/fix SPU active stream id. Same for audio. Few new functions, largely
f1rmb
parents:
17
diff
changeset
|
1062 return retval; |
| 0 | 1063 } |
| 1064 | |
| 114 | 1065 static int8_t dvdnav_is_domain(dvdnav_t *this, domain_t domain) { |
| 1066 int8_t retval; | |
| 388 | 1067 |
|
142
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1068 if(!this->started) { |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1069 printerr("Virtual DVD machine not started."); |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1070 return -1; |
|
e375b765ebf5
some more sanity checking will prevent segfaults in these functions
mroi
parents:
141
diff
changeset
|
1071 } |
| 388 | 1072 |
| 114 | 1073 pthread_mutex_lock(&this->vm_lock); |
| 1074 retval = (this->vm->state.domain == domain); | |
| 1075 pthread_mutex_unlock(&this->vm_lock); | |
| 388 | 1076 |
| 114 | 1077 return retval; |
| 1078 } | |
| 1079 | |
| 0 | 1080 /* First Play domain. (Menu) */ |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
1081 int8_t dvdnav_is_domain_fp(dvdnav_t *this) { |
| 114 | 1082 return dvdnav_is_domain(this, FP_DOMAIN); |
| 0 | 1083 } |
| 1084 /* Video management Menu domain. (Menu) */ | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
1085 int8_t dvdnav_is_domain_vmgm(dvdnav_t *this) { |
| 114 | 1086 return dvdnav_is_domain(this, VMGM_DOMAIN); |
| 0 | 1087 } |
| 1088 /* Video Title Menu domain (Menu) */ | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
1089 int8_t dvdnav_is_domain_vtsm(dvdnav_t *this) { |
| 114 | 1090 return dvdnav_is_domain(this, VTSM_DOMAIN); |
| 0 | 1091 } |
| 1092 /* Video Title domain (playing movie). */ | |
| 388 | 1093 int8_t dvdnav_is_domain_vts(dvdnav_t *this) { |
| 114 | 1094 return dvdnav_is_domain(this, VTS_DOMAIN); |
| 0 | 1095 } |
| 1096 | |
| 114 | 1097 /* Generally delegate angle information handling to VM */ |
| 195 | 1098 dvdnav_status_t dvdnav_angle_change(dvdnav_t *this, int32_t angle) { |
| 1099 int32_t num, current; | |
| 388 | 1100 |
| 114 | 1101 pthread_mutex_lock(&this->vm_lock); |
| 1102 vm_get_angle_info(this->vm, ¤t, &num); | |
| 0 | 1103 /* Set angle SPRM if valid */ |
| 1104 if((angle > 0) && (angle <= num)) { | |
|
22
3c1df0cb3aee
Start of rewrite of libdvdnav. Still need to re-implement seeking.
jcdutton
parents:
21
diff
changeset
|
1105 this->vm->state.AGL_REG = angle; |
| 0 | 1106 } else { |
| 114 | 1107 printerr("Passed an invalid angle number."); |
| 1108 pthread_mutex_unlock(&this->vm_lock); | |
| 193 | 1109 return DVDNAV_STATUS_ERR; |
| 0 | 1110 } |
| 114 | 1111 pthread_mutex_unlock(&this->vm_lock); |
| 0 | 1112 |
| 193 | 1113 return DVDNAV_STATUS_OK; |
| 0 | 1114 } |
| 1115 | |
| 195 | 1116 dvdnav_status_t dvdnav_get_angle_info(dvdnav_t *this, int32_t *current_angle, |
| 1117 int32_t *number_of_angles) { | |
| 114 | 1118 pthread_mutex_lock(&this->vm_lock); |
| 1119 vm_get_angle_info(this->vm, current_angle, number_of_angles); | |
| 1120 pthread_mutex_unlock(&this->vm_lock); | |
| 1121 | |
| 193 | 1122 return DVDNAV_STATUS_OK; |
| 114 | 1123 } |
| 0 | 1124 |
|
67
61c0ee1bbb7a
Moved get_current_nav_pci into dvdnac.c, changed example to use it instead of 'home-rolled'
richwareham
parents:
66
diff
changeset
|
1125 pci_t* dvdnav_get_current_nav_pci(dvdnav_t *this) { |
| 114 | 1126 if(!this) return 0; |
|
67
61c0ee1bbb7a
Moved get_current_nav_pci into dvdnac.c, changed example to use it instead of 'home-rolled'
richwareham
parents:
66
diff
changeset
|
1127 return &this->pci; |
|
61c0ee1bbb7a
Moved get_current_nav_pci into dvdnac.c, changed example to use it instead of 'home-rolled'
richwareham
parents:
66
diff
changeset
|
1128 } |
|
61c0ee1bbb7a
Moved get_current_nav_pci into dvdnac.c, changed example to use it instead of 'home-rolled'
richwareham
parents:
66
diff
changeset
|
1129 |
|
66
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
1130 dsi_t* dvdnav_get_current_nav_dsi(dvdnav_t *this) { |
| 114 | 1131 if(!this) return 0; |
|
66
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
1132 return &this->dsi; |
|
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
1133 } |
|
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
1134 |
|
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
1135 uint32_t dvdnav_get_next_still_flag(dvdnav_t *this) { |
| 114 | 1136 if(!this) return -1; |
|
66
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
1137 return this->position_next.still; |
|
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
1138 } |
|
2bd4a78eefce
Patch from aschultz@cs.uni-magdeburg.de to allow for still-frame 'peek-ahead'
richwareham
parents:
60
diff
changeset
|
1139 |
| 262 | 1140 user_ops_t dvdnav_get_restrictions(dvdnav_t* this) { |
| 388 | 1141 /* |
| 1142 * user_ops_t is a structure of 32 bits. We want to compute | |
| 1143 * the union of two of those bitfields so to make this quicker | |
| 262 | 1144 * than performing 32 ORs, we will access them as 32bits words. |
| 1145 */ | |
| 264 | 1146 union { |
| 1147 user_ops_t ops_struct; | |
| 1148 uint32_t ops_int; | |
| 1149 } ops; | |
| 388 | 1150 |
| 264 | 1151 ops.ops_int = 0; |
| 388 | 1152 |
| 263 | 1153 if(!this->started) { |
| 1154 printerr("Virtual DVD machine not started."); | |
| 264 | 1155 return ops.ops_struct; |
| 263 | 1156 } |
| 388 | 1157 |
| 1158 pthread_mutex_lock(&this->vm_lock); | |
| 264 | 1159 ops.ops_int |= *(uint32_t*)&this->pci.pci_gi.vobu_uop_ctl; |
| 388 | 1160 |
| 262 | 1161 if(this->vm && this->vm->state.pgc) |
| 264 | 1162 ops.ops_int |= *(uint32_t*)&this->vm->state.pgc->prohibited_ops; |
| 388 | 1163 pthread_mutex_unlock(&this->vm_lock); |
| 1164 | |
| 264 | 1165 return ops.ops_struct; |
| 262 | 1166 } |
