1 /* 2 * Copyright (C) 2011 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 #include <variablespeed.h> 18 19 #include <unistd.h> 20 #include <stdlib.h> 21 22 #include <sola_time_scaler.h> 23 #include <ring_buffer.h> 24 25 #include <hlogging.h> 26 27 #include <vector> 28 29 #include <sys/system_properties.h> 30 31 // **************************************************************************** 32 // Constants, utility methods, structures and other miscellany used throughout 33 // this file. 34 35 namespace { 36 37 // These variables are used to determine the size of the buffer queue used by 38 // the decoder. 39 // This is not the same as the large buffer used to hold the uncompressed data 40 // - for that see the member variable decodeBuffer_. 41 // The choice of 1152 corresponds to the number of samples per mp3 frame, so is 42 // a good choice of size for a decoding buffer in the absence of other 43 // information (we don't know exactly what formats we will be working with). 44 const size_t kNumberOfBuffersInQueue = 4; 45 const size_t kNumberOfSamplesPerBuffer = 1152; 46 const size_t kBufferSizeInBytes = 2 * kNumberOfSamplesPerBuffer; 47 const size_t kSampleSizeInBytes = 4; 48 49 // When calculating play buffer size before pushing to audio player. 50 const size_t kNumberOfBytesPerInt16 = 2; 51 52 // How long to sleep during the main play loop and the decoding callback loop. 53 // In due course this should be replaced with the better signal and wait on 54 // condition rather than busy-looping. 55 const int kSleepTimeMicros = 1000; 56 57 // Used in detecting errors with the OpenSL ES framework. 58 const SLuint32 kPrefetchErrorCandidate = 59 SL_PREFETCHEVENT_STATUSCHANGE | SL_PREFETCHEVENT_FILLLEVELCHANGE; 60 61 // Structure used when we perform a decoding callback. 62 typedef struct CallbackContext_ { 63 // Pointer to local storage buffers for decoded audio data. 64 int8_t* pDataBase; 65 // Pointer to the current buffer within local storage. 66 int8_t* pData; 67 // Used to read the sample rate and channels from the decoding stream during 68 // the first decoding callback. 69 SLMetadataExtractionItf decoderMetadata; 70 // The play interface used for reading duration. 71 SLPlayItf playItf; 72 } CallbackContext; 73 74 // Local storage for decoded audio data. 75 int8_t pcmData[kNumberOfBuffersInQueue * kBufferSizeInBytes]; 76 77 #define CheckSLResult(message, result) \ 78 CheckSLResult_Real(message, result, __LINE__) 79 80 // Helper function for debugging - checks the OpenSL result for success. 81 void CheckSLResult_Real(const char* message, SLresult result, int line) { 82 // This can be helpful when debugging. 83 // LOGD("sl result %d for %s", result, message); 84 if (SL_RESULT_SUCCESS != result) { 85 LOGE("slresult was %d at %s file variablespeed line %d", 86 static_cast<int>(result), message, line); 87 } 88 CHECK(SL_RESULT_SUCCESS == result); 89 } 90 91 // Whether logging should be enabled. Only used if LOG_OPENSL_API_CALL is 92 // defined to use it. 93 bool gLogEnabled = false; 94 // The property to set in order to enable logging. 95 const char *const kLogTagVariableSpeed = "log.tag.VariableSpeed"; 96 97 bool ShouldLog() { 98 char buffer[PROP_VALUE_MAX]; 99 __system_property_get(kLogTagVariableSpeed, buffer); 100 return strlen(buffer) > 0; 101 } 102 103 } // namespace 104 105 // **************************************************************************** 106 // Static instance of audio engine, and methods for getting, setting and 107 // deleting it. 108 109 // The single global audio engine instance. 110 AudioEngine* AudioEngine::audioEngine_ = NULL; 111 android::Mutex publishEngineLock_; 112 113 AudioEngine* AudioEngine::GetEngine() { 114 android::Mutex::Autolock autoLock(publishEngineLock_); 115 if (audioEngine_ == NULL) { 116 LOGE("you haven't initialized the audio engine"); 117 CHECK(false); 118 return NULL; 119 } 120 return audioEngine_; 121 } 122 123 void AudioEngine::SetEngine(AudioEngine* engine) { 124 if (audioEngine_ != NULL) { 125 LOGE("you have already set the audio engine"); 126 CHECK(false); 127 return; 128 } 129 audioEngine_ = engine; 130 } 131 132 bool AudioEngine::CompareAndSetEngine(AudioEngine* expect, AudioEngine* update) { 133 android::Mutex::Autolock autoLock(publishEngineLock_); 134 if (audioEngine_ == expect) { 135 DeleteEngine(); 136 audioEngine_ = update; 137 return true; 138 } 139 return false; 140 } 141 142 void AudioEngine::DeleteEngine() { 143 if (audioEngine_ != NULL) { 144 delete audioEngine_; 145 audioEngine_ = NULL; 146 } 147 } 148 149 // **************************************************************************** 150 // The callbacks from the engine require static callback functions. 151 // Here are the static functions - they just delegate to instance methods on 152 // the engine. 153 154 static void PlayingBufferQueueCb(SLAndroidSimpleBufferQueueItf, void*) { 155 AudioEngine::GetEngine()->PlayingBufferQueueCallback(); 156 } 157 158 static void PrefetchEventCb(SLPrefetchStatusItf caller, void*, SLuint32 event) { 159 AudioEngine::GetEngine()->PrefetchEventCallback(caller, event); 160 } 161 162 static void DecodingBufferQueueCb(SLAndroidSimpleBufferQueueItf queueItf, 163 void *context) { 164 AudioEngine::GetEngine()->DecodingBufferQueueCallback(queueItf, context); 165 } 166 167 static void DecodingEventCb(SLPlayItf caller, void*, SLuint32 event) { 168 AudioEngine::GetEngine()->DecodingEventCallback(caller, event); 169 } 170 171 // **************************************************************************** 172 // Macros for making working with OpenSL easier. 173 174 // Log based on the value of a property. 175 #define LOG_OPENSL_API_CALL(string) (gLogEnabled && LOGV(string)) 176 177 // The regular macro: log an api call, make the api call, check the result. 178 #define OpenSL(obj, method, ...) \ 179 { \ 180 LOG_OPENSL_API_CALL("OpenSL " #method "(" #obj ", " #__VA_ARGS__ ")"); \ 181 SLresult result = (*obj)->method(obj, __VA_ARGS__); \ 182 CheckSLResult("OpenSL " #method "(" #obj ", " #__VA_ARGS__ ")", result); \ 183 } 184 185 // Special case call for api call that has void return value, can't be checked. 186 #define VoidOpenSL(obj, method) \ 187 { \ 188 LOG_OPENSL_API_CALL("OpenSL (void) " #method "(" #obj ")"); \ 189 (*obj)->method(obj); \ 190 } 191 192 // Special case for api call with checked result but takes no arguments. 193 #define OpenSL0(obj, method) \ 194 { \ 195 LOG_OPENSL_API_CALL("OpenSL " #method "(" #obj ")"); \ 196 SLresult result = (*obj)->method(obj); \ 197 CheckSLResult("OpenSL " #method "(" #obj ")", result); \ 198 } 199 200 // Special case for api call whose result we want to store, not check. 201 // We have to encapsulate the two calls in braces, so that this expression 202 // evaluates to the last expression not the first. 203 #define ReturnOpenSL(obj, method, ...) \ 204 ( \ 205 LOG_OPENSL_API_CALL("OpenSL (int) " \ 206 #method "(" #obj ", " #__VA_ARGS__ ")"), \ 207 (*obj)->method(obj, __VA_ARGS__) \ 208 ) \ 209 210 // **************************************************************************** 211 // Static utility methods. 212 213 // Set the audio stream type for the player. 214 // 215 // Must be called before it is realized. 216 // 217 // The caller must have requested the SL_IID_ANDROIDCONFIGURATION interface when 218 // creating the player. 219 static void setAudioStreamType(SLObjectItf audioPlayer, SLint32 audioStreamType) { 220 SLAndroidConfigurationItf playerConfig; 221 OpenSL(audioPlayer, GetInterface, SL_IID_ANDROIDCONFIGURATION, &playerConfig); 222 // The STREAM_XXX constants defined by android.media.AudioManager match the 223 // corresponding SL_ANDROID_STREAM_XXX constants defined by 224 // include/SLES/OpenSLES_AndroidConfiguration.h, so we can just pass the 225 // value across. 226 OpenSL(playerConfig, SetConfiguration, SL_ANDROID_KEY_STREAM_TYPE, 227 &audioStreamType, sizeof(audioStreamType)); 228 } 229 230 // Must be called with callbackLock_ held. 231 static void ReadSampleRateAndChannelCount(CallbackContext *pContext, 232 SLuint32 *sampleRateOut, SLuint32 *channelsOut) { 233 SLMetadataExtractionItf decoderMetadata = pContext->decoderMetadata; 234 SLuint32 itemCount; 235 OpenSL(decoderMetadata, GetItemCount, &itemCount); 236 SLuint32 i, keySize, valueSize; 237 SLMetadataInfo *keyInfo, *value; 238 for (i = 0; i < itemCount; ++i) { 239 keyInfo = value = NULL; 240 keySize = valueSize = 0; 241 OpenSL(decoderMetadata, GetKeySize, i, &keySize); 242 keyInfo = static_cast<SLMetadataInfo*>(malloc(keySize)); 243 if (keyInfo) { 244 OpenSL(decoderMetadata, GetKey, i, keySize, keyInfo); 245 if (keyInfo->encoding == SL_CHARACTERENCODING_ASCII 246 || keyInfo->encoding == SL_CHARACTERENCODING_UTF8) { 247 OpenSL(decoderMetadata, GetValueSize, i, &valueSize); 248 value = static_cast<SLMetadataInfo*>(malloc(valueSize)); 249 if (value) { 250 OpenSL(decoderMetadata, GetValue, i, valueSize, value); 251 if (strcmp((char*) keyInfo->data, ANDROID_KEY_PCMFORMAT_SAMPLERATE) == 0) { 252 SLuint32 sampleRate = *(reinterpret_cast<SLuint32*>(value->data)); 253 LOGD("sample Rate: %d", sampleRate); 254 *sampleRateOut = sampleRate; 255 } else if (strcmp((char*) keyInfo->data, ANDROID_KEY_PCMFORMAT_NUMCHANNELS) == 0) { 256 SLuint32 channels = *(reinterpret_cast<SLuint32*>(value->data)); 257 LOGD("channels: %d", channels); 258 *channelsOut = channels; 259 } 260 free(value); 261 } 262 } 263 free(keyInfo); 264 } 265 } 266 } 267 268 // Must be called with callbackLock_ held. 269 static void RegisterCallbackContextAndAddEnqueueBuffersToDecoder( 270 SLAndroidSimpleBufferQueueItf decoderQueue, CallbackContext* context) { 271 // Register a callback on the decoder queue, so that we will be called 272 // throughout the decoding process (and can then extract the decoded audio 273 // for the next bit of the pipeline). 274 OpenSL(decoderQueue, RegisterCallback, DecodingBufferQueueCb, context); 275 276 // Enqueue buffers to map the region of memory allocated to store the 277 // decoded data. 278 for (size_t i = 0; i < kNumberOfBuffersInQueue; i++) { 279 OpenSL(decoderQueue, Enqueue, context->pData, kBufferSizeInBytes); 280 context->pData += kBufferSizeInBytes; 281 } 282 context->pData = context->pDataBase; 283 } 284 285 // **************************************************************************** 286 // Constructor and Destructor. 287 288 AudioEngine::AudioEngine(size_t targetFrames, float windowDuration, 289 float windowOverlapDuration, size_t maxPlayBufferCount, float initialRate, 290 size_t decodeInitialSize, size_t decodeMaxSize, size_t startPositionMillis, 291 int audioStreamType) 292 : decodeBuffer_(decodeInitialSize, decodeMaxSize), 293 playingBuffers_(), freeBuffers_(), timeScaler_(NULL), 294 floatBuffer_(NULL), injectBuffer_(NULL), 295 mSampleRate(0), mChannels(0), 296 targetFrames_(targetFrames), 297 windowDuration_(windowDuration), 298 windowOverlapDuration_(windowOverlapDuration), 299 maxPlayBufferCount_(maxPlayBufferCount), initialRate_(initialRate), 300 startPositionMillis_(startPositionMillis), 301 audioStreamType_(audioStreamType), 302 totalDurationMs_(0), decoderCurrentPosition_(0), startRequested_(false), 303 stopRequested_(false), finishedDecoding_(false) { 304 // Determine whether we should log calls. 305 gLogEnabled = ShouldLog(); 306 } 307 308 AudioEngine::~AudioEngine() { 309 // destroy the time scaler 310 if (timeScaler_ != NULL) { 311 delete timeScaler_; 312 timeScaler_ = NULL; 313 } 314 315 // delete all outstanding playing and free buffers 316 android::Mutex::Autolock autoLock(playBufferLock_); 317 while (playingBuffers_.size() > 0) { 318 delete[] playingBuffers_.front(); 319 playingBuffers_.pop(); 320 } 321 while (freeBuffers_.size() > 0) { 322 delete[] freeBuffers_.top(); 323 freeBuffers_.pop(); 324 } 325 326 delete[] floatBuffer_; 327 floatBuffer_ = NULL; 328 delete[] injectBuffer_; 329 injectBuffer_ = NULL; 330 } 331 332 // **************************************************************************** 333 // Regular AudioEngine class methods. 334 335 void AudioEngine::SetVariableSpeed(float speed) { 336 // TODO: Mutex for shared time scaler accesses. 337 if (HasSampleRateAndChannels()) { 338 GetTimeScaler()->set_speed(speed); 339 } else { 340 // This is being called at a point where we have not yet processed enough 341 // data to determine the sample rate and number of channels. 342 // Ignore the call. See http://b/5140693. 343 LOGD("set varaible speed called, sample rate and channels not ready yet"); 344 } 345 } 346 347 void AudioEngine::RequestStart() { 348 android::Mutex::Autolock autoLock(lock_); 349 startRequested_ = true; 350 } 351 352 void AudioEngine::ClearRequestStart() { 353 android::Mutex::Autolock autoLock(lock_); 354 startRequested_ = false; 355 } 356 357 bool AudioEngine::GetWasStartRequested() { 358 android::Mutex::Autolock autoLock(lock_); 359 return startRequested_; 360 } 361 362 void AudioEngine::RequestStop() { 363 android::Mutex::Autolock autoLock(lock_); 364 stopRequested_ = true; 365 } 366 367 int AudioEngine::GetCurrentPosition() { 368 android::Mutex::Autolock autoLock(decodeBufferLock_); 369 double result = decodeBuffer_.GetTotalAdvancedCount(); 370 // TODO: This is horrible, but should be removed soon once the outstanding 371 // issue with get current position on decoder is fixed. 372 android::Mutex::Autolock autoLock2(callbackLock_); 373 return static_cast<int>( 374 (result * 1000) / mSampleRate / mChannels + startPositionMillis_); 375 } 376 377 int AudioEngine::GetTotalDuration() { 378 android::Mutex::Autolock autoLock(lock_); 379 return static_cast<int>(totalDurationMs_); 380 } 381 382 video_editing::SolaTimeScaler* AudioEngine::GetTimeScaler() { 383 if (timeScaler_ == NULL) { 384 CHECK(HasSampleRateAndChannels()); 385 android::Mutex::Autolock autoLock(callbackLock_); 386 timeScaler_ = new video_editing::SolaTimeScaler(); 387 timeScaler_->Init(mSampleRate, mChannels, initialRate_, windowDuration_, 388 windowOverlapDuration_); 389 } 390 return timeScaler_; 391 } 392 393 bool AudioEngine::EnqueueNextBufferOfAudio( 394 SLAndroidSimpleBufferQueueItf audioPlayerQueue) { 395 size_t channels; 396 { 397 android::Mutex::Autolock autoLock(callbackLock_); 398 channels = mChannels; 399 } 400 size_t frameSizeInBytes = kSampleSizeInBytes * channels; 401 size_t frameCount = 0; 402 while (frameCount < targetFrames_) { 403 size_t framesLeft = targetFrames_ - frameCount; 404 // If there is data already in the time scaler, retrieve it. 405 if (GetTimeScaler()->available() > 0) { 406 size_t retrieveCount = min(GetTimeScaler()->available(), framesLeft); 407 int count = GetTimeScaler()->RetrieveSamples( 408 floatBuffer_ + frameCount * channels, retrieveCount); 409 if (count <= 0) { 410 LOGD("error: count was %d", count); 411 break; 412 } 413 frameCount += count; 414 continue; 415 } 416 // If there is no data in the time scaler, then feed some into it. 417 android::Mutex::Autolock autoLock(decodeBufferLock_); 418 size_t framesInDecodeBuffer = 419 decodeBuffer_.GetSizeInBytes() / frameSizeInBytes; 420 size_t framesScalerCanHandle = GetTimeScaler()->input_limit(); 421 size_t framesToInject = min(framesInDecodeBuffer, 422 min(targetFrames_, framesScalerCanHandle)); 423 if (framesToInject <= 0) { 424 // No more frames left to inject. 425 break; 426 } 427 for (size_t i = 0; i < framesToInject * channels; ++i) { 428 injectBuffer_[i] = decodeBuffer_.GetAtIndex(i); 429 } 430 int count = GetTimeScaler()->InjectSamples(injectBuffer_, framesToInject); 431 if (count <= 0) { 432 LOGD("error: count was %d", count); 433 break; 434 } 435 decodeBuffer_.AdvanceHeadPointerShorts(count * channels); 436 } 437 if (frameCount <= 0) { 438 // We must have finished playback. 439 if (GetEndOfDecoderReached()) { 440 // If we've finished decoding, clear the buffer - so we will terminate. 441 ClearDecodeBuffer(); 442 } 443 return false; 444 } 445 446 // Get a free playing buffer. 447 int16* playBuffer; 448 { 449 android::Mutex::Autolock autoLock(playBufferLock_); 450 if (freeBuffers_.size() > 0) { 451 // If we have a free buffer, recycle it. 452 playBuffer = freeBuffers_.top(); 453 freeBuffers_.pop(); 454 } else { 455 // Otherwise allocate a new one. 456 playBuffer = new int16[targetFrames_ * channels]; 457 } 458 } 459 460 // Try to play the buffer. 461 for (size_t i = 0; i < frameCount * channels; ++i) { 462 playBuffer[i] = floatBuffer_[i]; 463 } 464 size_t sizeOfPlayBufferInBytes = 465 frameCount * channels * kNumberOfBytesPerInt16; 466 SLresult result = ReturnOpenSL(audioPlayerQueue, Enqueue, playBuffer, 467 sizeOfPlayBufferInBytes); 468 if (result == SL_RESULT_SUCCESS) { 469 android::Mutex::Autolock autoLock(playBufferLock_); 470 playingBuffers_.push(playBuffer); 471 } else { 472 LOGE("could not enqueue audio buffer"); 473 delete[] playBuffer; 474 } 475 476 return (result == SL_RESULT_SUCCESS); 477 } 478 479 bool AudioEngine::GetEndOfDecoderReached() { 480 android::Mutex::Autolock autoLock(lock_); 481 return finishedDecoding_; 482 } 483 484 void AudioEngine::SetEndOfDecoderReached() { 485 android::Mutex::Autolock autoLock(lock_); 486 finishedDecoding_ = true; 487 } 488 489 bool AudioEngine::PlayFileDescriptor(int fd, int64 offset, int64 length) { 490 SLDataLocator_AndroidFD loc_fd = { 491 SL_DATALOCATOR_ANDROIDFD, fd, offset, length }; 492 SLDataFormat_MIME format_mime = { 493 SL_DATAFORMAT_MIME, NULL, SL_CONTAINERTYPE_UNSPECIFIED }; 494 SLDataSource audioSrc = { &loc_fd, &format_mime }; 495 return PlayFromThisSource(audioSrc); 496 } 497 498 bool AudioEngine::PlayUri(const char* uri) { 499 // Source of audio data for the decoding 500 SLDataLocator_URI decUri = { SL_DATALOCATOR_URI, 501 const_cast<SLchar*>(reinterpret_cast<const SLchar*>(uri)) }; 502 SLDataFormat_MIME decMime = { 503 SL_DATAFORMAT_MIME, NULL, SL_CONTAINERTYPE_UNSPECIFIED }; 504 SLDataSource decSource = { &decUri, &decMime }; 505 return PlayFromThisSource(decSource); 506 } 507 508 bool AudioEngine::IsDecodeBufferEmpty() { 509 android::Mutex::Autolock autoLock(decodeBufferLock_); 510 return decodeBuffer_.GetSizeInBytes() <= 0; 511 } 512 513 void AudioEngine::ClearDecodeBuffer() { 514 android::Mutex::Autolock autoLock(decodeBufferLock_); 515 decodeBuffer_.Clear(); 516 } 517 518 static size_t ReadDuration(SLPlayItf playItf) { 519 SLmillisecond durationInMsec = SL_TIME_UNKNOWN; 520 OpenSL(playItf, GetDuration, &durationInMsec); 521 if (durationInMsec == SL_TIME_UNKNOWN) { 522 LOGE("can't get duration"); 523 return 0; 524 } 525 LOGD("duration: %d", static_cast<int>(durationInMsec)); 526 return durationInMsec; 527 } 528 529 static size_t ReadPosition(SLPlayItf playItf) { 530 SLmillisecond positionInMsec = SL_TIME_UNKNOWN; 531 OpenSL(playItf, GetPosition, &positionInMsec); 532 if (positionInMsec == SL_TIME_UNKNOWN) { 533 LOGE("can't get position"); 534 return 0; 535 } 536 LOGW("decoder position: %d", static_cast<int>(positionInMsec)); 537 return positionInMsec; 538 } 539 540 static void CreateAndRealizeEngine(SLObjectItf &engine, 541 SLEngineItf &engineInterface) { 542 SLEngineOption EngineOption[] = { { 543 SL_ENGINEOPTION_THREADSAFE, SL_BOOLEAN_TRUE } }; 544 SLresult result = slCreateEngine(&engine, 1, EngineOption, 0, NULL, NULL); 545 CheckSLResult("create engine", result); 546 OpenSL(engine, Realize, SL_BOOLEAN_FALSE); 547 OpenSL(engine, GetInterface, SL_IID_ENGINE, &engineInterface); 548 } 549 550 SLuint32 AudioEngine::GetSLSampleRate() { 551 android::Mutex::Autolock autoLock(callbackLock_); 552 return mSampleRate * 1000; 553 } 554 555 SLuint32 AudioEngine::GetSLChannels() { 556 android::Mutex::Autolock autoLock(callbackLock_); 557 switch (mChannels) { 558 case 2: 559 return SL_SPEAKER_FRONT_LEFT | SL_SPEAKER_FRONT_RIGHT; 560 case 1: 561 return SL_SPEAKER_FRONT_CENTER; 562 default: 563 LOGE("unknown channels %d, using 2", mChannels); 564 return SL_SPEAKER_FRONT_LEFT | SL_SPEAKER_FRONT_RIGHT; 565 } 566 } 567 568 SLuint32 AudioEngine::GetChannelCount() { 569 android::Mutex::Autolock autoLock(callbackLock_); 570 return mChannels; 571 } 572 573 static void CreateAndRealizeAudioPlayer(SLuint32 slSampleRate, 574 size_t channelCount, SLuint32 slChannels, SLint32 audioStreamType, SLObjectItf &outputMix, 575 SLObjectItf &audioPlayer, SLEngineItf &engineInterface) { 576 // Define the source and sink for the audio player: comes from a buffer queue 577 // and goes to the output mix. 578 SLDataLocator_AndroidSimpleBufferQueue loc_bufq = { 579 SL_DATALOCATOR_ANDROIDSIMPLEBUFFERQUEUE, 2 }; 580 SLDataFormat_PCM format_pcm = {SL_DATAFORMAT_PCM, channelCount, slSampleRate, 581 SL_PCMSAMPLEFORMAT_FIXED_16, SL_PCMSAMPLEFORMAT_FIXED_16, 582 slChannels, SL_BYTEORDER_LITTLEENDIAN}; 583 SLDataSource playingSrc = {&loc_bufq, &format_pcm}; 584 SLDataLocator_OutputMix loc_outmix = {SL_DATALOCATOR_OUTPUTMIX, outputMix}; 585 SLDataSink audioSnk = {&loc_outmix, NULL}; 586 587 // Create the audio player, which will play from the buffer queue and send to 588 // the output mix. 589 const size_t playerInterfaceCount = 2; 590 const SLInterfaceID iids[playerInterfaceCount] = { 591 SL_IID_ANDROIDSIMPLEBUFFERQUEUE, SL_IID_ANDROIDCONFIGURATION }; 592 const SLboolean reqs[playerInterfaceCount] = { SL_BOOLEAN_TRUE, SL_BOOLEAN_TRUE }; 593 OpenSL(engineInterface, CreateAudioPlayer, &audioPlayer, &playingSrc, 594 &audioSnk, playerInterfaceCount, iids, reqs); 595 setAudioStreamType(audioPlayer, audioStreamType); 596 OpenSL(audioPlayer, Realize, SL_BOOLEAN_FALSE); 597 } 598 599 bool AudioEngine::HasSampleRateAndChannels() { 600 android::Mutex::Autolock autoLock(callbackLock_); 601 return mChannels != 0 && mSampleRate != 0; 602 } 603 604 bool AudioEngine::PlayFromThisSource(const SLDataSource& audioSrc) { 605 ClearDecodeBuffer(); 606 607 SLObjectItf engine; 608 SLEngineItf engineInterface; 609 CreateAndRealizeEngine(engine, engineInterface); 610 611 // Define the source and sink for the decoding player: comes from the source 612 // this method was called with, is sent to another buffer queue. 613 SLDataLocator_AndroidSimpleBufferQueue decBuffQueue; 614 decBuffQueue.locatorType = SL_DATALOCATOR_ANDROIDSIMPLEBUFFERQUEUE; 615 decBuffQueue.numBuffers = kNumberOfBuffersInQueue; 616 // A valid value seems required here but is currently ignored. 617 SLDataFormat_PCM pcm = {SL_DATAFORMAT_PCM, 1, SL_SAMPLINGRATE_44_1, 618 SL_PCMSAMPLEFORMAT_FIXED_16, 16, 619 SL_SPEAKER_FRONT_LEFT, SL_BYTEORDER_LITTLEENDIAN}; 620 SLDataSink decDest = { &decBuffQueue, &pcm }; 621 622 // Create the decoder with the given source and sink. 623 const size_t decoderInterfaceCount = 5; 624 SLObjectItf decoder; 625 const SLInterfaceID decodePlayerInterfaces[decoderInterfaceCount] = { 626 SL_IID_ANDROIDSIMPLEBUFFERQUEUE, SL_IID_PREFETCHSTATUS, SL_IID_SEEK, 627 SL_IID_METADATAEXTRACTION, SL_IID_ANDROIDCONFIGURATION }; 628 const SLboolean decodePlayerRequired[decoderInterfaceCount] = { 629 SL_BOOLEAN_TRUE, SL_BOOLEAN_TRUE, SL_BOOLEAN_TRUE, SL_BOOLEAN_TRUE, SL_BOOLEAN_TRUE }; 630 SLDataSource sourceCopy(audioSrc); 631 OpenSL(engineInterface, CreateAudioPlayer, &decoder, &sourceCopy, &decDest, 632 decoderInterfaceCount, decodePlayerInterfaces, decodePlayerRequired); 633 // Not sure if this is necessary, but just in case. 634 setAudioStreamType(decoder, audioStreamType_); 635 OpenSL(decoder, Realize, SL_BOOLEAN_FALSE); 636 637 // Get the play interface from the decoder, and register event callbacks. 638 // Get the buffer queue, prefetch and seek interfaces. 639 SLPlayItf decoderPlay = NULL; 640 SLAndroidSimpleBufferQueueItf decoderQueue = NULL; 641 SLPrefetchStatusItf decoderPrefetch = NULL; 642 SLSeekItf decoderSeek = NULL; 643 SLMetadataExtractionItf decoderMetadata = NULL; 644 OpenSL(decoder, GetInterface, SL_IID_PLAY, &decoderPlay); 645 OpenSL(decoderPlay, SetCallbackEventsMask, SL_PLAYEVENT_HEADATEND); 646 OpenSL(decoderPlay, RegisterCallback, DecodingEventCb, NULL); 647 OpenSL(decoder, GetInterface, SL_IID_PREFETCHSTATUS, &decoderPrefetch); 648 OpenSL(decoder, GetInterface, SL_IID_SEEK, &decoderSeek); 649 OpenSL(decoder, GetInterface, SL_IID_METADATAEXTRACTION, &decoderMetadata); 650 OpenSL(decoder, GetInterface, SL_IID_ANDROIDSIMPLEBUFFERQUEUE, 651 &decoderQueue); 652 653 // Initialize the callback structure, used during the decoding. 654 CallbackContext callbackContext; 655 { 656 android::Mutex::Autolock autoLock(callbackLock_); 657 callbackContext.pDataBase = pcmData; 658 callbackContext.pData = pcmData; 659 callbackContext.decoderMetadata = decoderMetadata; 660 callbackContext.playItf = decoderPlay; 661 RegisterCallbackContextAndAddEnqueueBuffersToDecoder( 662 decoderQueue, &callbackContext); 663 } 664 665 // Initialize the callback for prefetch errors, if we can't open the 666 // resource to decode. 667 OpenSL(decoderPrefetch, SetCallbackEventsMask, kPrefetchErrorCandidate); 668 OpenSL(decoderPrefetch, RegisterCallback, PrefetchEventCb, &decoderPrefetch); 669 670 // Seek to the start position. 671 OpenSL(decoderSeek, SetPosition, startPositionMillis_, SL_SEEKMODE_ACCURATE); 672 673 // Start decoding immediately. 674 OpenSL(decoderPlay, SetPlayState, SL_PLAYSTATE_PLAYING); 675 676 // These variables hold the audio player and its output. 677 // They will only be constructed once the decoder has invoked the callback, 678 // and given us the correct sample rate, number of channels and duration. 679 SLObjectItf outputMix = NULL; 680 SLObjectItf audioPlayer = NULL; 681 SLPlayItf audioPlayerPlay = NULL; 682 SLAndroidSimpleBufferQueueItf audioPlayerQueue = NULL; 683 684 // The main loop - until we're told to stop: if there is audio data coming 685 // out of the decoder, feed it through the time scaler. 686 // As it comes out of the time scaler, feed it into the audio player. 687 while (!Finished()) { 688 if (GetWasStartRequested() && HasSampleRateAndChannels()) { 689 // Build the audio player. 690 // TODO: What happens if I maliciously call start lots of times? 691 floatBuffer_ = new float[targetFrames_ * mChannels]; 692 injectBuffer_ = new float[targetFrames_ * mChannels]; 693 OpenSL(engineInterface, CreateOutputMix, &outputMix, 0, NULL, NULL); 694 OpenSL(outputMix, Realize, SL_BOOLEAN_FALSE); 695 CreateAndRealizeAudioPlayer(GetSLSampleRate(), GetChannelCount(), 696 GetSLChannels(), audioStreamType_, outputMix, audioPlayer, 697 engineInterface); 698 OpenSL(audioPlayer, GetInterface, SL_IID_PLAY, &audioPlayerPlay); 699 OpenSL(audioPlayer, GetInterface, SL_IID_ANDROIDSIMPLEBUFFERQUEUE, 700 &audioPlayerQueue); 701 OpenSL(audioPlayerQueue, RegisterCallback, PlayingBufferQueueCb, NULL); 702 ClearRequestStart(); 703 OpenSL(audioPlayerPlay, SetPlayState, SL_PLAYSTATE_PLAYING); 704 } 705 EnqueueMoreAudioIfNecessary(audioPlayerQueue); 706 usleep(kSleepTimeMicros); 707 } 708 709 // Delete the audio player and output mix, iff they have been created. 710 if (audioPlayer != NULL) { 711 OpenSL(audioPlayerPlay, SetPlayState, SL_PLAYSTATE_STOPPED); 712 OpenSL0(audioPlayerQueue, Clear); 713 OpenSL(audioPlayerQueue, RegisterCallback, NULL, NULL); 714 VoidOpenSL(audioPlayer, AbortAsyncOperation); 715 VoidOpenSL(audioPlayer, Destroy); 716 VoidOpenSL(outputMix, Destroy); 717 audioPlayer = NULL; 718 audioPlayerPlay = NULL; 719 audioPlayerQueue = NULL; 720 outputMix = NULL; 721 } 722 723 // Delete the decoder. 724 OpenSL(decoderPlay, SetPlayState, SL_PLAYSTATE_STOPPED); 725 OpenSL(decoderPrefetch, RegisterCallback, NULL, NULL); 726 // This is returning slresult 13 if I do no playback. 727 // Repro is to comment out all before this line, and all after enqueueing 728 // my buffers. 729 // OpenSL0(decoderQueue, Clear); 730 OpenSL(decoderQueue, RegisterCallback, NULL, NULL); 731 decoderSeek = NULL; 732 decoderPrefetch = NULL; 733 decoderQueue = NULL; 734 OpenSL(decoderPlay, RegisterCallback, NULL, NULL); 735 VoidOpenSL(decoder, AbortAsyncOperation); 736 VoidOpenSL(decoder, Destroy); 737 decoderPlay = NULL; 738 739 // Delete the engine. 740 VoidOpenSL(engine, Destroy); 741 engineInterface = NULL; 742 743 return true; 744 } 745 746 bool AudioEngine::Finished() { 747 if (GetWasStopRequested()) { 748 return true; 749 } 750 android::Mutex::Autolock autoLock(playBufferLock_); 751 return playingBuffers_.size() <= 0 && 752 IsDecodeBufferEmpty() && 753 GetEndOfDecoderReached(); 754 } 755 756 bool AudioEngine::GetWasStopRequested() { 757 android::Mutex::Autolock autoLock(lock_); 758 return stopRequested_; 759 } 760 761 bool AudioEngine::GetHasReachedPlayingBuffersLimit() { 762 android::Mutex::Autolock autoLock(playBufferLock_); 763 return playingBuffers_.size() >= maxPlayBufferCount_; 764 } 765 766 void AudioEngine::EnqueueMoreAudioIfNecessary( 767 SLAndroidSimpleBufferQueueItf audioPlayerQueue) { 768 bool keepEnqueueing = true; 769 while (audioPlayerQueue != NULL && 770 !GetWasStopRequested() && 771 !IsDecodeBufferEmpty() && 772 !GetHasReachedPlayingBuffersLimit() && 773 keepEnqueueing) { 774 keepEnqueueing = EnqueueNextBufferOfAudio(audioPlayerQueue); 775 } 776 } 777 778 bool AudioEngine::DecodeBufferTooFull() { 779 android::Mutex::Autolock autoLock(decodeBufferLock_); 780 return decodeBuffer_.IsTooLarge(); 781 } 782 783 // **************************************************************************** 784 // Code for handling the static callbacks. 785 786 void AudioEngine::PlayingBufferQueueCallback() { 787 // The head playing buffer is done, move it to the free list. 788 android::Mutex::Autolock autoLock(playBufferLock_); 789 if (playingBuffers_.size() > 0) { 790 freeBuffers_.push(playingBuffers_.front()); 791 playingBuffers_.pop(); 792 } 793 } 794 795 void AudioEngine::PrefetchEventCallback( 796 SLPrefetchStatusItf caller, SLuint32 event) { 797 // If there was a problem during decoding, then signal the end. 798 SLpermille level = 0; 799 SLuint32 status; 800 OpenSL(caller, GetFillLevel, &level); 801 OpenSL(caller, GetPrefetchStatus, &status); 802 if ((kPrefetchErrorCandidate == (event & kPrefetchErrorCandidate)) && 803 (level == 0) && 804 (status == SL_PREFETCHSTATUS_UNDERFLOW)) { 805 LOGI("prefetcheventcallback error while prefetching data"); 806 SetEndOfDecoderReached(); 807 } 808 if (SL_PREFETCHSTATUS_SUFFICIENTDATA == event) { 809 // android::Mutex::Autolock autoLock(prefetchLock_); 810 // prefetchCondition_.broadcast(); 811 } 812 } 813 814 void AudioEngine::DecodingBufferQueueCallback( 815 SLAndroidSimpleBufferQueueItf queueItf, void *context) { 816 if (GetWasStopRequested()) { 817 return; 818 } 819 820 CallbackContext *pCntxt; 821 { 822 android::Mutex::Autolock autoLock(callbackLock_); 823 pCntxt = reinterpret_cast<CallbackContext*>(context); 824 } 825 { 826 android::Mutex::Autolock autoLock(decodeBufferLock_); 827 decodeBuffer_.AddData(pCntxt->pData, kBufferSizeInBytes); 828 } 829 830 if (!HasSampleRateAndChannels()) { 831 android::Mutex::Autolock autoLock(callbackLock_); 832 ReadSampleRateAndChannelCount(pCntxt, &mSampleRate, &mChannels); 833 } 834 835 { 836 android::Mutex::Autolock autoLock(lock_); 837 if (totalDurationMs_ == 0) { 838 totalDurationMs_ = ReadDuration(pCntxt->playItf); 839 } 840 // TODO: This isn't working, it always reports zero. 841 // ReadPosition(pCntxt->playItf); 842 } 843 844 OpenSL(queueItf, Enqueue, pCntxt->pData, kBufferSizeInBytes); 845 846 // Increase data pointer by buffer size 847 pCntxt->pData += kBufferSizeInBytes; 848 if (pCntxt->pData >= pCntxt->pDataBase + 849 (kNumberOfBuffersInQueue * kBufferSizeInBytes)) { 850 pCntxt->pData = pCntxt->pDataBase; 851 } 852 853 // If we get too much data into the decoder, 854 // sleep until the playback catches up. 855 while (!GetWasStopRequested() && DecodeBufferTooFull()) { 856 usleep(kSleepTimeMicros); 857 } 858 } 859 860 void AudioEngine::DecodingEventCallback(SLPlayItf, SLuint32 event) { 861 if (SL_PLAYEVENT_HEADATEND & event) { 862 SetEndOfDecoderReached(); 863 } 864 } 865