summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJens Arnold <amiconn@rockbox.org>2007-09-05 06:48:33 +0000
committerJens Arnold <amiconn@rockbox.org>2007-09-05 06:48:33 +0000
commitaf533820ee49ac6f940293b22bb557b36bf75f7d (patch)
tree45806391001b156f30f63b8fc6a0c9a3b98271ff
parentfcab06125025e86dbad42e49af1c0b5c2a3085fb (diff)
downloadrockbox-af533820ee49ac6f940293b22bb557b36bf75f7d.tar.gz
rockbox-af533820ee49ac6f940293b22bb557b36bf75f7d.zip
More efficient version of the fix.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@14619 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--firmware/id3.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/firmware/id3.c b/firmware/id3.c
index 2a894aab10..2fd7894de8 100644
--- a/firmware/id3.c
+++ b/firmware/id3.c
@@ -512,13 +512,12 @@ static int unicode_len(char encoding, const void* string)
512 int len = 0; 512 int len = 0;
513 513
514 if (encoding == 0x01 || encoding == 0x02) { 514 if (encoding == 0x01 || encoding == 0x02) {
515 bool iswchar; 515 char first;
516 const char *s = string; 516 const char *s = string;
517 /* string might be unaligned, so using short* can crash on ARM and SH1 */ 517 /* string might be unaligned, so using short* can crash on ARM and SH1 */
518 do { 518 do {
519 iswchar = (*s++ != 0); 519 first = *s++;
520 iswchar |= (*s++ != 0); 520 } while ((first | *s++) != 0);
521 } while (iswchar);
522 521
523 len = s - (const char*) string; 522 len = s - (const char*) string;
524 } else { 523 } else {