Index: ppapi/shared_impl/ppb_audio_config_shared.cc |
=================================================================== |
--- ppapi/shared_impl/ppb_audio_config_shared.cc (revision 122585) |
+++ ppapi/shared_impl/ppb_audio_config_shared.cc (working copy) |
@@ -3,6 +3,7 @@ |
// found in the LICENSE file. |
#include "ppapi/shared_impl/ppb_audio_config_shared.h" |
+#include "ppapi/thunk/enter.h" |
namespace ppapi { |
@@ -28,6 +29,76 @@ |
return object->GetReference(); |
} |
+// static |
+uint32_t PPB_AudioConfig_Shared::RecommendSampleFrameCount_1_0( |
+ PP_AudioSampleRate sample_rate, |
+ uint32_t requested_sample_frame_count) { |
+ // Version 1.0: Don't actually query to get a value from the |
+ // hardware; instead return the input for in-range values. |
+ if (requested_sample_frame_count < PP_AUDIOMINSAMPLEFRAMECOUNT) |
+ return PP_AUDIOMINSAMPLEFRAMECOUNT; |
+ if (requested_sample_frame_count > PP_AUDIOMAXSAMPLEFRAMECOUNT) |
+ return PP_AUDIOMAXSAMPLEFRAMECOUNT; |
+ return requested_sample_frame_count; |
+} |
+ |
+// static |
+uint32_t PPB_AudioConfig_Shared::RecommendSampleFrameCount_1_1( |
+ PP_Instance instance, |
+ PP_AudioSampleRate sample_rate, |
+ uint32_t sample_frame_count) { |
+ // Version 1.1: Query the back-end hardware for sample rate and buffer size, |
+ // and recommend a best fit based on request. |
+ thunk::EnterInstance enter(instance); |
+ if (enter.failed()) |
+ return 0; |
+ |
+ // Get the hardware config. |
+ PP_AudioSampleRate hardware_sample_rate = static_cast<PP_AudioSampleRate>( |
+ enter.functions()->GetAudioHardwareOutputSampleRate(instance)); |
+ uint32_t hardware_sample_frame_count = |
+ enter.functions()->GetAudioHardwareOutputBufferSize(instance); |
+ if (sample_frame_count < PP_AUDIOMINSAMPLEFRAMECOUNT) |
+ sample_frame_count = PP_AUDIOMINSAMPLEFRAMECOUNT; |
+ |
+ // If client is using same sample rate as audio hardware, then recommend a |
+ // multiple of the audio hardware's sample frame count. |
+ if (hardware_sample_rate == sample_rate && hardware_sample_frame_count > 0) { |
+ // Round up input sample_frame_count to nearest multiple. |
+ uint32_t multiple = (sample_frame_count + hardware_sample_frame_count - 1) / |
+ hardware_sample_frame_count; |
+ uint32_t recommendation = hardware_sample_frame_count * multiple; |
+ if (recommendation > PP_AUDIOMAXSAMPLEFRAMECOUNT) |
+ recommendation = PP_AUDIOMAXSAMPLEFRAMECOUNT; |
+ return recommendation; |
+ } |
+ |
+ // Otherwise, recommend a conservative 30ms buffer based on sample rate. |
+ const uint32_t kDefault30msAt44100kHz = 1323; |
+ const uint32_t kDefault30msAt48000kHz = 1440; |
+ switch (sample_rate) { |
+ case PP_AUDIOSAMPLERATE_44100: |
+ return kDefault30msAt44100kHz; |
+ case PP_AUDIOSAMPLERATE_48000: |
+ return kDefault30msAt48000kHz; |
+ case PP_AUDIOSAMPLERATE_NONE: |
+ return 0; |
+ } |
+ // Unable to make a recommendation. |
+ return 0; |
+} |
+ |
+// static |
+PP_AudioSampleRate PPB_AudioConfig_Shared::RecommendSampleRate( |
+ PP_Instance instance) { |
+ thunk::EnterInstance enter(instance); |
+ if (enter.failed()) |
+ return PP_AUDIOSAMPLERATE_NONE; |
+ PP_AudioSampleRate hardware_sample_rate = static_cast<PP_AudioSampleRate>( |
+ enter.functions()->GetAudioHardwareOutputSampleRate(instance)); |
+ return hardware_sample_rate; |
+} |
+ |
thunk::PPB_AudioConfig_API* PPB_AudioConfig_Shared::AsPPB_AudioConfig_API() { |
return this; |
} |