blob: 1df283e6b8980ade269a75687d976f5ea51fa997 [file] [log] [blame]
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +00001/***************************************************************************
2 * __________ __ ___.
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
7 * \/ \/ \/ \/ \/
8 * $Id$
9 *
10 * Copyright (C) 2005 Miika Pekkarinen
11 *
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.
14 *
15 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
16 * KIND, either express or implied.
17 *
18 ****************************************************************************/
19
Dave Chapman3ad485b2005-06-14 22:27:57 +000020#ifndef _PLAYBACK_H
21#define _PLAYBACK_H
22
23#include <stdlib.h>
24#include <ctype.h>
25#include <stdbool.h>
26
27#include "id3.h"
28#include "mp3data.h"
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000029
Miika Pekkarinend94cba62005-06-13 15:26:53 +000030/* Supported file types. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000031#define AFMT_MPA_L1 0x0001 // MPEG Audio layer 1
32#define AFMT_MPA_L2 0x0002 // MPEG Audio layer 2
33#define AFMT_MPA_L3 0x0004 // MPEG Audio layer 3
34 /* (MPEG-1, 2, 2.5 layers 1, 2 and 3 */
35#define AFMT_PCM_WAV 0x0008 // Uncompressed PCM in a WAV file
36#define AFMT_OGG_VORBIS 0x0010 // Ogg Vorbis
37#define AFMT_FLAC 0x0020 // FLAC
38#define AFMT_MPC 0x0040 // Musepack
39#define AFMT_AAC 0x0080 // AAC
40#define AFMT_APE 0x0100 // Monkey's Audio
41#define AFMT_WMA 0x0200 // Windows Media Audio
42#define AFMT_A52 0x0400 // A/52 (aka AC3) audio
43#define AFMT_REAL 0x0800 // Realaudio
44#define AFMT_UNKNOWN 0x1000 // Unknown file format
Dave Bryant57c6f6e2005-06-13 06:00:35 +000045#define AFMT_WAVPACK 0x2000 // WavPack
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000046
Miika Pekkarinend94cba62005-06-13 15:26:53 +000047/* File buffer configuration keys. */
Miika Pekkarinen68b9acd2005-06-10 15:02:10 +000048#define CODEC_SET_FILEBUF_WATERMARK 1
49#define CODEC_SET_FILEBUF_CHUNKSIZE 2
50#define CODEC_SET_FILEBUF_LIMIT 3
51
52/* Not yet implemented. */
53#define CODEC_SET_AUDIOBUF_WATERMARK 4
54
Dave Chapman3ad485b2005-06-14 22:27:57 +000055#define MAX_TRACK 10
56struct track_info {
57 struct mp3entry id3; /* TAG metadata */
58 struct mp3info mp3data; /* MP3 metadata */
59 char *codecbuf; /* Pointer to codec buffer */
60 size_t codecsize; /* Codec length in bytes */
61 int codectype; /* Codec type (example AFMT_MPA_L3) */
62
63 off_t filerem; /* Remaining bytes of file NOT in buffer */
64 off_t filesize; /* File total length */
65 off_t filepos; /* Read position of file for next buffer fill */
66 off_t start_pos; /* Position to first bytes of file in buffer */
67 volatile int available; /* Available bytes to read from buffer */
68 bool taginfo_ready; /* Is metadata read */
69 int playlist_offset; /* File location in playlist */
70};
71
72
Miika Pekkarinend94cba62005-06-13 15:26:53 +000073/* Codec Interface */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000074struct codec_api {
Miika Pekkarinend94cba62005-06-13 15:26:53 +000075 off_t filesize; /* Total file length */
76 off_t curpos; /* Current buffer position */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000077
78 /* For gapless mp3 */
Miika Pekkarinend94cba62005-06-13 15:26:53 +000079 struct mp3entry *id3; /* TAG metadata pointer */
80 struct mp3info *mp3data; /* MP3 metadata pointer */
81 bool *taginfo_ready; /* Is metadata read */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000082
Miika Pekkarinend94cba62005-06-13 15:26:53 +000083 /* Codec should periodically check if stop_codec is set to true.
84 In case it's, codec must return with PLUGIN_OK status immediately. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000085 bool stop_codec;
Miika Pekkarinend94cba62005-06-13 15:26:53 +000086 /* Codec should periodically check if reload_codec is set to true.
87 In case it's, codec should reload itself without exiting. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000088 bool reload_codec;
Miika Pekkarinend94cba62005-06-13 15:26:53 +000089 /* If seek_time != 0, codec should seek to that song position (in ms)
90 if codec supports seeking. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000091 int seek_time;
92
Miika Pekkarinend94cba62005-06-13 15:26:53 +000093 /* Returns buffer to malloc array. Only codeclib should need this. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000094 void* (*get_codec_memory)(size_t *size);
Miika Pekkarinend94cba62005-06-13 15:26:53 +000095 /* Insert PCM data into audio buffer for playback. Playback will start
96 automatically. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000097 bool (*audiobuffer_insert)(char *data, size_t length);
Miika Pekkarinend94cba62005-06-13 15:26:53 +000098 /* Set song position in WPS (value in ms). */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +000099 void (*set_elapsed)(unsigned int value);
100
Miika Pekkarinend94cba62005-06-13 15:26:53 +0000101 /* Read next <size> amount bytes from file buffer to <ptr>.
102 Will return number of bytes read or 0 if end of file. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +0000103 size_t (*read_filebuf)(void *ptr, size_t size);
Miika Pekkarinend94cba62005-06-13 15:26:53 +0000104 /* Request pointer to file buffer which can be used to read
105 <realsize> amount of data. <reqsize> tells the buffer system
106 how much data it should try to allocate. If <realsize> is 0,
107 end of file is reached. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +0000108 void* (*request_buffer)(size_t *realsize, size_t reqsize);
Miika Pekkarinend94cba62005-06-13 15:26:53 +0000109 /* Advance file buffer position by <amount> amount of bytes. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +0000110 void (*advance_buffer)(size_t amount);
Miika Pekkarinend94cba62005-06-13 15:26:53 +0000111 /* Advance file buffer to a pointer location inside file buffer. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +0000112 void (*advance_buffer_loc)(void *ptr);
Miika Pekkarinend94cba62005-06-13 15:26:53 +0000113 /* Seek file buffer to position <newpos> beginning of file. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +0000114 bool (*seek_buffer)(off_t newpos);
Miika Pekkarinend94cba62005-06-13 15:26:53 +0000115 /* Calculate mp3 seek position from given time data in ms. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +0000116 off_t (*mp3_get_filepos)(int newtime);
Miika Pekkarinend94cba62005-06-13 15:26:53 +0000117 /* Request file change from file buffer. Returns true is next
118 track is available and changed. If return value is false,
119 codec should exit immediately with PLUGIN_OK status. */
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +0000120 bool (*request_next_track)(void);
Miika Pekkarinen68b9acd2005-06-10 15:02:10 +0000121
Miika Pekkarinend94cba62005-06-13 15:26:53 +0000122 /* Configure different codec buffer parameters. */
Miika Pekkarinen68b9acd2005-06-10 15:02:10 +0000123 void (*configure)(int setting, void *value);
Linus Nielsen Feltzing1c497e62005-06-05 23:05:10 +0000124};
125
126#endif
127
128