// 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(IsAlignedForChannelMessage(sizeof(BrokerMessageHeader)), "Invalid header size."); struct BufferRequestData { uint32_t size; }; #if defined(OS_WIN) struct InitData { // NOTE: InitData in the payload is followed by string16 data with exactly // |pipe_name_length| wide characters (i.e., |pipe_name_length|*2 bytes.) // This applies to Windows only. uint32_t pipe_name_length; }; #endif #pragma pack(pop) template <typename T> inline Channel::MessagePtr CreateBrokerMessage( BrokerMessageType type, size_t num_handles, size_t extra_data_size, T** out_message_data, void** out_extra_data = nullptr) { const size_t message_size = sizeof(BrokerMessageHeader) + sizeof(**out_message_data) + extra_data_size; 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); if (out_extra_data) *out_extra_data = *out_message_data + 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_