39#define AUDIO_INBUF_SIZE 20480
40#define AUDIO_REFILL_THRESH 4096
46 struct sample_fmt_entry {
48 } sample_fmt_entries[] = {
58 struct sample_fmt_entry *entry = &sample_fmt_entries[i];
59 if (sample_fmt == entry->sample_fmt) {
60 *fmt =
AV_NE(entry->fmt_be, entry->fmt_le);
66 "sample format %s is not supported as output format\n",
80 fprintf(stderr,
"Error submitting the packet to the decoder\n");
90 fprintf(stderr,
"Error during decoding\n");
96 fprintf(stderr,
"Failed to calculate data size\n");
101 fwrite(
frame->
data[ch] + data_size*i, 1, data_size, outfile);
107 const char *outfilename, *filename;
123 fprintf(stderr,
"Usage: %s <input file> <output file>\n", argv[0]);
127 outfilename = argv[2];
134 fprintf(stderr,
"Codec not found\n");
140 fprintf(stderr,
"Parser not found\n");
146 fprintf(stderr,
"Could not allocate audio codec context\n");
152 fprintf(stderr,
"Could not open codec\n");
156 f = fopen(filename,
"rb");
158 fprintf(stderr,
"Could not open %s\n", filename);
161 outfile = fopen(outfilename,
"wb");
171 while (data_size > 0) {
172 if (!decoded_frame) {
174 fprintf(stderr,
"Could not allocate audio frame\n");
183 fprintf(stderr,
"Error while parsing\n");
193 memmove(inbuf, data, data_size);
195 len = fread(data + data_size, 1,
212 printf(
"Warning: the sample format the decoder produced is planar "
213 "(%s). This example will output the first channel only.\n",
214 packed ? packed :
"?");
222 printf(
"Play the output audio file with the command:\n"
223 "ffplay -f %s -ac %d -ar %d %s\n",
Libavcodec external API header.
static void decode(AVCodecContext *dec_ctx, AVPacket *pkt, AVFrame *frame, FILE *outfile)
int main(int argc, char **argv)
static int get_format_from_sample_fmt(const char **fmt, enum AVSampleFormat sample_fmt)
#define AUDIO_REFILL_THRESH
static AVCodecContext * dec_ctx
reference-counted frame API
int avcodec_open2(AVCodecContext *avctx, const AVCodec *codec, AVDictionary **options)
Initialize the AVCodecContext to use the given AVCodec.
AVCodecContext * avcodec_alloc_context3(const AVCodec *codec)
Allocate an AVCodecContext and set its fields to default values.
const AVCodec * avcodec_find_decoder(enum AVCodecID id)
Find a registered decoder with a matching codec ID.
void avcodec_free_context(AVCodecContext **avctx)
Free the codec context and everything associated with it and write NULL to the provided pointer.
int avcodec_receive_frame(AVCodecContext *avctx, AVFrame *frame)
Return decoded output data from a decoder.
int avcodec_send_packet(AVCodecContext *avctx, const AVPacket *avpkt)
Supply raw packet data as input to a decoder.
#define AV_INPUT_BUFFER_PADDING_SIZE
Required number of additionally allocated bytes at the end of the input bitstream for decoding.
void av_packet_free(AVPacket **pkt)
Free the packet, if the packet is reference counted, it will be unreferenced first.
AVPacket * av_packet_alloc(void)
Allocate an AVPacket and set its fields to default values.
void av_parser_close(AVCodecParserContext *s)
int av_parser_parse2(AVCodecParserContext *s, AVCodecContext *avctx, uint8_t **poutbuf, int *poutbuf_size, const uint8_t *buf, int buf_size, int64_t pts, int64_t dts, int64_t pos)
Parse a packet.
AVCodecParserContext * av_parser_init(int codec_id)
#define AVERROR_EOF
End of file.
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values.
void av_free(void *ptr)
Free a memory block which has been allocated with a function of av_malloc() or av_realloc() family.
int av_sample_fmt_is_planar(enum AVSampleFormat sample_fmt)
Check if the sample format is planar.
int av_get_bytes_per_sample(enum AVSampleFormat sample_fmt)
Return number of bytes per sample.
enum AVSampleFormat av_get_packed_sample_fmt(enum AVSampleFormat sample_fmt)
Get the packed alternative form of the given sample format.
const char * av_get_sample_fmt_name(enum AVSampleFormat sample_fmt)
Return the name of sample_fmt, or NULL if sample_fmt is not recognized.
AVSampleFormat
Audio sample formats.
@ AV_SAMPLE_FMT_S32
signed 32 bits
@ AV_SAMPLE_FMT_U8
unsigned 8 bits
@ AV_SAMPLE_FMT_DBL
double
@ AV_SAMPLE_FMT_S16
signed 16 bits
#define AV_NOPTS_VALUE
Undefined timestamp value.
#define FF_ARRAY_ELEMS(a)
Memory handling functions.
int nb_channels
Number of channels in this layout.
main external API structure.
AVChannelLayout ch_layout
Audio channel layout.
enum AVSampleFormat sample_fmt
audio sample format
int sample_rate
samples per second
This structure describes decoded (raw) audio or video data.
int nb_samples
number of audio samples (per channel) described by this frame
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
This structure stores compressed data.