Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mpc-hc/mpc-hc.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorv0lt <v0lt@users.sourceforge.net>2012-06-14 00:19:53 +0400
committerv0lt <v0lt@users.sourceforge.net>2012-06-14 00:19:53 +0400
commitb53e3e4b5ceadedcfce22a62297486238244228f (patch)
tree61ce52c2f68acfbbd603954cc295665b30162b59 /src/filters/parser/MP4Splitter/MP4Splitter.cpp
parent51e4c08820126d7e926c3728c26c65d832e4cb7d (diff)
MP4Splitter: non-zero number of channels for some movs (ticket #2391), cosmetics
git-svn-id: https://mpc-hc.svn.sourceforge.net/svnroot/mpc-hc/trunk@5127 10f7b99b-c216-0410-bff0-8a66a9350fd8
Diffstat (limited to 'src/filters/parser/MP4Splitter/MP4Splitter.cpp')
-rw-r--r--src/filters/parser/MP4Splitter/MP4Splitter.cpp28
1 files changed, 17 insertions, 11 deletions
diff --git a/src/filters/parser/MP4Splitter/MP4Splitter.cpp b/src/filters/parser/MP4Splitter/MP4Splitter.cpp
index a5ab36613..42882d536 100644
--- a/src/filters/parser/MP4Splitter/MP4Splitter.cpp
+++ b/src/filters/parser/MP4Splitter/MP4Splitter.cpp
@@ -659,28 +659,31 @@ HRESULT CMP4SplitterFilter::CreateOutputs(IAsyncReader* pAsyncReader)
if (!di) {
di = &empty;
}
+ const BYTE* extdata = di->GetData();
+ size_t extsize = di->GetDataSize();
+ ASSERT(extsize <= WORD_MAX);
mt.majortype = MEDIATYPE_Audio;
mt.formattype = FORMAT_WaveFormatEx;
wfe = (WAVEFORMATEX*)mt.AllocFormatBuffer(sizeof(WAVEFORMATEX) + di->GetDataSize());
memset(wfe, 0, mt.FormatLength());
- wfe->nSamplesPerSec = audio_desc->GetSampleRate();
+ wfe->nSamplesPerSec = audio_desc->GetSampleRate();
wfe->nAvgBytesPerSec = audio_desc->GetAvgBitrate() / 8;
- wfe->nChannels = audio_desc->GetChannelCount();
- wfe->wBitsPerSample = audio_desc->GetSampleSize();
- wfe->cbSize = (WORD)di->GetDataSize();
- wfe->nBlockAlign = (WORD)((wfe->nChannels * wfe->wBitsPerSample) / 8);
+ wfe->nChannels = audio_desc->GetChannelCount();
+ wfe->wBitsPerSample = audio_desc->GetSampleSize();
+ wfe->cbSize = (WORD)extsize;
+ wfe->nBlockAlign = wfe->nChannels * wfe->wBitsPerSample / 8;
- memcpy(wfe + 1, di->GetData(), di->GetDataSize());
+ memcpy(wfe + 1, extdata, extsize);
switch (audio_desc->GetObjectTypeId()) {
case AP4_MPEG4_AUDIO_OTI:
case AP4_MPEG2_AAC_AUDIO_MAIN_OTI: // ???
case AP4_MPEG2_AAC_AUDIO_LC_OTI: // ???
case AP4_MPEG2_AAC_AUDIO_SSRP_OTI: // ???
- if (di->GetDataSize() > 10) {
- if (*(DWORD*)(di->GetData() + 6) == 0x00534c41) { // 'ALS\0' sync word
+ if (extsize > 10) {
+ if (*(DWORD*)(extdata + 6) == 0x00534c41) { // 'ALS\0' sync word
wfe->wFormatTag = WAVE_FORMAT_UNKNOWN;
mt.subtype = FOURCCMap(MAKEFOURCC('A', 'L', 'S', ' ')); // create our own GUID - {20534C41-0000-0010-8000-00AA00389B71}
mts.Add(mt);
@@ -688,9 +691,12 @@ HRESULT CMP4SplitterFilter::CreateOutputs(IAsyncReader* pAsyncReader)
}
}
mt.subtype = FOURCCMap(wfe->wFormatTag = WAVE_FORMAT_AAC);
- if (wfe->cbSize >= 2 && wfe->nChannels < 8) {
- wfe->nChannels = (((BYTE*)(wfe + 1))[1] >> 3) & 0xf;
- wfe->nBlockAlign = (WORD)((wfe->nChannels * wfe->wBitsPerSample) / 8);
+ if (extsize >= 2 && wfe->nChannels < 8) {
+ WORD channels = (extdata[1] >> 3) & 0xf;
+ if (channels) { // not the best solution
+ wfe->nChannels = channels;
+ wfe->nBlockAlign = channels * wfe->wBitsPerSample / 8;
+ }
}
mts.Add(mt);
break;