Index: mojo/edk/embedder/system_impl_private_entrypoints.cc |
diff --git a/mojo/edk/embedder/system_impl_private_entrypoints.cc b/mojo/edk/embedder/system_impl_private_entrypoints.cc |
index 79cd3096dc76d40264556864e2615577e83d0d56..f35c91f06abb1ad7d0abf950136c95ecda320386 100644 |
--- a/mojo/edk/embedder/system_impl_private_entrypoints.cc |
+++ b/mojo/edk/embedder/system_impl_private_entrypoints.cc |
@@ -20,6 +20,7 @@ |
using mojo::embedder::internal::g_core; |
using mojo::system::Core; |
using mojo::system::Dispatcher; |
+using mojo::system::Handle; |
using mojo::system::MakeUserPointer; |
using mojo::util::RefPtr; |
@@ -55,23 +56,23 @@ MojoResult MojoSystemImplTransferHandle(MojoSystemImpl from_system, |
if (result_handle == nullptr) |
return MOJO_RESULT_INVALID_ARGUMENT; |
- RefPtr<Dispatcher> d; |
- MojoResult result = from_core->GetAndRemoveDispatcher(handle, &d); |
+ Handle h; |
+ MojoResult result = from_core->GetAndRemoveHandle(handle, &h); |
if (result != MOJO_RESULT_OK) |
return result; |
- // TODO(vtl): The rights should come from the original handle (to be dealt |
- // with when I fix/replace |Core::GetAndRemoveDispatcher()|. |
- MojoHandle created_handle = to_core->AddHandle(mojo::system::Handle( |
- d.Clone(), MOJO_HANDLE_RIGHT_TRANSFER | MOJO_HANDLE_RIGHT_READ | |
- MOJO_HANDLE_RIGHT_WRITE)); |
+ MojoHandle created_handle = |
+ to_core->AddHandle(Handle(h.dispatcher.Clone(), h.rights)); |
if (created_handle == MOJO_HANDLE_INVALID) { |
// The handle has been lost, unfortunately. There's no guarentee we can put |
// it back where it came from, or get the original ID back. Holding locks |
// for multiple cores risks deadlock, so that isn't a solution. This case |
// should not happen for reasonable uses of this API, however. |
+ // TODO(vtl): This behaviour is pretty crappy. This can be fixed by marking |
+ // the original handle as busy and only removing it on success, though |
+ // that'd require some work. |
LOG(ERROR) << "Could not transfer handle"; |
- d->Close(); |
+ h.dispatcher->Close(); |
return MOJO_RESULT_RESOURCE_EXHAUSTED; |
} |