Chromium Code Reviews| Index: ppapi/shared_impl/ppb_audio_config_shared.cc |
| =================================================================== |
| --- ppapi/shared_impl/ppb_audio_config_shared.cc (revision 120806) |
| +++ ppapi/shared_impl/ppb_audio_config_shared.cc (working copy) |
| @@ -1,8 +1,9 @@ |
| -// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| #include "ppapi/shared_impl/ppb_audio_config_shared.h" |
| +#include "ppapi/thunk/enter.h" |
| namespace ppapi { |
| @@ -46,6 +47,74 @@ |
| 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. |
|
brettw
2012/02/14 18:50:18
Can you put a blank line before this?
nfullagar
2012/02/14 23:21:22
Done.
|
| + PP_AudioSampleRate hardware_sample_rate = static_cast<PP_AudioSampleRate>( |
| + enter.functions()->GetAudioHardwareOutputSampleRate(instance)); |
|
dmichael (off chromium)
2012/02/14 17:19:24
nit: 4-space indent
nfullagar
2012/02/14 23:21:22
Done.
|
| + uint32_t hardware_sample_frame_count = |
| + enter.functions()->GetAudioHardwareOutputBufferSize(instance); |
|
dmichael (off chromium)
2012/02/14 17:19:24
nit: 4-space indent
nfullagar
2012/02/14 23:21:22
Done.
|
| + // Clamp the input. |
|
brettw
2012/02/14 18:50:18
This comment is probably not necessary
nfullagar
2012/02/14 23:21:22
Done.
|
| + if (sample_frame_count < PP_AUDIOMINSAMPLEFRAMECOUNT) |
| + sample_frame_count = PP_AUDIOMINSAMPLEFRAMECOUNT; |
| + // If client is using same sample rate as audio hardware, then recommend a |
|
brettw
2012/02/14 18:50:18
I'd also do a blank line above this comment...
nfullagar
2012/02/14 23:21:22
Done.
|
| + // 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. |
|
brettw
2012/02/14 18:50:18
...and here as well.
nfullagar
2012/02/14 23:21:22
Done.
|
| + 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; |
| } |