1 /***************************************************************************
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
10 * Copyright (C) 2005 Dave Chapman
12 * All files in this archive are subject to the GNU General Public License.
13 * See the file COPYING in the source tree root for full license agreement.
15 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
16 * KIND, either express or implied.
18 ****************************************************************************/
31 #if CONFIG_CODEC == SWCODEC
33 #include "metadata/metadata_common.h"
34 #include "metadata/metadata_parsers.h"
36 static const unsigned short a52_bitrates
[] =
38 32, 40, 48, 56, 64, 80, 96, 112, 128, 160,
39 192, 224, 256, 320, 384, 448, 512, 576, 640
42 /* Only store frame sizes for 44.1KHz - others are simply multiples
44 static const unsigned short a52_441framesizes
[] =
46 69 * 2, 70 * 2, 87 * 2, 88 * 2, 104 * 2, 105 * 2, 121 * 2,
47 122 * 2, 139 * 2, 140 * 2, 174 * 2, 175 * 2, 208 * 2, 209 * 2,
48 243 * 2, 244 * 2, 278 * 2, 279 * 2, 348 * 2, 349 * 2, 417 * 2,
49 418 * 2, 487 * 2, 488 * 2, 557 * 2, 558 * 2, 696 * 2, 697 * 2,
50 835 * 2, 836 * 2, 975 * 2, 976 * 2, 1114 * 2, 1115 * 2, 1253 * 2,
51 1254 * 2, 1393 * 2, 1394 * 2
54 static const long wavpack_sample_rates
[] =
56 6000, 8000, 9600, 11025, 12000, 16000, 22050, 24000,
57 32000, 44100, 48000, 64000, 88200, 96000, 192000
60 #endif /* CONFIG_CODEC == SWCODEC */
63 /* Simple file type probing by looking at the filename extension. */
64 unsigned int probe_file_format(const char *filename
)
69 suffix
= strrchr(filename
, '.');
79 for (i
= 1; i
< AFMT_NUM_CODECS
; i
++)
81 /* search extension list for type */
82 const char *ext
= audio_formats
[i
].ext_list
;
86 if (strcasecmp(suffix
, ext
) == 0)
91 ext
+= strlen(ext
) + 1;
99 /* Get metadata for track - return false if parsing showed problems with the
100 * file that would prevent playback.
102 bool get_metadata(struct track_info
* track
, int fd
, const char* trackname
,
105 #if CONFIG_CODEC == SWCODEC
107 unsigned long totalsamples
;
111 /* Take our best guess at the codec type based on file extension */
112 track
->id3
.codectype
= probe_file_format(trackname
);
114 /* Load codec specific track tag information and confirm the codec type. */
115 switch (track
->id3
.codectype
)
120 if (!get_mp3_metadata(fd
, &track
->id3
, trackname
, v1first
))
127 #if CONFIG_CODEC == SWCODEC
129 if (!get_flac_metadata(fd
, &(track
->id3
)))
137 if (!get_asf_metadata(fd
, &(track
->id3
)))
144 if (!get_monkeys_metadata(fd
, &(track
->id3
)))
148 read_ape_tags(fd
, &(track
->id3
));
152 if (!get_musepack_metadata(fd
, &(track
->id3
)))
154 read_ape_tags(fd
, &(track
->id3
));
157 case AFMT_OGG_VORBIS
:
158 if (!get_vorbis_metadata(fd
, &(track
->id3
)))/*detects and handles Ogg/Speex files*/
166 if (!get_speex_metadata(fd
, &(track
->id3
)))
174 if (!get_wave_metadata(fd
, &(track
->id3
)))
182 /* A simple parser to read basic information from a WavPack file. This
183 * now works with self-extrating WavPack files. This no longer fails on
184 * WavPack files containing floating-point audio data because these are
185 * now converted to standard Rockbox format in the decoder.
188 /* Use the trackname part of the id3 structure as a temporary buffer */
189 buf
= (unsigned char *)track
->id3
.path
;
191 for (i
= 0; i
< 256; ++i
) {
193 /* at every 256 bytes into file, try to read a WavPack header */
195 if ((lseek(fd
, i
* 256, SEEK_SET
) < 0) || (read(fd
, buf
, 32) < 32))
200 /* if valid WavPack 4 header version & not floating data, break */
202 if (memcmp (buf
, "wvpk", 4) == 0 && buf
[9] == 4 &&
203 (buf
[8] >= 2 && buf
[8] <= 0x10))
210 logf ("%s is not a WavPack file\n", trackname
);
214 track
->id3
.vbr
= true; /* All WavPack files are VBR */
215 track
->id3
.filesize
= filesize (fd
);
217 if ((buf
[20] | buf
[21] | buf
[22] | buf
[23]) &&
218 (buf
[12] & buf
[13] & buf
[14] & buf
[15]) != 0xff)
220 int srindx
= ((buf
[26] >> 7) & 1) + ((buf
[27] << 1) & 14);
224 track
->id3
.frequency
= 44100;
228 track
->id3
.frequency
= wavpack_sample_rates
[srindx
];
231 totalsamples
= get_long_le(&buf
[12]);
232 track
->id3
.length
= totalsamples
/ (track
->id3
.frequency
/ 100) * 10;
233 track
->id3
.bitrate
= filesize (fd
) / (track
->id3
.length
/ 8);
236 read_ape_tags(fd
, &track
->id3
); /* use any apetag info we find */
240 /* Use the trackname part of the id3 structure as a temporary buffer */
241 buf
= (unsigned char *)track
->id3
.path
;
243 if ((lseek(fd
, 0, SEEK_SET
) < 0) || (read(fd
, buf
, 5) < 5))
248 if ((buf
[0] != 0x0b) || (buf
[1] != 0x77))
250 logf("%s is not an A52/AC3 file\n",trackname
);
258 logf("A52: Invalid frmsizecod: %d\n",i
);
262 track
->id3
.bitrate
= a52_bitrates
[i
>> 1];
263 track
->id3
.vbr
= false;
264 track
->id3
.filesize
= filesize(fd
);
266 switch (buf
[4] & 0xc0)
269 track
->id3
.frequency
= 48000;
270 track
->id3
.bytesperframe
=track
->id3
.bitrate
* 2 * 2;
274 track
->id3
.frequency
= 44100;
275 track
->id3
.bytesperframe
= a52_441framesizes
[i
];
279 track
->id3
.frequency
= 32000;
280 track
->id3
.bytesperframe
= track
->id3
.bitrate
* 3 * 2;
284 logf("A52: Invalid samplerate code: 0x%02x\n", buf
[4] & 0xc0);
289 /* One A52 frame contains 6 blocks, each containing 256 samples */
290 totalsamples
= track
->id3
.filesize
/ track
->id3
.bytesperframe
* 6 * 256;
291 track
->id3
.length
= totalsamples
/ track
->id3
.frequency
* 1000;
296 if (!get_mp4_metadata(fd
, &(track
->id3
)))
304 track
->id3
.vbr
= true;
305 track
->id3
.filesize
= filesize(fd
);
306 if (!skip_id3v2(fd
, &(track
->id3
)))
310 /* TODO: read the id3v2 header if it exists */
314 if (!get_sid_metadata(fd
, &(track
->id3
)))
320 if(!get_spc_metadata(fd
, &(track
->id3
)))
322 DEBUGF("get_spc_metadata error\n");
325 track
->id3
.filesize
= filesize(fd
);
326 track
->id3
.genre_string
= id3_get_num_genre(36);
329 if (!get_adx_metadata(fd
, &(track
->id3
)))
331 DEBUGF("get_adx_metadata error\n");
337 buf
= (unsigned char *)track
->id3
.path
;
338 if ((lseek(fd
, 0, SEEK_SET
) < 0) || ((read(fd
, buf
, 8)) < 8))
340 DEBUGF("lseek or read failed\n");
343 track
->id3
.vbr
= false;
344 track
->id3
.filesize
= filesize(fd
);
345 if (memcmp(buf
,"NESM",4) && memcmp(buf
,"NSFE",4)) return false;
349 if (!get_aiff_metadata(fd
, &(track
->id3
)))
356 #endif /* CONFIG_CODEC == SWCODEC */
359 /* If we don't know how to read the metadata, assume we can't play
365 /* We have successfully read the metadata from the file */
368 if (cuesheet_is_enabled() && look_for_cuesheet_file(trackname
, NULL
))
370 track
->id3
.cuesheet_type
= 1;
374 lseek(fd
, 0, SEEK_SET
);
375 strncpy(track
->id3
.path
, trackname
, sizeof(track
->id3
.path
));
376 track
->taginfo_ready
= true;