diff options
author | Dave Chapman <dave@dchapman.com> | 2007-12-01 01:01:35 +0000 |
---|---|---|
committer | Dave Chapman <dave@dchapman.com> | 2007-12-01 01:01:35 +0000 |
commit | aaacb7010fc247cfc9f16b2e3aee568f29089a22 (patch) | |
tree | 5270f80f3dbad56eba3a408bdc8b36ac7394722d /apps/codecs/libalac | |
parent | 95c117cdb8b2db2e3b5520e9181443a7915463e7 (diff) |
Remove the mallocs for the codecdata in the m4a parser and assume a maximum size of 64 bytes (see comments in source). Also clean up the alac_set_info() function a little and make it alignment-safe. We still need to remove the seektable related mallocs. Please report if any AAC or ALAC files stop playing in Rockbox after this commit - but it is not expected to cause problems.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@15861 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'apps/codecs/libalac')
-rw-r--r-- | apps/codecs/libalac/alac.c | 66 |
1 files changed, 24 insertions, 42 deletions
diff --git a/apps/codecs/libalac/alac.c b/apps/codecs/libalac/alac.c index f8e4df8b1d..d5d9be17f7 100644 --- a/apps/codecs/libalac/alac.c +++ b/apps/codecs/libalac/alac.c @@ -38,23 +38,25 @@ #include "../codec.h" #include "decomp.h" -#define _Swap32(v) do { \ - v = (((v) & 0x000000FF) << 0x18) | \ - (((v) & 0x0000FF00) << 0x08) | \ - (((v) & 0x00FF0000) >> 0x08) | \ - (((v) & 0xFF000000) >> 0x18); } while(0) - -#define _Swap16(v) do { \ - v = (((v) & 0x00FF) << 0x08) | \ - (((v) & 0xFF00) >> 0x08); } while (0) - int16_t predictor_coef_table[32] IBSS_ATTR; int16_t predictor_coef_table_a[32] IBSS_ATTR; int16_t predictor_coef_table_b[32] IBSS_ATTR; + +/* Endian/aligment safe functions - only used in alac_set_info() */ +static uint32_t get_uint32be(unsigned char* p) +{ + return((p[0]<<24) | (p[1]<<16) | (p[2]<<8) | p[3]); +} + +static uint16_t get_uint16be(unsigned char* p) +{ + return((p[0]<<8) | p[1]); +} + void alac_set_info(alac_file *alac, char *inputbuffer) { - char *ptr = inputbuffer; + unsigned char* ptr = (unsigned char*)inputbuffer; ptr += 4; /* size */ ptr += 4; /* frma */ ptr += 4; /* alac */ @@ -63,42 +65,22 @@ void alac_set_info(alac_file *alac, char *inputbuffer) ptr += 4; /* 0 ? */ - alac->setinfo_max_samples_per_frame = *(uint32_t*)ptr; /* buffer size / 2 ? */ -#ifdef ROCKBOX_LITTLE_ENDIAN - _Swap32(alac->setinfo_max_samples_per_frame); -#endif + alac->setinfo_max_samples_per_frame = get_uint32be(ptr); /* buffer size / 2 ? */ ptr += 4; - alac->setinfo_7a = *(uint8_t*)ptr; + alac->setinfo_7a = *ptr++; + alac->setinfo_sample_size = *ptr++; + alac->setinfo_rice_historymult = *ptr++; + alac->setinfo_rice_initialhistory = *ptr++; + alac->setinfo_rice_kmodifier = *ptr++; + alac->setinfo_7f = *ptr++; ptr += 1; - alac->setinfo_sample_size = *(uint8_t*)ptr; - ptr += 1; - alac->setinfo_rice_historymult = *(uint8_t*)ptr; - ptr += 1; - alac->setinfo_rice_initialhistory = *(uint8_t*)ptr; - ptr += 1; - alac->setinfo_rice_kmodifier = *(uint8_t*)ptr; - ptr += 1; - alac->setinfo_7f = *(uint8_t*)ptr; - ptr += 1; - alac->setinfo_80 = *(uint16_t*)ptr; -#ifdef ROCKBOX_LITTLE_ENDIAN - _Swap16(alac->setinfo_80); -#endif + alac->setinfo_80 = get_uint16be(ptr); ptr += 2; - alac->setinfo_82 = *(uint32_t*)ptr; -#ifdef ROCKBOX_LITTLE_ENDIAN - _Swap32(alac->setinfo_82); -#endif + alac->setinfo_82 = get_uint32be(ptr); ptr += 4; - alac->setinfo_86 = *(uint32_t*)ptr; -#ifdef ROCKBOX_LITTLE_ENDIAN - _Swap32(alac->setinfo_86); -#endif + alac->setinfo_86 = get_uint32be(ptr); ptr += 4; - alac->setinfo_8a_rate = *(uint32_t*)ptr; -#ifdef ROCKBOX_LITTLE_ENDIAN - _Swap32(alac->setinfo_8a_rate); -#endif + alac->setinfo_8a_rate = get_uint32be(ptr); ptr += 4; } |