FFmpeg
flac.h
Go to the documentation of this file.
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 /**
23  * @file
24  * FLAC (Free Lossless Audio Codec) decoder/demuxer common functions
25  */
26 
27 #ifndef AVCODEC_FLAC_H
28 #define AVCODEC_FLAC_H
29 
30 #include "avcodec.h"
31 #include "bytestream.h"
32 #include "get_bits.h"
33 
34 #define FLAC_STREAMINFO_SIZE 34
35 #define FLAC_MAX_CHANNELS 8
36 #define FLAC_MIN_BLOCKSIZE 16
37 #define FLAC_MAX_BLOCKSIZE 65535
38 #define FLAC_MIN_FRAME_SIZE 11
39 
40 enum {
45 };
46 
47 enum {
56 };
57 
61 };
62 
63 #define FLACCOMMONINFO \
64  int samplerate; /**< sample rate */\
65  int channels; /**< number of channels */\
66  int bps; /**< bits-per-sample */\
67 
68 /**
69  * Data needed from the Streaminfo header for use by the raw FLAC demuxer
70  * and/or the FLAC decoder.
71  */
72 #define FLACSTREAMINFO \
73  FLACCOMMONINFO \
74  int max_blocksize; /**< maximum block size, in samples */\
75  int max_framesize; /**< maximum frame size, in bytes */\
76  int64_t samples; /**< total number of samples */\
77 
78 typedef struct FLACStreaminfo {
81 
82 typedef struct FLACFrameInfo {
84  int blocksize; /**< block size of the frame */
85  int ch_mode; /**< channel decorrelation mode */
86  int64_t frame_or_sample_num; /**< frame number or sample number */
87  int is_var_size; /**< specifies if the stream uses variable
88  block sizes or a fixed block size;
89  also determines the meaning of
90  frame_or_sample_num */
92 
93 /**
94  * Parse the Streaminfo metadata block
95  * @param[out] avctx codec context to set basic stream parameters
96  * @param[out] s where parsed information is stored
97  * @param[in] buffer pointer to start of 34-byte streaminfo data
98  *
99  * @return negative error code on faiure or >= 0 on success
100  */
102  const uint8_t *buffer);
103 
104 /**
105  * Validate the FLAC extradata.
106  * @param[in] avctx codec context containing the extradata.
107  * @param[out] format extradata format.
108  * @param[out] streaminfo_start pointer to start of 34-byte STREAMINFO data.
109  * @return 1 if valid, 0 if not valid.
110  */
113  uint8_t **streaminfo_start);
114 
115 /**
116  * Calculate an estimate for the maximum frame size based on verbatim mode.
117  * @param blocksize block size, in samples
118  * @param ch number of channels
119  * @param bps bits-per-sample
120  */
121 int ff_flac_get_max_frame_size(int blocksize, int ch, int bps);
122 
123 /**
124  * Validate and decode a frame header.
125  * @param avctx AVCodecContext to use as av_log() context
126  * @param gb GetBitContext from which to read frame header
127  * @param[out] fi frame information
128  * @param log_level_offset log level offset. can be used to silence error messages.
129  * @return non-zero on error, 0 if ok
130  */
132  FLACFrameInfo *fi, int log_level_offset);
133 
135 
136 /**
137  * Parse the metadata block parameters from the header.
138  * @param[in] block_header header data, at least 4 bytes
139  * @param[out] last indicator for last metadata block
140  * @param[out] type metadata block type
141  * @param[out] size metadata block size
142  */
143 static av_always_inline void flac_parse_block_header(const uint8_t *block_header,
144  int *last, int *type, int *size)
145 {
146  int tmp = bytestream_get_byte(&block_header);
147  if (last)
148  *last = tmp & 0x80;
149  if (type)
150  *type = tmp & 0x7F;
151  if (size)
152  *size = bytestream_get_be24(&block_header);
153 }
154 
155 #endif /* AVCODEC_FLAC_H */
ff_flac_decode_frame_header
int ff_flac_decode_frame_header(AVCodecContext *avctx, GetBitContext *gb, FLACFrameInfo *fi, int log_level_offset)
Validate and decode a frame header.
Definition: flac.c:50
ff_flac_set_channel_layout
void ff_flac_set_channel_layout(AVCodecContext *avctx)
Definition: flac.c:196
tmp
static uint8_t tmp[11]
Definition: aes_ctr.c:26
FLACFrameInfo::frame_or_sample_num
int64_t frame_or_sample_num
frame number or sample number
Definition: flac.h:88
FLACFrameInfo::is_var_size
int is_var_size
specifies if the stream uses variable block sizes or a fixed block size; also determines the meaning ...
Definition: flac.h:89
FLAC_METADATA_TYPE_SEEKTABLE
@ FLAC_METADATA_TYPE_SEEKTABLE
Definition: flac.h:51
GetBitContext
Definition: get_bits.h:62
type
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf type
Definition: writing_filters.txt:86
FLACCOMMONINFO
#define FLACCOMMONINFO
bits-per-sample
Definition: flac.h:63
FLAC_CHMODE_RIGHT_SIDE
@ FLAC_CHMODE_RIGHT_SIDE
Definition: flac.h:43
FLACStreaminfo
Definition: flac.h:80
s
#define s(width, name)
Definition: cbs_vp9.c:257
get_bits.h
FLACExtradataFormat
FLACExtradataFormat
Definition: flac.h:58
FLACFrameInfo::blocksize
FLACCOMMONINFO int blocksize
block size of the frame
Definition: flac.h:86
flac_parse_block_header
static av_always_inline void flac_parse_block_header(const uint8_t *block_header, int *last, int *type, int *size)
Parse the metadata block parameters from the header.
Definition: flac.h:145
ff_flac_get_max_frame_size
int ff_flac_get_max_frame_size(int blocksize, int ch, int bps)
Calculate an estimate for the maximum frame size based on verbatim mode.
Definition: flac.c:148
ff_flac_is_extradata_valid
int ff_flac_is_extradata_valid(AVCodecContext *avctx, enum FLACExtradataFormat *format, uint8_t **streaminfo_start)
Validate the FLAC extradata.
Definition: flac.c:169
FLACFrameInfo
Definition: flac.h:84
FLAC_METADATA_TYPE_PICTURE
@ FLAC_METADATA_TYPE_PICTURE
Definition: flac.h:54
FLAC_CHMODE_MID_SIDE
@ FLAC_CHMODE_MID_SIDE
Definition: flac.h:44
FLAC_METADATA_TYPE_CUESHEET
@ FLAC_METADATA_TYPE_CUESHEET
Definition: flac.h:53
FLAC_CHMODE_LEFT_SIDE
@ FLAC_CHMODE_LEFT_SIDE
Definition: flac.h:42
bps
unsigned bps
Definition: movenc.c:1597
FLAC_METADATA_TYPE_APPLICATION
@ FLAC_METADATA_TYPE_APPLICATION
Definition: flac.h:50
size
int size
Definition: twinvq_data.h:10344
format
ofilter format
Definition: ffmpeg_filter.c:172
FLAC_EXTRADATA_FORMAT_FULL_HEADER
@ FLAC_EXTRADATA_FORMAT_FULL_HEADER
Definition: flac.h:60
FLAC_METADATA_TYPE_VORBIS_COMMENT
@ FLAC_METADATA_TYPE_VORBIS_COMMENT
Definition: flac.h:52
FLACFrameInfo::ch_mode
int ch_mode
channel decorrelation mode
Definition: flac.h:87
av_always_inline
#define av_always_inline
Definition: attributes.h:49
ff_flac_parse_streaminfo
int ff_flac_parse_streaminfo(AVCodecContext *avctx, struct FLACStreaminfo *s, const uint8_t *buffer)
Parse the Streaminfo metadata block.
Definition: flac.c:204
avcodec.h
AVCodecContext
main external API structure.
Definition: avcodec.h:383
FLAC_METADATA_TYPE_PADDING
@ FLAC_METADATA_TYPE_PADDING
Definition: flac.h:49
buffer
the frame and frame reference mechanism is intended to as much as expensive copies of that data while still allowing the filters to produce correct results The data is stored in buffers represented by AVFrame structures Several references can point to the same frame buffer
Definition: filter_design.txt:49
FLAC_EXTRADATA_FORMAT_STREAMINFO
@ FLAC_EXTRADATA_FORMAT_STREAMINFO
Definition: flac.h:59
FLAC_METADATA_TYPE_STREAMINFO
@ FLAC_METADATA_TYPE_STREAMINFO
Definition: flac.h:48
bytestream.h
FLAC_METADATA_TYPE_INVALID
@ FLAC_METADATA_TYPE_INVALID
Definition: flac.h:55
FLACSTREAMINFO
#define FLACSTREAMINFO
Data needed from the Streaminfo header for use by the raw FLAC demuxer and/or the FLAC decoder.
Definition: flac.h:73
FLAC_CHMODE_INDEPENDENT
@ FLAC_CHMODE_INDEPENDENT
Definition: flac.h:41