mirror of https://github.com/FFmpeg/FFmpeg.git
Compare commits
2 Commits
35464ad9eb
...
6cdd2cbe32
| Author | SHA1 | Date |
|---|---|---|
|
|
6cdd2cbe32 | |
|
|
362d673ad6 |
|
|
@ -596,6 +596,7 @@ const AVCodecTag ff_codec_wav_tags[] = {
|
|||
/* ADTS AAC */
|
||||
{ AV_CODEC_ID_AAC, 0x1600 },
|
||||
{ AV_CODEC_ID_AAC_LATM, 0x1602 },
|
||||
{ AV_CODEC_ID_AAC, 0x1610 },
|
||||
{ AV_CODEC_ID_AC3, 0x2000 },
|
||||
/* There is no Microsoft Format Tag for E-AC3, the GUID has to be used */
|
||||
{ AV_CODEC_ID_EAC3, 0x2000 },
|
||||
|
|
|
|||
|
|
@ -149,6 +149,20 @@ int ff_get_wav_header(AVFormatContext *s, AVIOContext *pb,
|
|||
parse_waveformatex(s, pb, par);
|
||||
cbSize -= 22;
|
||||
size -= 22;
|
||||
} else if (cbSize >= 12 && id == 0x1610) { /* HEAACWAVEFORMAT */
|
||||
int wPayloadType = avio_rl16(pb);
|
||||
if (wPayloadType == 3)
|
||||
par->codec_id = AV_CODEC_ID_AAC_LATM;
|
||||
avio_skip(pb, 2); // wAudioProfileLevelIndication
|
||||
int wStructType = avio_rl16(pb);
|
||||
if (wStructType) {
|
||||
avpriv_report_missing_feature(s, "HEAACWAVEINFO wStructType \"%d\"", wStructType);
|
||||
return AVERROR_PATCHWELCOME;
|
||||
}
|
||||
avio_skip(pb, 2); // wReserved1
|
||||
avio_skip(pb, 4); // dwReserved2
|
||||
cbSize -= 12;
|
||||
size -= 12;
|
||||
}
|
||||
if (cbSize > 0) {
|
||||
ret = ff_get_extradata(s, par, pb, cbSize);
|
||||
|
|
|
|||
|
|
@ -200,6 +200,18 @@ int ff_put_wav_header(AVFormatContext *s, AVIOContext *pb,
|
|||
par->codec_tag != 0x0001 /* PCM */ ||
|
||||
riff_extradata - riff_extradata_start) {
|
||||
/* WAVEFORMATEX */
|
||||
if (par->codec_tag == 0x1610) {
|
||||
/* HEAACWAVEFORMAT */
|
||||
avio_wl16(pb, par->extradata_size + 12); /* cbSize */
|
||||
avio_wl16(pb, !par->extradata_size); // wPayloadType, 0 = Raw, 1 = ADTS
|
||||
avio_wl16(pb, 0xFE); // wAudioProfileLevelIndication, 0xFE = unspecified
|
||||
avio_wl16(pb, 0); // wStructType, 0 = AudioSpecificConfig()
|
||||
avio_wl16(pb, 0); // wReserved1
|
||||
avio_wl32(pb, 0); // dwReserved2
|
||||
} else if (par->codec_tag == 0xFF && !par->extradata_size) {
|
||||
av_log(s, AV_LOG_ERROR, "ADTS is only supported with codec tag 0x1610\n");
|
||||
return AVERROR(EINVAL);
|
||||
} else
|
||||
avio_wl16(pb, riff_extradata - riff_extradata_start); /* cbSize */
|
||||
} /* else PCMWAVEFORMAT */
|
||||
avio_write(pb, riff_extradata_start, riff_extradata - riff_extradata_start);
|
||||
|
|
|
|||
|
|
@ -32,7 +32,7 @@
|
|||
#include "version_major.h"
|
||||
|
||||
#define LIBAVFORMAT_VERSION_MINOR 6
|
||||
#define LIBAVFORMAT_VERSION_MICRO 101
|
||||
#define LIBAVFORMAT_VERSION_MICRO 103
|
||||
|
||||
#define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \
|
||||
LIBAVFORMAT_VERSION_MINOR, \
|
||||
|
|
|
|||
Loading…
Reference in New Issue