// 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_EDK_SYSTEM_BROKER_MESSAGES_H_ #define MOJO_EDK_SYSTEM_BROKER_MESSAGES_H_ #include "mojo/edk/system/channel.h" namespace mojo { namespace edk { #pragma pack(push, 1) enum BrokerMessageType : uint32_t { INIT, BUFFER_REQUEST, BUFFER_RESPONSE, }; struct BrokerMessageHeader { BrokerMessageType type; uint32_t padding; }; static_assert(sizeof(BrokerMessageHeader) % kChannelMessageAlignment == 0, "Invalid header size."); struct BufferRequestData { uint32_t size; }; #pragma pack(pop) template <typename T> inline Channel::MessagePtr CreateBrokerMessage(BrokerMessageType type, size_t num_handles, T** out_message_data) { const size_t message_size = sizeof(BrokerMessageHeader) + sizeof(T); Channel::MessagePtr message(new Channel::Message(message_size, num_handles)); BrokerMessageHeader* header = reinterpret_cast<BrokerMessageHeader*>(message->mutable_payload()); header->type = type; header->padding = 0; *out_message_data = reinterpret_cast<T*>(header + 1); return message; } inline Channel::MessagePtr CreateBrokerMessage( BrokerMessageType type, size_t num_handles, std::nullptr_t** dummy_out_data) { Channel::MessagePtr message( new Channel::Message(sizeof(BrokerMessageHeader), num_handles)); BrokerMessageHeader* header = reinterpret_cast<BrokerMessageHeader*>(message->mutable_payload()); header->type = type; header->padding = 0; return message; } } // namespace edk } // namespace mojo #endif // MOJO_EDK_SYSTEM_BROKER_MESSAGES_H_