| Index: ppapi/proxy/ppb_image_data_proxy.cc
|
| diff --git a/ppapi/proxy/ppb_image_data_proxy.cc b/ppapi/proxy/ppb_image_data_proxy.cc
|
| index 2eecc0ffe19972c0a1d4921f2754dda2df14e40c..aec48895829872dfdade268b73292a39582ec439 100644
|
| --- a/ppapi/proxy/ppb_image_data_proxy.cc
|
| +++ b/ppapi/proxy/ppb_image_data_proxy.cc
|
| @@ -22,7 +22,7 @@
|
| #include "ppapi/thunk/enter.h"
|
| #include "ppapi/thunk/thunk.h"
|
|
|
| -#if !defined(OS_NACL)
|
| +#if !defined(OS_NACL) && !defined(NACL_WIN64)
|
| #include "skia/ext/platform_canvas.h"
|
| #include "ui/surface/transport_dib.h"
|
| #endif
|
| @@ -30,7 +30,7 @@
|
| namespace ppapi {
|
| namespace proxy {
|
|
|
| -#if !defined(OS_NACL)
|
| +#if !defined(OS_NACL) && !defined(NACL_WIN64)
|
| ImageData::ImageData(const HostResource& resource,
|
| const PP_ImageDataDesc& desc,
|
| ImageHandle handle)
|
| @@ -42,7 +42,7 @@ ImageData::ImageData(const HostResource& resource,
|
| transport_dib_.reset(TransportDIB::Map(handle));
|
| #endif // defined(OS_WIN)
|
| }
|
| -#else // !defined(OS_NACL)
|
| +#else // !defined(OS_NACL) && !defined(NACL_WIN64)
|
|
|
| ImageData::ImageData(const HostResource& resource,
|
| const PP_ImageDataDesc& desc,
|
| @@ -53,7 +53,7 @@ ImageData::ImageData(const HostResource& resource,
|
| size_(desc.size.width * desc.size.height * 4),
|
| map_count_(0) {
|
| }
|
| -#endif // !defined(OS_NACL)
|
| +#endif // else, !defined(OS_NACL) && !defined(NACL_WIN64)
|
|
|
| ImageData::~ImageData() {
|
| }
|
| @@ -68,7 +68,7 @@ PP_Bool ImageData::Describe(PP_ImageDataDesc* desc) {
|
| }
|
|
|
| void* ImageData::Map() {
|
| -#if defined(OS_NACL)
|
| +#if defined(OS_NACL) || defined(NACL_WIN64)
|
| if (map_count_++ == 0)
|
| shm_.Map(size_);
|
| return shm_.memory();
|
| @@ -88,7 +88,7 @@ void* ImageData::Map() {
|
| }
|
|
|
| void ImageData::Unmap() {
|
| -#if defined(OS_NACL)
|
| +#if defined(OS_NACL) || defined(NACL_WIN64)
|
| if (--map_count_ == 0)
|
| shm_.Unmap();
|
| #else
|
| @@ -106,7 +106,7 @@ int32_t ImageData::GetSharedMemory(int* /* handle */,
|
| }
|
|
|
| skia::PlatformCanvas* ImageData::GetPlatformCanvas() {
|
| -#if defined(OS_NACL)
|
| +#if defined(OS_NACL) || defined(NACL_WIN64)
|
| return NULL; // No canvas in NaCl.
|
| #else
|
| return mapped_canvas_.get();
|
| @@ -114,14 +114,14 @@ skia::PlatformCanvas* ImageData::GetPlatformCanvas() {
|
| }
|
|
|
| SkCanvas* ImageData::GetCanvas() {
|
| -#if defined(OS_NACL)
|
| +#if defined(OS_NACL) || defined(NACL_WIN64)
|
| return NULL; // No canvas in NaCl.
|
| #else
|
| return mapped_canvas_.get();
|
| #endif
|
| }
|
|
|
| -#if !defined(OS_NACL)
|
| +#if !defined(OS_NACL) && !defined(NACL_WIN64)
|
| // static
|
| ImageHandle ImageData::NullHandle() {
|
| #if defined(OS_WIN)
|
| @@ -142,7 +142,7 @@ ImageHandle ImageData::HandleFromInt(int32_t i) {
|
| return static_cast<ImageHandle>(i);
|
| #endif
|
| }
|
| -#endif // !defined(OS_NACL)
|
| +#endif // !defined(OS_NACL) || !defined(NACL_WIN64)
|
|
|
| PPB_ImageData_Proxy::PPB_ImageData_Proxy(Dispatcher* dispatcher)
|
| : InterfaceProxy(dispatcher) {
|
| @@ -162,11 +162,14 @@ PP_Resource PPB_ImageData_Proxy::CreateProxyResource(PP_Instance instance,
|
|
|
| HostResource result;
|
| std::string image_data_desc;
|
| -#if defined(OS_NACL)
|
| - base::SharedMemoryHandle image_handle = base::SharedMemory::NULLHandle();
|
| +#if defined(OS_NACL) || defined(NACL_WIN64)
|
| + ppapi::proxy::SerializedHandle image_handle_wrapper;
|
| dispatcher->Send(new PpapiHostMsg_PPBImageData_CreateNaCl(
|
| kApiID, instance, format, size, init_to_zero,
|
| - &result, &image_data_desc, &image_handle));
|
| + &result, &image_data_desc, &image_handle_wrapper));
|
| + if (!image_handle_wrapper.is_shmem())
|
| + return 0;
|
| + base::SharedMemoryHandle image_handle = image_handle_wrapper.shmem();
|
| #else
|
| ImageHandle image_handle = ImageData::NullHandle();
|
| dispatcher->Send(new PpapiHostMsg_PPBImageData_Create(
|
| @@ -202,7 +205,7 @@ void PPB_ImageData_Proxy::OnHostMsgCreate(PP_Instance instance,
|
| HostResource* result,
|
| std::string* image_data_desc,
|
| ImageHandle* result_image_handle) {
|
| -#if defined(OS_NACL)
|
| +#if defined(OS_NACL) || defined(NACL_WIN64)
|
| // This message should never be received in untrusted code. To minimize the
|
| // size of the IRT, we just don't handle it.
|
| return;
|
| @@ -239,7 +242,7 @@ void PPB_ImageData_Proxy::OnHostMsgCreate(PP_Instance instance,
|
| *result_image_handle = ImageData::HandleFromInt(handle);
|
| #endif // defined(OS_WIN)
|
| }
|
| -#endif // defined(OS_NACL)
|
| +#endif // defined(OS_NACL) || defined(NACL_WIN64)
|
| }
|
|
|
| void PPB_ImageData_Proxy::OnHostMsgCreateNaCl(
|
| @@ -249,13 +252,13 @@ void PPB_ImageData_Proxy::OnHostMsgCreateNaCl(
|
| PP_Bool init_to_zero,
|
| HostResource* result,
|
| std::string* image_data_desc,
|
| - base::SharedMemoryHandle* result_image_handle) {
|
| -#if defined(OS_NACL)
|
| + ppapi::proxy::SerializedHandle* result_image_handle) {
|
| +#if defined(OS_NACL) || defined(NACL_WIN64)
|
| // This message should never be received in untrusted code. To minimize the
|
| // size of the IRT, we just don't handle it.
|
| return;
|
| #else
|
| - *result_image_handle = base::SharedMemory::NULLHandle();
|
| + result_image_handle->set_null_shmem();
|
| HostDispatcher* dispatcher = HostDispatcher::GetForInstance(instance);
|
| if (!dispatcher)
|
| return;
|
| @@ -284,7 +287,6 @@ void PPB_ImageData_Proxy::OnHostMsgCreateNaCl(
|
| uint32_t byte_count;
|
| if (enter_resource.object()->GetSharedMemory(&local_fd, &byte_count) != PP_OK)
|
| return;
|
| -
|
| // TODO(dmichael): Change trusted interface to return a PP_FileHandle, those
|
| // casts are ugly.
|
| base::PlatformFile platform_file =
|
| @@ -295,9 +297,10 @@ void PPB_ImageData_Proxy::OnHostMsgCreateNaCl(
|
| #else
|
| #error Not implemented.
|
| #endif // defined(OS_WIN)
|
| - *result_image_handle =
|
| - dispatcher->ShareHandleWithRemote(platform_file, false);
|
| -#endif // defined(OS_NACL)
|
| + result_image_handle->set_shmem(
|
| + dispatcher->ShareHandleWithRemote(platform_file, false),
|
| + byte_count);
|
| +#endif // defined(OS_NACL) || defined(NACL_WIN64)
|
| }
|
|
|
| } // namespace proxy
|
|
|