summaryrefslogtreecommitdiff
path: root/modules/ogg
diff options
context:
space:
mode:
authorEllen Poe <ellen@ellenhp.me>2022-02-16 20:14:31 -0800
committerGitHub <noreply@github.com>2022-02-16 20:14:31 -0800
commit76f667bf2a58f1c87ceed34684e11d39510458c7 (patch)
tree609e3b7456968e78e7bcb25565ea5e63416d4e9a /modules/ogg
parent73ece5ba1962eb3c19ac529b8cb4ac18aefd5cac (diff)
parentb4ffaebb8754d78f64ae3d8aae3439e7927bb409 (diff)
Merge pull request #58130 from timothyqiu/ogg-seek-crash
Fix infinite recursion when seeking Ogg Vorbis file
Diffstat (limited to 'modules/ogg')
-rw-r--r--modules/ogg/ogg_packet_sequence.cpp4
1 files changed, 3 insertions, 1 deletions
diff --git a/modules/ogg/ogg_packet_sequence.cpp b/modules/ogg/ogg_packet_sequence.cpp
index 65058f088e..da52ecfdd5 100644
--- a/modules/ogg/ogg_packet_sequence.cpp
+++ b/modules/ogg/ogg_packet_sequence.cpp
@@ -162,6 +162,7 @@ bool OGGPacketSequencePlayback::next_ogg_packet(ogg_packet **p_packet) const {
}
uint32_t OGGPacketSequencePlayback::seek_page_internal(int64_t granule, uint32_t after_page_inclusive, uint32_t before_page_inclusive) {
+ // FIXME: This function needs better corner case handling.
if (before_page_inclusive == after_page_inclusive) {
return before_page_inclusive;
}
@@ -169,7 +170,8 @@ uint32_t OGGPacketSequencePlayback::seek_page_internal(int64_t granule, uint32_t
// Complicating the bisection search algorithm, the middle page might not have a packet that ends on it,
// which means it might not have a correct granule position. Find a nearby page that does have a packet ending on it.
uint32_t bisection_page = -1;
- for (uint32_t test_page = actual_middle_page; test_page <= before_page_inclusive; test_page++) {
+ // Don't include before_page_inclusive because that always succeeds and will cause infinite recursion later.
+ for (uint32_t test_page = actual_middle_page; test_page < before_page_inclusive; test_page++) {
if (ogg_packet_sequence->page_data[test_page].size() > 0) {
bisection_page = test_page;
break;