diff options
author | Glenn Kasten <gkasten@google.com> | 2012-08-29 11:10:32 -0700 |
---|---|---|
committer | Glenn Kasten <gkasten@google.com> | 2012-08-30 10:53:37 -0700 |
commit | 2dd4bdd715f586d4d30cf90cc6fc2bbfbce60fe0 (patch) | |
tree | d0f594b402b6d2a4de89386c30c3db4adab89894 /media/libnbaio/MonoPipeReader.cpp | |
parent | 0a24726a64ba1c50aa6ee1610de2d80602d49fe6 (diff) | |
download | frameworks_av-2dd4bdd715f586d4d30cf90cc6fc2bbfbce60fe0.zip frameworks_av-2dd4bdd715f586d4d30cf90cc6fc2bbfbce60fe0.tar.gz frameworks_av-2dd4bdd715f586d4d30cf90cc6fc2bbfbce60fe0.tar.bz2 |
Move libnbaio out of AudioFlinger
libnbaio is now a separate shared library from AudioFlinger, rather
than a static library used only by AudioFlinger.
AudioBufferProvider interface is now also independent of AudioFlinger,
moved to include/media/
Change-Id: I9bb62ffbc38d42a38b0af76e66da5e9ab1e0e21b
Diffstat (limited to 'media/libnbaio/MonoPipeReader.cpp')
-rw-r--r-- | media/libnbaio/MonoPipeReader.cpp | 89 |
1 files changed, 89 insertions, 0 deletions
diff --git a/media/libnbaio/MonoPipeReader.cpp b/media/libnbaio/MonoPipeReader.cpp new file mode 100644 index 0000000..394f6ac --- /dev/null +++ b/media/libnbaio/MonoPipeReader.cpp @@ -0,0 +1,89 @@ +/* + * Copyright (C) 2012 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#define LOG_TAG "MonoPipeReader" +//#define LOG_NDEBUG 0 + +#include <cutils/compiler.h> +#include <utils/Log.h> +#include <media/nbaio/MonoPipeReader.h> + +namespace android { + +MonoPipeReader::MonoPipeReader(MonoPipe* pipe) : + NBAIO_Source(pipe->mFormat), + mPipe(pipe) +{ +} + +MonoPipeReader::~MonoPipeReader() +{ +} + +ssize_t MonoPipeReader::availableToRead() +{ + if (CC_UNLIKELY(!mNegotiated)) { + return NEGOTIATE; + } + ssize_t ret = android_atomic_acquire_load(&mPipe->mRear) - mPipe->mFront; + ALOG_ASSERT((0 <= ret) && (ret <= mMaxFrames)); + return ret; +} + +ssize_t MonoPipeReader::read(void *buffer, size_t count, int64_t readPTS) +{ + // Compute the "next read PTS" and cache it. Callers of read pass a read + // PTS indicating the local time for which they are requesting data along + // with a count (which is the number of audio frames they are going to + // ultimately pass to the next stage of the pipeline). Offsetting readPTS + // by the duration of count will give us the readPTS which will be passed to + // us next time, assuming they system continues to operate in steady state + // with no discontinuities. We stash this value so it can be used by the + // MonoPipe writer to imlement getNextWriteTimestamp. + int64_t nextReadPTS; + nextReadPTS = mPipe->offsetTimestampByAudioFrames(readPTS, count); + + // count == 0 is unlikely and not worth checking for explicitly; will be handled automatically + ssize_t red = availableToRead(); + if (CC_UNLIKELY(red <= 0)) { + // Uh-oh, looks like we are underflowing. Update the next read PTS and + // get out. + mPipe->updateFrontAndNRPTS(mPipe->mFront, nextReadPTS); + return red; + } + if (CC_LIKELY((size_t) red > count)) { + red = count; + } + size_t front = mPipe->mFront & (mPipe->mMaxFrames - 1); + size_t part1 = mPipe->mMaxFrames - front; + if (part1 > (size_t) red) { + part1 = red; + } + if (CC_LIKELY(part1 > 0)) { + memcpy(buffer, (char *) mPipe->mBuffer + (front << mBitShift), part1 << mBitShift); + if (CC_UNLIKELY(front + part1 == mPipe->mMaxFrames)) { + size_t part2 = red - part1; + if (CC_LIKELY(part2 > 0)) { + memcpy((char *) buffer + (part1 << mBitShift), mPipe->mBuffer, part2 << mBitShift); + } + } + mPipe->updateFrontAndNRPTS(red + mPipe->mFront, nextReadPTS); + mFramesRead += red; + } + return red; +} + +} // namespace android |