| // Copyright 2016 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. |
| |
| #ifndef MOJO_CORE_BROKER_H_ |
| #define MOJO_CORE_BROKER_H_ |
| |
| #include "base/macros.h" |
| #include "base/memory/ref_counted.h" |
| #include "base/memory/writable_shared_memory_region.h" |
| #include "base/synchronization/lock.h" |
| #include "mojo/public/cpp/platform/platform_channel_endpoint.h" |
| #include "mojo/public/cpp/platform/platform_handle.h" |
| |
| namespace mojo { |
| namespace core { |
| |
| // The Broker is a channel to the broker process, which allows synchronous IPCs |
| // to fulfill shared memory allocation requests on some platforms. |
| class Broker { |
| public: |
| // Note: This is blocking, and will wait for the first message over |
| // the endpoint handle in |handle|. |
| explicit Broker(PlatformHandle handle); |
| ~Broker(); |
| |
| // Returns the platform handle that should be used to establish a NodeChannel |
| // to the process which is inviting us to join its network. This is the first |
| // handle read off the Broker channel upon construction. |
| PlatformChannelEndpoint GetInviterEndpoint(); |
| |
| // Request a shared buffer from the broker process. Blocks the current thread. |
| base::WritableSharedMemoryRegion GetWritableSharedMemoryRegion( |
| size_t num_bytes); |
| |
| private: |
| // Handle to the broker process, used for synchronous IPCs. |
| PlatformHandle sync_channel_; |
| |
| // Channel endpoint connected to the inviter process. Recieved in the first |
| // first message over |sync_channel_|. |
| PlatformChannelEndpoint inviter_endpoint_; |
| |
| // Lock to only allow one sync message at a time. This avoids having to deal |
| // with message ordering since we can only have one request at a time |
| // in-flight. |
| base::Lock lock_; |
| |
| DISALLOW_COPY_AND_ASSIGN(Broker); |
| }; |
| |
| } // namespace core |
| } // namespace mojo |
| |
| #endif // MOJO_CORE_BROKER_H_ |