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

Unified Diff: ppapi/proxy/ppb_image_data_proxy.cc

Issue 10828023: PPAPI/NaCl: Make NaClIPCAdapter transfer handles more generally (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: ready for review? Created 8 years, 4 months 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: 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

Powered by Google App Engine
This is Rietveld 408576698