summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGlenn Kasten <gkasten@google.com>2012-01-20 14:13:41 -0800
committerAndroid Git Automerger <android-git-automerger@android.com>2012-01-20 14:13:41 -0800
commitb4ae95519a29f2b0a9cc34f72a9b3a7733cdb90f (patch)
tree8da97263ea83487a4bf4cf896d0b29644c04c7ad
parent6e14668cc4fe2cb457e53937568efbe94e967cbc (diff)
parent5ecff094f4df499f997bc9406c6e1a76a899aa12 (diff)
downloadframeworks_base-b4ae95519a29f2b0a9cc34f72a9b3a7733cdb90f.zip
frameworks_base-b4ae95519a29f2b0a9cc34f72a9b3a7733cdb90f.tar.gz
frameworks_base-b4ae95519a29f2b0a9cc34f72a9b3a7733cdb90f.tar.bz2
am 5ecff094: Merge "Move memcpy_to_i16_from_u8 to audio_utils"
* commit '5ecff094f4df499f997bc9406c6e1a76a899aa12': Move memcpy_to_i16_from_u8 to audio_utils
-rw-r--r--media/libmedia/AudioTrack.cpp18
1 files changed, 5 insertions, 13 deletions
diff --git a/media/libmedia/AudioTrack.cpp b/media/libmedia/AudioTrack.cpp
index 837fcc3..17e3d4b 100644
--- a/media/libmedia/AudioTrack.cpp
+++ b/media/libmedia/AudioTrack.cpp
@@ -43,6 +43,8 @@
#include <system/audio.h>
#include <system/audio_policy.h>
+#include <audio_utils/primitives.h>
+
namespace android {
// ---------------------------------------------------------------------------
@@ -1017,12 +1019,7 @@ ssize_t AudioTrack::write(const void* buffer, size_t userSize)
if (mFormat == AUDIO_FORMAT_PCM_8_BIT && !(mFlags & AUDIO_POLICY_OUTPUT_FLAG_DIRECT)) {
// Divide capacity by 2 to take expansion into account
toWrite = audioBuffer.size>>1;
- // 8 to 16 bit conversion
- int count = toWrite;
- int16_t *dst = (int16_t *)(audioBuffer.i8);
- while(count--) {
- *dst++ = (int16_t)(*src++^0x80) << 8;
- }
+ memcpy_to_i16_from_u8(audioBuffer.i16, (const uint8_t *) src, toWrite);
} else {
toWrite = audioBuffer.size;
memcpy(audioBuffer.i8, src, toWrite);
@@ -1143,13 +1140,8 @@ bool AudioTrack::processAudioBuffer(const sp<AudioTrackThread>& thread)
if (writtenSize > reqSize) writtenSize = reqSize;
if (mFormat == AUDIO_FORMAT_PCM_8_BIT && !(mFlags & AUDIO_POLICY_OUTPUT_FLAG_DIRECT)) {
- // 8 to 16 bit conversion
- const int8_t *src = audioBuffer.i8 + writtenSize-1;
- int count = writtenSize;
- int16_t *dst = audioBuffer.i16 + writtenSize-1;
- while(count--) {
- *dst-- = (int16_t)(*src--^0x80) << 8;
- }
+ // 8 to 16 bit conversion, note that source and destination are the same address
+ memcpy_to_i16_from_u8(audioBuffer.i16, (const uint8_t *) audioBuffer.i8, writtenSize);
writtenSize <<= 1;
}