summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--NEWS2
-rw-r--r--src/archive/plugins/Iso9660ArchivePlugin.cxx4
2 files changed, 4 insertions, 2 deletions
diff --git a/NEWS b/NEWS
index 6f2606b0e..9bb3f60a0 100644
--- a/NEWS
+++ b/NEWS
@@ -1,6 +1,8 @@
ver 0.22.5 (not yet released)
* tags
- id: translate TPE3 to Conductor, not Performer
+* archive
+ - iso9660: another fix for unaligned reads
* output
- httpd: error handling on Windows improved
diff --git a/src/archive/plugins/Iso9660ArchivePlugin.cxx b/src/archive/plugins/Iso9660ArchivePlugin.cxx
index 56bf15c28..71f2ebb22 100644
--- a/src/archive/plugins/Iso9660ArchivePlugin.cxx
+++ b/src/archive/plugins/Iso9660ArchivePlugin.cxx
@@ -221,8 +221,8 @@ public:
if (new_offset > size)
throw std::runtime_error("Invalid seek offset");
+ offset = new_offset;
skip = new_offset % ISO_BLOCKSIZE;
- offset = new_offset - skip;
buffer.Clear();
}
};
@@ -260,7 +260,7 @@ Iso9660InputStream::Read(std::unique_lock<Mutex> &,
if (r.empty()) {
/* the buffer is empty - read more data from the ISO file */
- assert(offset % ISO_BLOCKSIZE == 0);
+ assert((offset - skip) % ISO_BLOCKSIZE == 0);
const ScopeUnlock unlock(mutex);