diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2013-04-22 12:36:29 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2013-04-22 12:36:29 +0200 |
commit | 05deb05fe9ce28cc7b9951446edfaabc364b0b88 (patch) | |
tree | 6e03a0ede6c6285de9eccb86faabedb258534ba7 | |
parent | 52e40155a8e1f41b2d97e5832022263b77752f32 (diff) | |
parent | a3bf80a5aea577663354bd538e345b283bcb73de (diff) | |
download | ffmpeg-05deb05fe9ce28cc7b9951446edfaabc364b0b88.tar.gz |
Merge commit 'a3bf80a5aea577663354bd538e345b283bcb73de'
* commit 'a3bf80a5aea577663354bd538e345b283bcb73de':
riff: Perform full lookup on WAVEFORMATEXTENSIBLE subformat guid
Conflicts:
libavformat/riff.c
Merged-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r-- | libavformat/riff.c | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/libavformat/riff.c b/libavformat/riff.c index 9bc637262c..b9957e698b 100644 --- a/libavformat/riff.c +++ b/libavformat/riff.c @@ -770,7 +770,8 @@ int ff_get_wav_header(AVIOContext *pb, AVCodecContext *codec, int size) codec->codec_tag = 0; } else { codec->codec_tag = id; - codec->codec_id = ff_wav_codec_get_id(id, codec->bits_per_coded_sample); + codec->codec_id = ff_wav_codec_get_id(id, + codec->bits_per_coded_sample); } if (size >= 18) { /* We're obviously dealing with WAVEFORMATEX */ int cbSize = avio_rl16(pb); /* cbSize */ @@ -782,14 +783,20 @@ int ff_get_wav_header(AVIOContext *pb, AVCodecContext *codec, int size) if (bps) codec->bits_per_coded_sample = bps; codec->channel_layout = avio_rl32(pb); /* dwChannelMask */ + ff_get_guid(pb, &subformat); - if (!memcmp(subformat + 4, (const uint8_t[]){FF_MEDIASUBTYPE_BASE_GUID}, 12)) { + if (!memcmp(subformat + 4, + (const uint8_t[]){ FF_MEDIASUBTYPE_BASE_GUID }, 12)) { codec->codec_tag = AV_RL32(subformat); - codec->codec_id = ff_wav_codec_get_id(codec->codec_tag, codec->bits_per_coded_sample); + codec->codec_id = ff_wav_codec_get_id(codec->codec_tag, + codec->bits_per_coded_sample); } else { - codec->codec_id = ff_codec_guid_get_id(ff_codec_wav_guids, subformat); + codec->codec_id = ff_codec_guid_get_id(ff_codec_wav_guids, + subformat); if (!codec->codec_id) - av_log(codec, AV_LOG_WARNING, "unknown subformat:"FF_PRI_GUID"\n", FF_ARG_GUID(subformat)); + av_log(codec, AV_LOG_WARNING, + "unknown subformat: "FF_PRI_GUID"\n", + FF_ARG_GUID(subformat)); } cbSize -= 22; size -= 22; |