Mercurial > libavcodec.hg
annotate flac.h @ 9236:7ec90057127a libavcodec
10l: don't check against current layout until after validating ch_mode.
should have been in last commit.
author | jbr |
---|---|
date | Sun, 22 Mar 2009 21:13:10 +0000 |
parents | e150ca8d7f91 |
children | 8d570fb097f8 |
rev | line source |
---|---|
6728 | 1 /* |
2 * FLAC (Free Lossless Audio Codec) decoder/demuxer common functions | |
3 * Copyright (c) 2008 Justin Ruggles | |
4 * | |
5 * This file is part of FFmpeg. | |
6 * | |
7 * FFmpeg is free software; you can redistribute it and/or | |
8 * modify it under the terms of the GNU Lesser General Public | |
9 * License as published by the Free Software Foundation; either | |
10 * version 2.1 of the License, or (at your option) any later version. | |
11 * | |
12 * FFmpeg is distributed in the hope that it will be useful, | |
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
15 * Lesser General Public License for more details. | |
16 * | |
17 * You should have received a copy of the GNU Lesser General Public | |
18 * License along with FFmpeg; if not, write to the Free Software | |
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
20 */ | |
21 | |
22 /** | |
8718
e9d9d946f213
Use full internal pathname in doxygen @file directives.
diego
parents:
8661
diff
changeset
|
23 * @file libavcodec/flac.h |
6728 | 24 * FLAC (Free Lossless Audio Codec) decoder/demuxer common functions |
25 */ | |
26 | |
7760 | 27 #ifndef AVCODEC_FLAC_H |
28 #define AVCODEC_FLAC_H | |
6728 | 29 |
6732 | 30 #include "avcodec.h" |
31 | |
9231 | 32 #define FLAC_STREAMINFO_SIZE 34 |
9188
f534d0cca450
share some constants between the FLAC encoder and FLAC decoder
jbr
parents:
9146
diff
changeset
|
33 #define FLAC_MAX_CHANNELS 8 |
f534d0cca450
share some constants between the FLAC encoder and FLAC decoder
jbr
parents:
9146
diff
changeset
|
34 #define FLAC_MIN_BLOCKSIZE 16 |
f534d0cca450
share some constants between the FLAC encoder and FLAC decoder
jbr
parents:
9146
diff
changeset
|
35 #define FLAC_MAX_BLOCKSIZE 65535 |
8660 | 36 |
8659 | 37 enum { |
9208
443f056ba7e7
share channel mode constants between the FLAC decoder and FLAC encoder
jbr
parents:
9188
diff
changeset
|
38 FLAC_CHMODE_INDEPENDENT = 0, |
443f056ba7e7
share channel mode constants between the FLAC decoder and FLAC encoder
jbr
parents:
9188
diff
changeset
|
39 FLAC_CHMODE_LEFT_SIDE = 8, |
443f056ba7e7
share channel mode constants between the FLAC decoder and FLAC encoder
jbr
parents:
9188
diff
changeset
|
40 FLAC_CHMODE_RIGHT_SIDE = 9, |
443f056ba7e7
share channel mode constants between the FLAC decoder and FLAC encoder
jbr
parents:
9188
diff
changeset
|
41 FLAC_CHMODE_MID_SIDE = 10, |
443f056ba7e7
share channel mode constants between the FLAC decoder and FLAC encoder
jbr
parents:
9188
diff
changeset
|
42 }; |
443f056ba7e7
share channel mode constants between the FLAC decoder and FLAC encoder
jbr
parents:
9188
diff
changeset
|
43 |
443f056ba7e7
share channel mode constants between the FLAC decoder and FLAC encoder
jbr
parents:
9188
diff
changeset
|
44 enum { |
8659 | 45 FLAC_METADATA_TYPE_STREAMINFO = 0, |
46 FLAC_METADATA_TYPE_PADDING, | |
47 FLAC_METADATA_TYPE_APPLICATION, | |
48 FLAC_METADATA_TYPE_SEEKTABLE, | |
49 FLAC_METADATA_TYPE_VORBIS_COMMENT, | |
50 FLAC_METADATA_TYPE_CUESHEET, | |
51 FLAC_METADATA_TYPE_PICTURE, | |
52 FLAC_METADATA_TYPE_INVALID = 127 | |
53 }; | |
54 | |
9054 | 55 enum FLACExtradataFormat { |
56 FLAC_EXTRADATA_FORMAT_STREAMINFO = 0, | |
57 FLAC_EXTRADATA_FORMAT_FULL_HEADER = 1 | |
58 }; | |
59 | |
6728 | 60 /** |
61 * Data needed from the Streaminfo header for use by the raw FLAC demuxer | |
62 * and/or the FLAC decoder. | |
63 */ | |
64 #define FLACSTREAMINFO \ | |
65 int max_blocksize; /**< maximum block size, in samples */\ | |
66 int max_framesize; /**< maximum frame size, in bytes */\ | |
67 int samplerate; /**< sample rate */\ | |
68 int channels; /**< number of channels */\ | |
69 int bps; /**< bits-per-sample */\ | |
8661 | 70 int64_t samples; /**< total number of samples */\ |
6728 | 71 |
6729 | 72 typedef struct FLACStreaminfo { |
73 FLACSTREAMINFO | |
74 } FLACStreaminfo; | |
75 | |
76 /** | |
77 * Parse the Streaminfo metadata block | |
78 * @param[out] avctx codec context to set basic stream parameters | |
79 * @param[out] s where parsed information is stored | |
80 * @param[in] buffer pointer to start of 34-byte streaminfo data | |
81 */ | |
82 void ff_flac_parse_streaminfo(AVCodecContext *avctx, struct FLACStreaminfo *s, | |
83 const uint8_t *buffer); | |
84 | |
9054 | 85 /** |
86 * Validate the FLAC extradata. | |
87 * @param[in] avctx codec context containing the extradata. | |
88 * @param[out] format extradata format. | |
89 * @param[out] streaminfo_start pointer to start of 34-byte STREAMINFO data. | |
90 * @return 1 if valid, 0 if not valid. | |
91 */ | |
92 int ff_flac_is_extradata_valid(AVCodecContext *avctx, | |
93 enum FLACExtradataFormat *format, | |
94 uint8_t **streaminfo_start); | |
95 | |
9146
b980183eb831
flacdec: Add a shared function for parsing a FLAC metadata block header.
jbr
parents:
9106
diff
changeset
|
96 /** |
b980183eb831
flacdec: Add a shared function for parsing a FLAC metadata block header.
jbr
parents:
9106
diff
changeset
|
97 * Parse the metadata block parameters from the header. |
b980183eb831
flacdec: Add a shared function for parsing a FLAC metadata block header.
jbr
parents:
9106
diff
changeset
|
98 * @param[in] block_header header data, at least 4 bytes |
b980183eb831
flacdec: Add a shared function for parsing a FLAC metadata block header.
jbr
parents:
9106
diff
changeset
|
99 * @param[out] last indicator for last metadata block |
b980183eb831
flacdec: Add a shared function for parsing a FLAC metadata block header.
jbr
parents:
9106
diff
changeset
|
100 * @param[out] type metadata block type |
b980183eb831
flacdec: Add a shared function for parsing a FLAC metadata block header.
jbr
parents:
9106
diff
changeset
|
101 * @param[out] size metadata block size |
b980183eb831
flacdec: Add a shared function for parsing a FLAC metadata block header.
jbr
parents:
9106
diff
changeset
|
102 */ |
b980183eb831
flacdec: Add a shared function for parsing a FLAC metadata block header.
jbr
parents:
9106
diff
changeset
|
103 void ff_flac_parse_block_header(const uint8_t *block_header, |
b980183eb831
flacdec: Add a shared function for parsing a FLAC metadata block header.
jbr
parents:
9106
diff
changeset
|
104 int *last, int *type, int *size); |
b980183eb831
flacdec: Add a shared function for parsing a FLAC metadata block header.
jbr
parents:
9106
diff
changeset
|
105 |
9216
64246d9e583a
add a function to calculate a more accurate estimate for maximum FLAC
jbr
parents:
9208
diff
changeset
|
106 /** |
64246d9e583a
add a function to calculate a more accurate estimate for maximum FLAC
jbr
parents:
9208
diff
changeset
|
107 * Calculate an estimate for the maximum frame size based on verbatim mode. |
64246d9e583a
add a function to calculate a more accurate estimate for maximum FLAC
jbr
parents:
9208
diff
changeset
|
108 * @param blocksize block size, in samples |
64246d9e583a
add a function to calculate a more accurate estimate for maximum FLAC
jbr
parents:
9208
diff
changeset
|
109 * @param ch number of channels |
64246d9e583a
add a function to calculate a more accurate estimate for maximum FLAC
jbr
parents:
9208
diff
changeset
|
110 * @param bps bits-per-sample |
64246d9e583a
add a function to calculate a more accurate estimate for maximum FLAC
jbr
parents:
9208
diff
changeset
|
111 */ |
64246d9e583a
add a function to calculate a more accurate estimate for maximum FLAC
jbr
parents:
9208
diff
changeset
|
112 int ff_flac_get_max_frame_size(int blocksize, int ch, int bps); |
64246d9e583a
add a function to calculate a more accurate estimate for maximum FLAC
jbr
parents:
9208
diff
changeset
|
113 |
7760 | 114 #endif /* AVCODEC_FLAC_H */ |