Loading media/libaaudio/src/client/AudioStreamInternal.cpp +2 −1 Original line number Diff line number Diff line Loading @@ -27,6 +27,7 @@ #include <aaudio/AAudio.h> #include <cutils/properties.h> #include <media/AudioSystem.h> #include <media/MediaMetricsItem.h> #include <utils/Trace.h> Loading Loading @@ -95,7 +96,7 @@ aaudio_result_t AudioStreamInternal::open(const AudioStreamBuilder &builder) { return result; } const int32_t burstMinMicros = AAudioProperty_getHardwareBurstMinMicros(); const int32_t burstMinMicros = android::AudioSystem::getAAudioHardwareBurstMinUsec(); int32_t burstMicros = 0; const audio_format_t requestedFormat = getFormat(); Loading media/libaudioclient/AudioSystem.cpp +16 −0 Original line number Diff line number Diff line Loading @@ -2367,6 +2367,22 @@ status_t AudioSystem::getMmapPolicyInfo( return af->getMmapPolicyInfos(policyType, policyInfos); } int32_t AudioSystem::getAAudioMixerBurstCount() { const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger(); if (af == nullptr) { return PERMISSION_DENIED; } return af->getAAudioMixerBurstCount(); } int32_t AudioSystem::getAAudioHardwareBurstMinUsec() { const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger(); if (af == nullptr) { return PERMISSION_DENIED; } return af->getAAudioHardwareBurstMinUsec(); } // --------------------------------------------------------------------------- int AudioSystem::AudioPolicyServiceClient::addAudioPortCallback( Loading media/libaudioclient/IAudioFlinger.cpp +33 −0 Original line number Diff line number Diff line Loading @@ -788,6 +788,27 @@ status_t AudioFlingerClientAdapter::getMmapPolicyInfos( return statusTFromBinderStatus(mDelegate->getMmapPolicyInfos(policyType, policyInfos)); } int32_t AudioFlingerClientAdapter::getAAudioMixerBurstCount() { auto result = [&]() -> ConversionResult<int32_t> { int32_t aidlRet; RETURN_IF_ERROR(statusTFromBinderStatus(mDelegate->getAAudioMixerBurstCount(&aidlRet))); return convertIntegral<int32_t>(aidlRet); }(); // Failure is ignored. return result.value_or(0); } int32_t AudioFlingerClientAdapter::getAAudioHardwareBurstMinUsec() { auto result = [&]() -> ConversionResult<int32_t> { int32_t aidlRet; RETURN_IF_ERROR(statusTFromBinderStatus( mDelegate->getAAudioHardwareBurstMinUsec(&aidlRet))); return convertIntegral<int32_t>(aidlRet); }(); // Failure is ignored. return result.value_or(0); } //////////////////////////////////////////////////////////////////////////////////////////////////// // AudioFlingerServerAdapter Loading Loading @@ -1265,4 +1286,16 @@ Status AudioFlingerServerAdapter::getMmapPolicyInfos( return Status::fromStatusT(mDelegate->getMmapPolicyInfos(policyType, _aidl_return)); } Status AudioFlingerServerAdapter::getAAudioMixerBurstCount(int32_t* _aidl_return) { *_aidl_return = VALUE_OR_RETURN_BINDER( convertIntegral<int32_t>(mDelegate->getAAudioMixerBurstCount())); return Status::ok(); } Status AudioFlingerServerAdapter::getAAudioHardwareBurstMinUsec(int32_t* _aidl_return) { *_aidl_return = VALUE_OR_RETURN_BINDER( convertIntegral<int32_t>(mDelegate->getAAudioHardwareBurstMinUsec())); return Status::ok(); } } // namespace android media/libaudioclient/aidl/android/media/IAudioFlingerService.aidl +4 −0 Original line number Diff line number Diff line Loading @@ -221,4 +221,8 @@ interface IAudioFlingerService { in TrackSecondaryOutputInfo[] trackSecondaryOutputInfos); AudioMMapPolicyInfo[] getMmapPolicyInfos(AudioMMapPolicyType policyType); int getAAudioMixerBurstCount(); int getAAudioHardwareBurstMinUsec(); } media/libaudioclient/include/media/AudioSystem.h +4 −0 Original line number Diff line number Diff line Loading @@ -620,6 +620,10 @@ public: media::audio::common::AudioMMapPolicyType policyType, std::vector<media::audio::common::AudioMMapPolicyInfo> *policyInfos); static int32_t getAAudioMixerBurstCount(); static int32_t getAAudioHardwareBurstMinUsec(); private: class AudioFlingerClient: public IBinder::DeathRecipient, public media::BnAudioFlingerClient Loading Loading
media/libaaudio/src/client/AudioStreamInternal.cpp +2 −1 Original line number Diff line number Diff line Loading @@ -27,6 +27,7 @@ #include <aaudio/AAudio.h> #include <cutils/properties.h> #include <media/AudioSystem.h> #include <media/MediaMetricsItem.h> #include <utils/Trace.h> Loading Loading @@ -95,7 +96,7 @@ aaudio_result_t AudioStreamInternal::open(const AudioStreamBuilder &builder) { return result; } const int32_t burstMinMicros = AAudioProperty_getHardwareBurstMinMicros(); const int32_t burstMinMicros = android::AudioSystem::getAAudioHardwareBurstMinUsec(); int32_t burstMicros = 0; const audio_format_t requestedFormat = getFormat(); Loading
media/libaudioclient/AudioSystem.cpp +16 −0 Original line number Diff line number Diff line Loading @@ -2367,6 +2367,22 @@ status_t AudioSystem::getMmapPolicyInfo( return af->getMmapPolicyInfos(policyType, policyInfos); } int32_t AudioSystem::getAAudioMixerBurstCount() { const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger(); if (af == nullptr) { return PERMISSION_DENIED; } return af->getAAudioMixerBurstCount(); } int32_t AudioSystem::getAAudioHardwareBurstMinUsec() { const sp<IAudioFlinger>& af = AudioSystem::get_audio_flinger(); if (af == nullptr) { return PERMISSION_DENIED; } return af->getAAudioHardwareBurstMinUsec(); } // --------------------------------------------------------------------------- int AudioSystem::AudioPolicyServiceClient::addAudioPortCallback( Loading
media/libaudioclient/IAudioFlinger.cpp +33 −0 Original line number Diff line number Diff line Loading @@ -788,6 +788,27 @@ status_t AudioFlingerClientAdapter::getMmapPolicyInfos( return statusTFromBinderStatus(mDelegate->getMmapPolicyInfos(policyType, policyInfos)); } int32_t AudioFlingerClientAdapter::getAAudioMixerBurstCount() { auto result = [&]() -> ConversionResult<int32_t> { int32_t aidlRet; RETURN_IF_ERROR(statusTFromBinderStatus(mDelegate->getAAudioMixerBurstCount(&aidlRet))); return convertIntegral<int32_t>(aidlRet); }(); // Failure is ignored. return result.value_or(0); } int32_t AudioFlingerClientAdapter::getAAudioHardwareBurstMinUsec() { auto result = [&]() -> ConversionResult<int32_t> { int32_t aidlRet; RETURN_IF_ERROR(statusTFromBinderStatus( mDelegate->getAAudioHardwareBurstMinUsec(&aidlRet))); return convertIntegral<int32_t>(aidlRet); }(); // Failure is ignored. return result.value_or(0); } //////////////////////////////////////////////////////////////////////////////////////////////////// // AudioFlingerServerAdapter Loading Loading @@ -1265,4 +1286,16 @@ Status AudioFlingerServerAdapter::getMmapPolicyInfos( return Status::fromStatusT(mDelegate->getMmapPolicyInfos(policyType, _aidl_return)); } Status AudioFlingerServerAdapter::getAAudioMixerBurstCount(int32_t* _aidl_return) { *_aidl_return = VALUE_OR_RETURN_BINDER( convertIntegral<int32_t>(mDelegate->getAAudioMixerBurstCount())); return Status::ok(); } Status AudioFlingerServerAdapter::getAAudioHardwareBurstMinUsec(int32_t* _aidl_return) { *_aidl_return = VALUE_OR_RETURN_BINDER( convertIntegral<int32_t>(mDelegate->getAAudioHardwareBurstMinUsec())); return Status::ok(); } } // namespace android
media/libaudioclient/aidl/android/media/IAudioFlingerService.aidl +4 −0 Original line number Diff line number Diff line Loading @@ -221,4 +221,8 @@ interface IAudioFlingerService { in TrackSecondaryOutputInfo[] trackSecondaryOutputInfos); AudioMMapPolicyInfo[] getMmapPolicyInfos(AudioMMapPolicyType policyType); int getAAudioMixerBurstCount(); int getAAudioHardwareBurstMinUsec(); }
media/libaudioclient/include/media/AudioSystem.h +4 −0 Original line number Diff line number Diff line Loading @@ -620,6 +620,10 @@ public: media::audio::common::AudioMMapPolicyType policyType, std::vector<media::audio::common::AudioMMapPolicyInfo> *policyInfos); static int32_t getAAudioMixerBurstCount(); static int32_t getAAudioHardwareBurstMinUsec(); private: class AudioFlingerClient: public IBinder::DeathRecipient, public media::BnAudioFlingerClient Loading