summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiika Pekkarinen <miipekk@ihme.org>2006-04-02 20:19:00 +0000
committerMiika Pekkarinen <miipekk@ihme.org>2006-04-02 20:19:00 +0000
commit93b6a1d12c31a601df6b548bda81e3c40f431c47 (patch)
tree88e25758af6c67e1eb62bdc2223fc327ebf058a9
parentea6b4cbe4f10751087a64a13ff5d44837862cef3 (diff)
downloadrockbox-93b6a1d12c31a601df6b548bda81e3c40f431c47.zip
rockbox-93b6a1d12c31a601df6b548bda81e3c40f431c47.tar.gz
rockbox-93b6a1d12c31a601df6b548bda81e3c40f431c47.tar.bz2
rockbox-93b6a1d12c31a601df6b548bda81e3c40f431c47.tar.xz
Prevent two division by zeros and one problem causing a crash in the
mp3 metadata parser. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@9438 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--apps/dsp.c5
-rw-r--r--apps/playback.c5
-rw-r--r--firmware/mp3data.c11
3 files changed, 19 insertions, 2 deletions
diff --git a/apps/dsp.c b/apps/dsp.c
index 9cdc715..29e103a 100644
--- a/apps/dsp.c
+++ b/apps/dsp.c
@@ -629,7 +629,10 @@ void dsp_set_eq_coefs(int band)
cutoff = 0xffffffff / NATIVE_FREQUENCY * (*setting++);
q = ((*setting++) << 16) / 10; /* 16.16 */
gain = ((*setting++) << 16) / 10; /* s15.16 */
-
+
+ if (q == 0)
+ q = 1;
+
/* The coef functions assume the EMAC unit is in fractional mode */
#if defined(CPU_COLDFIRE) && !defined(SIMULATOR)
/* set emac unit for dsp processing, and save old macsr, we're running in
diff --git a/apps/playback.c b/apps/playback.c
index eab6fd1..9f8fc5a 100644
--- a/apps/playback.c
+++ b/apps/playback.c
@@ -2359,8 +2359,11 @@ static void mp3_set_elapsed(struct mp3entry* id3)
}
}
else
+ {
/* constant bitrate, use exact calculation */
- id3->elapsed = id3->offset / (id3->bitrate / 8);
+ if (id3->bitrate != 0)
+ id3->elapsed = id3->offset / (id3->bitrate / 8);
+ }
}
/* Copied from mpeg.c. Should be moved somewhere else. */
diff --git a/firmware/mp3data.c b/firmware/mp3data.c
index 52aee11..e3de767 100644
--- a/firmware/mp3data.c
+++ b/firmware/mp3data.c
@@ -118,6 +118,9 @@ static bool mp3headerinfo(struct mp3info *info, unsigned long header)
int bitindex, freqindex;
/* MPEG Audio Version */
+ if ((header & VERSION_MASK) >> 19 >= sizeof(version_table))
+ return false;
+
info->version = version_table[(header & VERSION_MASK) >> 19];
if (info->version < 0)
return false;
@@ -359,6 +362,14 @@ int get_mp3file_info(int fd, struct mp3info *info)
return -2;
/* OK, we have found a frame. Let's see if it has a Xing header */
+ if (info->frame_size-4 >= sizeof(frame))
+ {
+#if defined(DEBUG) || defined(SIMULATOR)
+ DEBUGF("Error: Invalid id3 header, frame_size: %d\n", info->frame_size);
+#endif
+ return -8;
+ }
+
if(read(fd, frame, info->frame_size-4) < 0)
return -3;