// Copyright (c) 2011 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/proxy/ppb_buffer_proxy.h" #include #include "base/logging.h" #include "build/build_config.h" #include "ppapi/c/pp_completion_callback.h" #include "ppapi/c/pp_resource.h" #include "ppapi/c/dev/ppb_buffer_dev.h" #include "ppapi/proxy/plugin_dispatcher.h" #include "ppapi/proxy/plugin_resource.h" #include "ppapi/proxy/ppapi_messages.h" namespace pp { namespace proxy { class Buffer : public PluginResource { public: Buffer(const HostResource& resource, int memory_handle, uint32_t size); virtual ~Buffer(); // Resource overrides. virtual Buffer* AsBuffer() { return this; } uint32_t size() const { return size_; } void* Map(); void Unmap(); private: int memory_handle_; uint32_t size_; void* mapped_data_; DISALLOW_COPY_AND_ASSIGN(Buffer); }; Buffer::Buffer(const HostResource& resource, int memory_handle, uint32_t size) : PluginResource(resource), memory_handle_(memory_handle), size_(size), mapped_data_(NULL) { } Buffer::~Buffer() { Unmap(); } void* Buffer::Map() { // TODO(brettw) implement this. return mapped_data_; } void Buffer::Unmap() { // TODO(brettw) implement this. } namespace { PP_Resource Create(PP_Instance instance, uint32_t size) { HostResource result; int32_t shm_handle = -1; PluginDispatcher::GetForInstance(instance)->Send( new PpapiHostMsg_PPBBuffer_Create( INTERFACE_ID_PPB_BUFFER, instance, size, &result, &shm_handle)); if (result.is_null()) return 0; linked_ptr object(new Buffer(result, static_cast(shm_handle), size)); return PluginResourceTracker::GetInstance()->AddResource(object); } PP_Bool IsBuffer(PP_Resource resource) { Buffer* object = PluginResource::GetAs(resource); return BoolToPPBool(!!object); } PP_Bool Describe(PP_Resource resource, uint32_t* size_in_bytes) { Buffer* object = PluginResource::GetAs(resource); if (!object) { *size_in_bytes = 0; return PP_FALSE; } *size_in_bytes = object->size(); return PP_TRUE; } void* Map(PP_Resource resource) { Buffer* object = PluginResource::GetAs(resource); if (!object) return NULL; return object->Map(); } void Unmap(PP_Resource resource) { Buffer* object = PluginResource::GetAs(resource); if (object) object->Unmap(); } const PPB_Buffer_Dev buffer_interface = { &Create, &IsBuffer, &Describe, &Map, &Unmap, }; InterfaceProxy* CreateBufferProxy(Dispatcher* dispatcher, const void* target_interface) { return new PPB_Buffer_Proxy(dispatcher, target_interface); } } // namespace PPB_Buffer_Proxy::PPB_Buffer_Proxy(Dispatcher* dispatcher, const void* target_interface) : InterfaceProxy(dispatcher, target_interface) { } PPB_Buffer_Proxy::~PPB_Buffer_Proxy() { } // static const InterfaceProxy::Info* PPB_Buffer_Proxy::GetInfo() { static const Info info = { &buffer_interface, PPB_BUFFER_DEV_INTERFACE, INTERFACE_ID_PPB_BUFFER, false, &CreateBufferProxy, }; return &info; } bool PPB_Buffer_Proxy::OnMessageReceived(const IPC::Message& msg) { bool handled = true; IPC_BEGIN_MESSAGE_MAP(PPB_Buffer_Proxy, msg) IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBBuffer_Create, OnMsgCreate) IPC_MESSAGE_UNHANDLED(handled = false) IPC_END_MESSAGE_MAP() // TODO(brettw) handle bad messages! return handled; } void PPB_Buffer_Proxy::OnMsgCreate(PP_Instance instance, uint32_t size, HostResource* result_resource, int* result_shm_handle) { result_resource->SetHostResource( instance, ppb_buffer_target()->Create(instance, size)); // TODO(brettw) set the shm handle from a trusted interface. *result_shm_handle = 0; } } // namespace proxy } // namespace pp