summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDiego 'Flameeyes' Pettenò <flameeyes@gmail.com>2007-04-21 16:58:52 +0200
committerDiego 'Flameeyes' Pettenò <flameeyes@gmail.com>2007-04-21 16:58:52 +0200
commitf53eb0c49bfbb53164c8e4507635435d6e0654fe (patch)
tree2e346094e139a8dfa869b2b4405ab2e785a18a63 /src
parent8eaab6c32431f588378d25e6dbaa9252f7ad4887 (diff)
parent837894b153407936105bf5b358f235b6600bbd42 (diff)
downloadxine-lib-f53eb0c49bfbb53164c8e4507635435d6e0654fe.tar.gz
xine-lib-f53eb0c49bfbb53164c8e4507635435d6e0654fe.tar.bz2
Merge from 1.1 branch.
Diffstat (limited to 'src')
-rw-r--r--src/demuxers/demux_qt.c12
-rw-r--r--src/xine-engine/input_cache.c6
2 files changed, 14 insertions, 4 deletions
diff --git a/src/demuxers/demux_qt.c b/src/demuxers/demux_qt.c
index aca94f73d..cff4c48f9 100644
--- a/src/demuxers/demux_qt.c
+++ b/src/demuxers/demux_qt.c
@@ -916,9 +916,15 @@ static qt_error parse_trak_atom (qt_trak *trak,
trak->edit_list_table[j].media_time);
}
- } else if (current_atom == MDHD_ATOM)
- trak->timescale = BE_32(&trak_atom[i + 0x10]);
- else if (current_atom == STSD_ATOM) {
+ } else if (current_atom == MDHD_ATOM) {
+ int version;
+ debug_atom_load ("demux_qt: mdhd atom\n");
+
+ version = trak_atom[i+4];
+ if ( version > 1 ) continue; /* unsupported, undocumented */
+
+ trak->timescale = BE_32(&trak_atom[i + (version == 0 ? 0x10 : 0x18) ]);
+ } else if (current_atom == STSD_ATOM) {
debug_atom_load ("demux_qt: stsd atom\n");
#if DEBUG_ATOM_LOAD
diff --git a/src/xine-engine/input_cache.c b/src/xine-engine/input_cache.c
index a566e1f84..75c4beb43 100644
--- a/src/xine-engine/input_cache.c
+++ b/src/xine-engine/input_cache.c
@@ -74,7 +74,11 @@ static off_t cache_plugin_read(input_plugin_t *this_gen, char *buf, off_t len) {
if (len <= (this->buf_len - this->buf_pos)) {
/* all bytes are in the buffer */
switch (len) {
-#if !(defined(sparc) || defined(__sparc__) || defined __ia64__)
+#if defined(__i386__) || defined(__x86_64__)
+ /* These are restricted to x86 and amd64. Some other architectures don't
+ * handle unaligned accesses in the same way, quite possibly requiring
+ * extra code over and above simple byte copies.
+ */
case 8:
*((uint64_t *)buf) = *(uint64_t *)(&(this->buf[this->buf_pos]));
break;