Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(481)

Unified Diff: content/renderer/pepper/pepper_audio_input_host.cc

Issue 11366038: Rewrite PPB_AudioInput_Dev to use the new-style host/resource. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 8 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/renderer/pepper/pepper_audio_input_host.cc
diff --git a/content/renderer/pepper/pepper_audio_input_host.cc b/content/renderer/pepper/pepper_audio_input_host.cc
new file mode 100644
index 0000000000000000000000000000000000000000..7e334b459469d56dff1085da6825359c6208f247
--- /dev/null
+++ b/content/renderer/pepper/pepper_audio_input_host.cc
@@ -0,0 +1,255 @@
+// 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 "content/renderer/pepper/pepper_audio_input_host.h"
+
+#include "base/bind.h"
+#include "base/logging.h"
+#include "build/build_config.h"
+#include "content/public/renderer/renderer_ppapi_host.h"
+#include "ipc/ipc_message.h"
+#include "media/audio/shared_memory_util.h"
+#include "ppapi/c/pp_errors.h"
+#include "ppapi/host/dispatch_host_message.h"
+#include "ppapi/host/ppapi_host.h"
+#include "ppapi/proxy/ppapi_messages.h"
+#include "ppapi/proxy/serialized_structs.h"
+#include "ppapi/shared_impl/ppb_device_ref_shared.h"
+#include "webkit/plugins/ppapi/ppapi_plugin_instance.h"
+
+namespace content {
+
+namespace {
+
+base::PlatformFile ConvertSyncSocketHandle(const base::SyncSocket& socket) {
+ return socket.handle();
+}
+
+base::PlatformFile ConvertSharedMemoryHandle(
+ const base::SharedMemory& shared_memory) {
+#if defined(OS_POSIX)
+ return shared_memory.handle().fd;
+#elif defined(OS_WIN)
+ return shared_memory.handle();
+#else
+#error "Platform not supported."
+#endif
+}
+
+} // namespace
+
+PepperAudioInputHost::PepperAudioInputHost(
+ RendererPpapiHost* host,
+ PP_Instance instance,
+ PP_Resource resource)
+ : ResourceHost(host->GetPpapiHost(), instance, resource),
+ renderer_ppapi_host_(host),
+ audio_input_(NULL) {
+}
+
+PepperAudioInputHost::~PepperAudioInputHost() {
+ Close();
+}
+
+int32_t PepperAudioInputHost::OnResourceMessageReceived(
+ const IPC::Message& msg,
+ ppapi::host::HostMessageContext* context) {
+ IPC_BEGIN_MESSAGE_MAP(PepperAudioInputHost, msg)
+ PPAPI_DISPATCH_HOST_RESOURCE_CALL_0(
+ PpapiHostMsg_AudioInput_EnumerateDevices, OnMsgEnumerateDevices)
+ PPAPI_DISPATCH_HOST_RESOURCE_CALL(PpapiHostMsg_AudioInput_Open, OnMsgOpen)
+ PPAPI_DISPATCH_HOST_RESOURCE_CALL(PpapiHostMsg_AudioInput_StartOrStop,
+ OnMsgStartOrStop);
+ PPAPI_DISPATCH_HOST_RESOURCE_CALL_0(PpapiHostMsg_AudioInput_Close,
+ OnMsgClose);
+ IPC_END_MESSAGE_MAP()
+ return PP_ERROR_FAILED;
+}
+
+void PepperAudioInputHost::StreamCreated(
+ base::SharedMemoryHandle shared_memory_handle,
+ size_t shared_memory_size,
+ base::SyncSocket::Handle socket) {
+ OnOpenComplete(PP_OK, shared_memory_handle, shared_memory_size, socket);
+}
+
+void PepperAudioInputHost::StreamCreationFailed() {
+ OnOpenComplete(PP_ERROR_FAILED, base::SharedMemory::NULLHandle(), 0,
+ base::SyncSocket::kInvalidHandle);
+}
+
+int32_t PepperAudioInputHost::OnMsgEnumerateDevices(
+ ppapi::host::HostMessageContext* context) {
+ if (enumerate_devices_context_.get())
+ return PP_ERROR_INPROGRESS;
+
+ webkit::ppapi::PluginDelegate* plugin_delegate = GetDelegate();
+ if (!plugin_delegate)
+ return PP_ERROR_FAILED;
+
+ enumerate_devices_context_.reset(
+ new ppapi::host::ReplyMessageContext(context->MakeReplyMessageContext()));
+ // Note that the callback may be called synchronously.
+ plugin_delegate->EnumerateDevices(
+ PP_DEVICETYPE_DEV_AUDIOCAPTURE,
+ base::Bind(&PepperAudioInputHost::EnumerateDevicesCallbackFunc,
+ AsWeakPtr()));
+ return PP_OK_COMPLETIONPENDING;
+}
+
+int32_t PepperAudioInputHost::OnMsgOpen(
+ ppapi::host::HostMessageContext* context,
+ const std::string& device_id,
+ PP_AudioSampleRate sample_rate,
+ uint32_t sample_frame_count) {
+ if (open_context_.get())
+ return PP_ERROR_INPROGRESS;
+ if (audio_input_)
+ return PP_ERROR_FAILED;
+
+ webkit::ppapi::PluginDelegate* plugin_delegate = GetDelegate();
+ if (!plugin_delegate)
+ return PP_ERROR_FAILED;
+
+ // When it is done, we'll get called back on StreamCreated() or
+ // StreamCreationFailed().
+ audio_input_ = plugin_delegate->CreateAudioInput(
+ device_id, sample_rate, sample_frame_count, this);
+ if (audio_input_) {
+ open_context_.reset(new ppapi::host::ReplyMessageContext(
+ context->MakeReplyMessageContext()));
+ return PP_OK_COMPLETIONPENDING;
+ } else {
+ return PP_ERROR_FAILED;
+ }
+}
+
+int32_t PepperAudioInputHost::OnMsgStartOrStop(
+ ppapi::host::HostMessageContext* /* context */,
+ bool capture) {
+ if (!audio_input_)
+ return PP_ERROR_FAILED;
+ if (capture)
+ audio_input_->StartCapture();
+ else
+ audio_input_->StopCapture();
+ return PP_OK;
+}
+
+int32_t PepperAudioInputHost::OnMsgClose(
+ ppapi::host::HostMessageContext* /* context */) {
+ Close();
+ return PP_OK;
+}
+
+void PepperAudioInputHost::EnumerateDevicesCallbackFunc(
+ int request_id,
+ bool succeeded,
+ const std::vector<ppapi::DeviceRefData>& devices) {
+ DCHECK(enumerate_devices_context_.get());
+
+ webkit::ppapi::PluginDelegate* plugin_delegate = GetDelegate();
+ if (plugin_delegate)
+ plugin_delegate->StopEnumerateDevices(request_id);
+
+ enumerate_devices_context_->params.set_result(
+ succeeded ? PP_OK : PP_ERROR_FAILED);
+ host()->SendReply(
+ *enumerate_devices_context_,
+ PpapiPluginMsg_AudioInput_EnumerateDevicesReply(
+ succeeded ? devices : std::vector<ppapi::DeviceRefData>()));
+ enumerate_devices_context_.reset();
+}
+
+void PepperAudioInputHost::OnOpenComplete(
+ int32_t result,
+ base::SharedMemoryHandle shared_memory_handle,
+ size_t shared_memory_size,
+ base::SyncSocket::Handle socket_handle) {
+ // Make sure the handles are cleaned up.
+ base::SyncSocket scoped_socket(socket_handle);
+ base::SharedMemory scoped_shared_memory(shared_memory_handle, false);
+
+ if (!open_context_.get()) {
+ NOTREACHED();
+ return;
+ }
+
+ ppapi::proxy::SerializedHandle serialized_socket_handle(
+ ppapi::proxy::SerializedHandle::SOCKET);
+ ppapi::proxy::SerializedHandle serialized_shared_memory_handle(
+ ppapi::proxy::SerializedHandle::SHARED_MEMORY);
+
+ if (result == PP_OK) {
+ IPC::PlatformFileForTransit temp_socket =
+ IPC::InvalidPlatformFileForTransit();
+ base::SharedMemoryHandle temp_shmem = base::SharedMemory::NULLHandle();
+ result = GetRemoteHandles(
+ scoped_socket, scoped_shared_memory, &temp_socket, &temp_shmem);
+
+ serialized_socket_handle.set_socket(temp_socket);
+ // Note that we must call TotalSharedMemorySizeInBytes() because extra space
+ // in shared memory is allocated for book-keeping, so the actual size of the
+ // shared memory buffer is larger than |shared_memory_size|. When sending to
+ // NaCl, NaClIPCAdapter expects this size to match the size of the full
+ // shared memory buffer.
+ serialized_shared_memory_handle.set_shmem(
+ temp_shmem, media::TotalSharedMemorySizeInBytes(shared_memory_size));
+ }
+
+ // Send all the values, even on error. This simplifies some of our cleanup
+ // code since the handles will be in the other process and could be
+ // inconvenient to clean up. Our IPC code will automatically handle this for
+ // us, as long as the remote side always closes the handles it receives, even
+ // in the failure case.
+ open_context_->params.set_result(result);
+ open_context_->params.AppendHandle(serialized_socket_handle);
+ open_context_->params.AppendHandle(serialized_shared_memory_handle);
+
+ host()->SendReply(*open_context_, PpapiPluginMsg_AudioInput_OpenReply());
+ open_context_.reset();
+}
+
+int32_t PepperAudioInputHost::GetRemoteHandles(
+ const base::SyncSocket& socket,
+ const base::SharedMemory& shared_memory,
+ IPC::PlatformFileForTransit* remote_socket_handle,
+ base::SharedMemoryHandle* remote_shared_memory_handle) {
+ *remote_socket_handle = renderer_ppapi_host_->ShareHandleWithRemote(
+ ConvertSyncSocketHandle(socket), false);
+ if (*remote_socket_handle == IPC::InvalidPlatformFileForTransit())
+ return PP_ERROR_FAILED;
+
+ *remote_shared_memory_handle = renderer_ppapi_host_->ShareHandleWithRemote(
+ ConvertSharedMemoryHandle(shared_memory), false);
+ if (*remote_shared_memory_handle == IPC::InvalidPlatformFileForTransit())
+ return PP_ERROR_FAILED;
+
+ return PP_OK;
+}
+
+void PepperAudioInputHost::Close() {
+ if (!audio_input_)
+ return;
+
+ audio_input_->ShutDown();
+ audio_input_ = NULL;
+
+ if (open_context_.get()) {
+ open_context_->params.set_result(PP_ERROR_ABORTED);
+ host()->SendReply(*open_context_, PpapiPluginMsg_AudioInput_OpenReply());
+ open_context_.reset();
+ }
+}
+
+webkit::ppapi::PluginDelegate* PepperAudioInputHost::GetDelegate() const {
+ webkit::ppapi::PluginInstance* instance =
+ renderer_ppapi_host_->GetPluginInstance(pp_instance());
+ if (instance)
+ return instance->delegate();
+ return NULL;
+}
+
+} // namespace content
+
« no previous file with comments | « content/renderer/pepper/pepper_audio_input_host.h ('k') | content/renderer/pepper/renderer_ppapi_host_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698