From: Vincent Penquerc'h Date: Fri, 16 Sep 2011 14:03:54 +0000 (+0100) Subject: dvdreadsrc: fix sector seeking X-Git-Tag: freedesktop-RELEASE-0.10.18.3-pre-release~44 X-Git-Url: https://git.ti.com/gitweb?p=glsdk%2Fgst-plugins-ugly0-10.git;a=commitdiff_plain;h=f4bb2ddcc2d9959f938be0e1dead65fc22bae953;ds=sidebyside dvdreadsrc: fix sector seeking It was overly complicated, and did not take into account the offset needed for titles which do not start on a new file. https://bugzilla.gnome.org/show_bug.cgi?id=659252 --- diff --git a/ext/dvdread/dvdreadsrc.c b/ext/dvdread/dvdreadsrc.c index a53019f9..ba36bec0 100644 --- a/ext/dvdread/dvdreadsrc.c +++ b/ext/dvdread/dvdreadsrc.c @@ -1545,25 +1545,27 @@ static gboolean gst_dvd_read_src_goto_sector (GstDvdReadSrc * src, int angle) { gint seek_to = src->cur_pack; - gint chapter, sectors, next, cur, i; + gint chapter, next, cur, i; /* retrieve position */ src->cur_pack = 0; + GST_DEBUG_OBJECT (src, "Goto sector %d, angle %d, within %d chapters", + seek_to, angle, src->num_chapters); + for (i = 0; i < src->num_chapters; i++) { gint c1, c2; cur_title_get_chapter_bounds (src, i, &c1, &c2); + GST_DEBUG_OBJECT (src, " Looking in chapter %d, bounds: %d %d", i, c1, c2); for (next = cur = c1; cur < c2;) { - if (next != cur) { - sectors = - src->cur_pgc->cell_playback[cur].last_sector - - src->cur_pgc->cell_playback[cur].first_sector; - if (src->cur_pack + sectors > seek_to) { - chapter = i; - goto done; - } - src->cur_pack += sectors; + gint first = src->cur_pgc->cell_playback[cur].first_sector; + gint last = src->cur_pgc->cell_playback[cur].last_sector; + GST_DEBUG_OBJECT (src, "Cell %d sector bounds: %d %d", cur, first, last); + if (seek_to >= first && seek_to <= last) { + GST_DEBUG_OBJECT (src, "Seek target found in chapter %d", i); + chapter = i; + goto done; } cur = next; if (src->cur_pgc->cell_playback[cur].block_type == BLOCK_TYPE_ANGLE_BLOCK)