mirror of https://git.ffmpeg.org/ffmpeg.git
Merge commit '0097cbea695e534fce39958ccd103af2fbf65831'
* commit '0097cbea695e534fce39958ccd103af2fbf65831': flac muxer: accept only STREAMINFO extradata Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
commit
855e3b5700
|
@ -22,7 +22,7 @@
|
|||
#include "libavutil/channel_layout.h"
|
||||
|
||||
#include "libavcodec/flac.h"
|
||||
#include "libavcodec/bytestream.h"
|
||||
|
||||
#include "avformat.h"
|
||||
#include "flacenc.h"
|
||||
|
||||
|
@ -32,18 +32,17 @@ int ff_flac_write_header(AVIOContext *pb, AVCodecContext *codec,
|
|||
uint8_t header[8] = {
|
||||
0x66, 0x4C, 0x61, 0x43, 0x00, 0x00, 0x00, 0x22
|
||||
};
|
||||
uint8_t *streaminfo;
|
||||
enum FLACExtradataFormat format;
|
||||
|
||||
header[4] = last_block ? 0x80 : 0x00;
|
||||
if (!avpriv_flac_is_extradata_valid(codec, &format, &streaminfo))
|
||||
return -1;
|
||||
|
||||
if (codec->extradata_size < FLAC_STREAMINFO_SIZE)
|
||||
return AVERROR_INVALIDDATA;
|
||||
|
||||
/* write "fLaC" stream marker and first metadata block header */
|
||||
avio_write(pb, header, 8);
|
||||
|
||||
/* write STREAMINFO */
|
||||
avio_write(pb, streaminfo, FLAC_STREAMINFO_SIZE);
|
||||
avio_write(pb, codec->extradata, FLAC_STREAMINFO_SIZE);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue