summaryrefslogtreecommitdiff
path: root/firmware/mpeg.c
diff options
context:
space:
mode:
authorLinus Nielsen Feltzing <linus@haxx.se>2002-07-25 11:12:54 +0000
committerLinus Nielsen Feltzing <linus@haxx.se>2002-07-25 11:12:54 +0000
commit4e2384eb0747548c56599cfe92db45bea1fabda3 (patch)
treedf495c30c5650e3a2534f8d4b56d15db660fc35e /firmware/mpeg.c
parent3b919cbda3f542dafb34e40ae36c49ecfaaba2b1 (diff)
downloadrockbox-4e2384eb0747548c56599cfe92db45bea1fabda3.zip
rockbox-4e2384eb0747548c56599cfe92db45bea1fabda3.tar.gz
rockbox-4e2384eb0747548c56599cfe92db45bea1fabda3.tar.bz2
rockbox-4e2384eb0747548c56599cfe92db45bea1fabda3.tar.xz
Second-exact track change detection
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@1444 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware/mpeg.c')
-rw-r--r--firmware/mpeg.c41
1 files changed, 29 insertions, 12 deletions
diff --git a/firmware/mpeg.c b/firmware/mpeg.c
index 3ca605b..d6fdf90 100644
--- a/firmware/mpeg.c
+++ b/firmware/mpeg.c
@@ -415,6 +415,23 @@ void DEI3(void)
if(mp3buf_read >= mp3buflen)
mp3buf_read = 0;
+ /* First, check if we are on a track boundary */
+ if (last_tag > 1)
+ {
+ if (mp3buf_read == id3tags[1].mempos)
+ {
+ /* shift array so index 0 is current track */
+ int i;
+
+ DEBUGF("Track change\n");
+ for (i=0; i<last_tag-1; i++)
+ {
+ id3tags[i] = id3tags[i+1];
+ }
+ last_tag--;
+ }
+ }
+
unplayed_space_left = mp3buf_write - mp3buf_read;
if(unplayed_space_left < 0)
unplayed_space_left = mp3buflen + unplayed_space_left;
@@ -430,23 +447,23 @@ void DEI3(void)
if(unplayed_space_left)
{
last_dma_chunk_size = MIN(65536, unplayed_space_left);
- last_dma_chunk_size = MIN(last_dma_chunk_size, space_until_end_of_buffer);
- DTCR3 = last_dma_chunk_size & 0xffff;
- SAR3 = (unsigned int)mp3buf + mp3buf_read;
+ last_dma_chunk_size = MIN(last_dma_chunk_size,
+ space_until_end_of_buffer);
/* several tracks loaded? */
- if ( last_tag>1 ) {
+ if (last_tag>1)
+ {
/* will we move across the track boundary? */
- if (( mp3buf_read <= id3tags[1].mempos ) &&
- ((mp3buf_read+last_dma_chunk_size) > id3tags[1].mempos )) {
- /* shift array so index 0 is current track */
- int i;
- for (i=0; i<last_tag-1; i++)
- id3tags[i] = id3tags[i+1];
- last_tag--;
- DEBUGF("Track change\n");
+ if (( mp3buf_read < id3tags[1].mempos ) &&
+ ((mp3buf_read+last_dma_chunk_size) > id3tags[1].mempos ))
+ {
+ /* Make sure that we end exactly on the boundary */
+ last_dma_chunk_size = id3tags[1].mempos - mp3buf_read;
}
}
+
+ DTCR3 = last_dma_chunk_size & 0xffff;
+ SAR3 = (unsigned int)mp3buf + mp3buf_read;
}
else
{