Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "content/renderer/pepper/ppb_audio_impl.h" | 5 #include "content/renderer/pepper/ppb_audio_impl.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "content/renderer/pepper/common.h" | 8 #include "content/renderer/pepper/common.h" |
| 9 #include "content/renderer/pepper/pepper_platform_audio_output.h" | 9 #include "content/renderer/pepper/pepper_platform_audio_output.h" |
| 10 #include "content/renderer/pepper/pepper_plugin_instance_impl.h" | 10 #include "content/renderer/pepper/pepper_plugin_instance_impl.h" |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 24 using ppapi::thunk::PPB_Audio_API; | 24 using ppapi::thunk::PPB_Audio_API; |
| 25 using ppapi::thunk::PPB_AudioConfig_API; | 25 using ppapi::thunk::PPB_AudioConfig_API; |
| 26 using ppapi::TrackedCallback; | 26 using ppapi::TrackedCallback; |
| 27 | 27 |
| 28 namespace content { | 28 namespace content { |
| 29 | 29 |
| 30 // PPB_Audio_Impl -------------------------------------------------------------- | 30 // PPB_Audio_Impl -------------------------------------------------------------- |
| 31 | 31 |
| 32 PPB_Audio_Impl::PPB_Audio_Impl(PP_Instance instance) | 32 PPB_Audio_Impl::PPB_Audio_Impl(PP_Instance instance) |
| 33 : Resource(::ppapi::OBJECT_IS_IMPL, instance), | 33 : Resource(::ppapi::OBJECT_IS_IMPL, instance), |
| 34 audio_(NULL), | 34 audio_(NULL) { |
| 35 sample_frame_count_(0) { | |
| 36 } | 35 } |
| 37 | 36 |
| 38 PPB_Audio_Impl::~PPB_Audio_Impl() { | 37 PPB_Audio_Impl::~PPB_Audio_Impl() { |
| 39 // Calling ShutDown() makes sure StreamCreated cannot be called anymore and | 38 // Calling ShutDown() makes sure StreamCreated cannot be called anymore and |
| 40 // releases the audio data associated with the pointer. Note however, that | 39 // releases the audio data associated with the pointer. Note however, that |
| 41 // until ShutDown returns, StreamCreated may still be called. This will be | 40 // until ShutDown returns, StreamCreated may still be called. This will be |
| 42 // OK since we'll just immediately clean up the data it stored later in this | 41 // OK since we'll just immediately clean up the data it stored later in this |
| 43 // destructor. | 42 // destructor. |
| 44 if (audio_) { | 43 if (audio_) { |
| 45 audio_->ShutDown(); | 44 audio_->ShutDown(); |
| 46 audio_ = NULL; | 45 audio_ = NULL; |
| 47 } | 46 } |
| 48 } | 47 } |
| 49 | 48 |
| 50 // static | 49 // static |
| 51 PP_Resource PPB_Audio_Impl::Create(PP_Instance instance, | 50 PP_Resource PPB_Audio_Impl::Create(PP_Instance instance, |
| 52 PP_Resource config, | 51 PP_Resource config, |
| 53 PPB_Audio_Callback audio_callback, | 52 const ppapi::AudioCallback& audio_callback, |
| 54 void* user_data) { | 53 void* user_data) { |
| 55 scoped_refptr<PPB_Audio_Impl> audio(new PPB_Audio_Impl(instance)); | 54 scoped_refptr<PPB_Audio_Impl> audio(new PPB_Audio_Impl(instance)); |
| 56 if (!audio->Init(config, audio_callback, user_data)) | 55 if (!audio->Init(config, audio_callback, user_data)) |
| 57 return 0; | 56 return 0; |
| 58 return audio->GetReference(); | 57 return audio->GetReference(); |
| 59 } | 58 } |
| 60 | 59 |
| 61 PPB_Audio_API* PPB_Audio_Impl::AsPPB_Audio_API() { | 60 PPB_Audio_API* PPB_Audio_Impl::AsPPB_Audio_API() { |
| 62 return this; | 61 return this; |
| 63 } | 62 } |
| 64 | 63 |
| 65 bool PPB_Audio_Impl::Init(PP_Resource config, | 64 bool PPB_Audio_Impl::Init(PP_Resource config, |
| 66 PPB_Audio_Callback callback, void* user_data) { | 65 const ppapi::AudioCallback& callback, |
| 66 void* user_data) { | |
| 67 // Validate the config and keep a reference to it. | 67 // Validate the config and keep a reference to it. |
| 68 EnterResourceNoLock<PPB_AudioConfig_API> enter(config, true); | 68 EnterResourceNoLock<PPB_AudioConfig_API> enter(config, true); |
| 69 if (enter.failed()) | 69 if (enter.failed()) |
| 70 return false; | 70 return false; |
| 71 config_ = config; | 71 config_ = config; |
| 72 | 72 |
| 73 if (!callback) | 73 if (!callback.IsValid()) |
| 74 return false; | 74 return false; |
| 75 SetCallback(callback, user_data); | 75 SetCallback(callback, user_data); |
| 76 | 76 |
| 77 PepperPluginInstanceImpl* instance = ResourceHelper::GetPluginInstance(this); | 77 PepperPluginInstanceImpl* instance = ResourceHelper::GetPluginInstance(this); |
| 78 if (!instance) | 78 if (!instance) |
| 79 return false; | 79 return false; |
| 80 | 80 |
| 81 // When the stream is created, we'll get called back on StreamCreated(). | 81 // When the stream is created, we'll get called back on StreamCreated(). |
| 82 CHECK(!audio_); | 82 CHECK(!audio_); |
| 83 audio_ = PepperPlatformAudioOutput::Create( | 83 audio_ = PepperPlatformAudioOutput::Create( |
| 84 static_cast<int>(enter.object()->GetSampleRate()), | 84 static_cast<int>(enter.object()->GetSampleRate()), |
| 85 static_cast<int>(enter.object()->GetSampleFrameCount()), | 85 static_cast<int>(enter.object()->GetSampleFrameCount()), |
| 86 instance->GetRenderView()->GetRoutingID(), | 86 instance->GetRenderView()->GetRoutingID(), |
| 87 this); | 87 this); |
| 88 sample_frame_count_ = enter.object()->GetSampleFrameCount(); | |
| 89 return audio_ != NULL; | 88 return audio_ != NULL; |
| 90 } | 89 } |
| 91 | 90 |
| 92 PP_Resource PPB_Audio_Impl::GetCurrentConfig() { | 91 PP_Resource PPB_Audio_Impl::GetCurrentConfig() { |
| 93 // AddRef on behalf of caller, while keeping a ref for ourselves. | 92 // AddRef on behalf of caller, while keeping a ref for ourselves. |
| 94 PpapiGlobals::Get()->GetResourceTracker()->AddRefResource(config_); | 93 PpapiGlobals::Get()->GetResourceTracker()->AddRefResource(config_); |
| 95 return config_; | 94 return config_; |
| 96 } | 95 } |
| 97 | 96 |
| 98 PP_Bool PPB_Audio_Impl::StartPlayback() { | 97 PP_Bool PPB_Audio_Impl::StartPlayback() { |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 152 | 151 |
| 153 int32_t PPB_Audio_Impl::GetSharedMemory(int* shm_handle, | 152 int32_t PPB_Audio_Impl::GetSharedMemory(int* shm_handle, |
| 154 uint32_t* shm_size) { | 153 uint32_t* shm_size) { |
| 155 return GetSharedMemoryImpl(shm_handle, shm_size); | 154 return GetSharedMemoryImpl(shm_handle, shm_size); |
| 156 } | 155 } |
| 157 | 156 |
| 158 void PPB_Audio_Impl::OnSetStreamInfo( | 157 void PPB_Audio_Impl::OnSetStreamInfo( |
| 159 base::SharedMemoryHandle shared_memory_handle, | 158 base::SharedMemoryHandle shared_memory_handle, |
| 160 size_t shared_memory_size, | 159 size_t shared_memory_size, |
| 161 base::SyncSocket::Handle socket_handle) { | 160 base::SyncSocket::Handle socket_handle) { |
| 161 EnterResourceNoLock<PPB_AudioConfig_API> enter(config_, true); | |
|
dmichael (off chromium)
2013/08/06 19:43:25
I think this could fail if the plugin releases con
yzshen1
2013/08/07 20:51:06
This class also holds a ref to config_, so it shou
dmichael (off chromium)
2013/08/07 21:11:38
Thanks, I missed that it's a ScopedPPResource inst
| |
| 162 SetStreamInfo(pp_instance(), shared_memory_handle, shared_memory_size, | 162 SetStreamInfo(pp_instance(), shared_memory_handle, shared_memory_size, |
| 163 socket_handle, sample_frame_count_); | 163 socket_handle, enter.object()->GetSampleRate(), |
| 164 enter.object()->GetSampleFrameCount()); | |
| 164 } | 165 } |
| 165 | 166 |
| 166 } // namespace content | 167 } // namespace content |
| OLD | NEW |