This source file includes following definitions.
- buffer_manager_
- InitBuffers
- SendEnqueueBufferMessageToPlugin
- OnResourceMessageReceived
- OnHostMsgEnqueueBuffer
- OnHostMsgClose
#include "content/renderer/pepper/pepper_media_stream_track_host_base.h"
#include "base/logging.h"
#include "content/public/renderer/render_thread.h"
#include "content/public/renderer/renderer_ppapi_host.h"
#include "ppapi/c/pp_errors.h"
#include "ppapi/host/dispatch_host_message.h"
#include "ppapi/host/host_message_context.h"
#include "ppapi/host/ppapi_host.h"
#include "ppapi/proxy/ppapi_messages.h"
#include "ppapi/shared_impl/media_stream_buffer.h"
using ppapi::host::HostMessageContext;
using ppapi::proxy::SerializedHandle;
namespace content {
PepperMediaStreamTrackHostBase::PepperMediaStreamTrackHostBase(
RendererPpapiHost* host,
PP_Instance instance,
PP_Resource resource)
: ResourceHost(host->GetPpapiHost(), instance, resource),
host_(host),
buffer_manager_(this) {
}
PepperMediaStreamTrackHostBase::~PepperMediaStreamTrackHostBase() {
}
bool PepperMediaStreamTrackHostBase::InitBuffers(int32_t number_of_buffers,
int32_t buffer_size) {
DCHECK_GT(number_of_buffers, 0);
DCHECK_GT(buffer_size,
static_cast<int32_t>(sizeof(ppapi::MediaStreamBuffer::Header)));
buffer_size = (buffer_size + 3) & ~0x3;
int32_t size = number_of_buffers * buffer_size;
content::RenderThread* render_thread = content::RenderThread::Get();
scoped_ptr<base::SharedMemory> shm(
render_thread->HostAllocateSharedMemoryBuffer(size).Pass());
if (!shm)
return false;
base::SharedMemoryHandle shm_handle = shm->handle();
if (!buffer_manager_.SetBuffers(
number_of_buffers, buffer_size, shm.Pass(), true)) {
return false;
}
base::PlatformFile platform_file =
#if defined(OS_WIN)
shm_handle;
#elif defined(OS_POSIX)
shm_handle.fd;
#else
#error Not implemented.
#endif
SerializedHandle handle(
host_->ShareHandleWithRemote(platform_file, false), size);
host()->SendUnsolicitedReplyWithHandles(pp_resource(),
PpapiPluginMsg_MediaStreamTrack_InitBuffers(number_of_buffers,
buffer_size),
std::vector<SerializedHandle>(1, handle));
return true;
}
void PepperMediaStreamTrackHostBase::SendEnqueueBufferMessageToPlugin(
int32_t index) {
DCHECK_GE(index, 0);
DCHECK_LT(index, buffer_manager_.number_of_buffers());
host()->SendUnsolicitedReply(pp_resource(),
PpapiPluginMsg_MediaStreamTrack_EnqueueBuffer(index));
}
int32_t PepperMediaStreamTrackHostBase::OnResourceMessageReceived(
const IPC::Message& msg,
HostMessageContext* context) {
IPC_BEGIN_MESSAGE_MAP(PepperMediaStreamTrackHostBase, msg)
PPAPI_DISPATCH_HOST_RESOURCE_CALL(
PpapiHostMsg_MediaStreamTrack_EnqueueBuffer, OnHostMsgEnqueueBuffer)
PPAPI_DISPATCH_HOST_RESOURCE_CALL_0(
PpapiHostMsg_MediaStreamTrack_Close, OnHostMsgClose)
IPC_END_MESSAGE_MAP()
return ppapi::host::ResourceHost::OnResourceMessageReceived(msg, context);
}
int32_t PepperMediaStreamTrackHostBase::OnHostMsgEnqueueBuffer(
HostMessageContext* context,
int32_t index) {
buffer_manager_.EnqueueBuffer(index);
return PP_OK;
}
int32_t PepperMediaStreamTrackHostBase::OnHostMsgClose(
HostMessageContext* context) {
OnClose();
return PP_OK;
}
}