diff options
author | Glenn Kasten <gkasten@google.com> | 2015-03-03 11:48:45 -0800 |
---|---|---|
committer | Glenn Kasten <gkasten@google.com> | 2015-03-03 15:56:01 -0800 |
commit | 5115777127bb4d2d50833537e09054dcdffdfc76 (patch) | |
tree | 70e9d2aeb62926d0d9513fad6f607904a43de74f /services/audioflinger | |
parent | 8a0554c63dc40a2a7c066b03041079ec9eb220e5 (diff) | |
download | frameworks_av-5115777127bb4d2d50833537e09054dcdffdfc76.zip frameworks_av-5115777127bb4d2d50833537e09054dcdffdfc76.tar.gz frameworks_av-5115777127bb4d2d50833537e09054dcdffdfc76.tar.bz2 |
Remove PCM16 assumption from FastCapture
Bug: 19586911
Change-Id: I74d4ddc09a9eb9c651f874482639d39a56f8ca1f
Diffstat (limited to 'services/audioflinger')
-rw-r--r-- | services/audioflinger/FastCapture.cpp | 13 | ||||
-rw-r--r-- | services/audioflinger/FastCapture.h | 2 |
2 files changed, 6 insertions, 9 deletions
diff --git a/services/audioflinger/FastCapture.cpp b/services/audioflinger/FastCapture.cpp index 2a10b4b..9e7e8a4 100644 --- a/services/audioflinger/FastCapture.cpp +++ b/services/audioflinger/FastCapture.cpp @@ -69,7 +69,7 @@ void FastCapture::onIdle() void FastCapture::onExit() { - delete[] mReadBuffer; + free(mReadBuffer); } bool FastCapture::isSubClassCommand(FastThreadState::Command command) @@ -124,16 +124,14 @@ void FastCapture::onStateChange() } if ((!Format_isEqual(mFormat, previousFormat)) || (frameCount != previous->mFrameCount)) { - // FIXME to avoid priority inversion, don't delete here - delete[] mReadBuffer; + // FIXME to avoid priority inversion, don't free here + free(mReadBuffer); mReadBuffer = NULL; if (frameCount > 0 && mSampleRate > 0) { // FIXME new may block for unbounded time at internal mutex of the heap // implementation; it would be better to have normal capture thread allocate for // us to avoid blocking here and to prevent possible priority inversion - unsigned channelCount = Format_channelCount(mFormat); - // FIXME frameSize - mReadBuffer = new short[frameCount * channelCount]; + (void)posix_memalign(&mReadBuffer, 32, frameCount * Format_frameSize(mFormat)); mPeriodNs = (frameCount * 1000000000LL) / mSampleRate; // 1.00 mUnderrunNs = (frameCount * 1750000000LL) / mSampleRate; // 1.75 mOverrunNs = (frameCount * 500000000LL) / mSampleRate; // 0.50 @@ -188,8 +186,7 @@ void FastCapture::onWork() ALOG_ASSERT(mReadBuffer != NULL); if (mReadBufferState < 0) { unsigned channelCount = Format_channelCount(mFormat); - // FIXME frameSize - memset(mReadBuffer, 0, frameCount * channelCount * sizeof(short)); + memset(mReadBuffer, 0, frameCount * Format_frameSize(mFormat)); mReadBufferState = frameCount; } if (mReadBufferState > 0) { diff --git a/services/audioflinger/FastCapture.h b/services/audioflinger/FastCapture.h index eec89c9..e258a4d 100644 --- a/services/audioflinger/FastCapture.h +++ b/services/audioflinger/FastCapture.h @@ -54,7 +54,7 @@ private: int mInputSourceGen; NBAIO_Sink* mPipeSink; int mPipeSinkGen; - short* mReadBuffer; + void* mReadBuffer; ssize_t mReadBufferState; // number of initialized frames in readBuffer, // or -1 to clear NBAIO_Format mFormat; |