summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndree Buschmann <AndreeBuschmann@t-online.de>2011-11-29 19:48:57 +0000
committerAndree Buschmann <AndreeBuschmann@t-online.de>2011-11-29 19:48:57 +0000
commit3c63cb29e945ae8e4af1a682f35f04cae5445e19 (patch)
tree7684edbdcc7cd90471ae4567ced3f43906b15267
parent16d736d3c76204d60c86531f8f434b83909e0a4a (diff)
downloadrockbox-3c63cb29e945ae8e4af1a682f35f04cae5445e19.tar.gz
rockbox-3c63cb29e945ae8e4af1a682f35f04cae5445e19.zip
Resync mpc to r476 of svn.musepack.org. Improves error handling after seek.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@31093 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--apps/codecs/libmusepack/mpc_demux.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/apps/codecs/libmusepack/mpc_demux.c b/apps/codecs/libmusepack/mpc_demux.c
index 97a431e597..3f4c9d021a 100644
--- a/apps/codecs/libmusepack/mpc_demux.c
+++ b/apps/codecs/libmusepack/mpc_demux.c
@@ -625,10 +625,15 @@ static mpc_status mpc_demux_decode_inner(mpc_demux * d, mpc_frame_info * i)
625} 625}
626 626
627mpc_status mpc_demux_decode(mpc_demux * d, mpc_frame_info * i) { 627mpc_status mpc_demux_decode(mpc_demux * d, mpc_frame_info * i) {
628 mpc_status s = mpc_demux_decode_inner(d, i); 628 for(;;) {
629 if (MPC_IS_FAILURE(s)) 629 // mpc_demux_decode_inner may return 0 samples and require repeated calls after a seek. Loop over until we have data to return.
630 i->bits = -1; // we pretend it's end of file 630 mpc_status s = mpc_demux_decode_inner(d, i);
631 return s; 631 if (MPC_IS_FAILURE(s))
632 i->bits = -1; // we pretend it's end of file
633
634 if (MPC_IS_FAILURE(s) || i->samples > 0)
635 return s;
636 }
632} 637}
633 638
634/* rockbox: not used 639/* rockbox: not used