blob: a01c8028174c470461caee2020faeca3fed86da2 [file] [log] [blame]
// Copyright 2017 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 IPC_HANDLE_ATTACHMENT_FUCHSIA_H_
#define IPC_HANDLE_ATTACHMENT_FUCHSIA_H_
#include <stdint.h>
#include "base/process/process_handle.h"
#include "ipc/handle_fuchsia.h"
#include "ipc/ipc_export.h"
#include "ipc/ipc_message_attachment.h"
namespace IPC {
namespace internal {
// This class represents a Fuchsia mx_handle_t attached to a Chrome IPC message.
class IPC_EXPORT HandleAttachmentFuchsia : public MessageAttachment {
public:
// This constructor makes a copy of |handle| and takes ownership of the
// result. Should only be called by the sender of a Chrome IPC message.
HandleAttachmentFuchsia(const mx_handle_t& handle,
HandleFuchsia::Permissions permissions);
enum FromWire {
FROM_WIRE,
};
// This constructor takes ownership of |handle|. Should only be called by the
// receiver of a Chrome IPC message.
HandleAttachmentFuchsia(const mx_handle_t& handle, FromWire from_wire);
Type GetType() const override;
mx_handle_t get_handle() const { return handle_; }
// The caller of this method has taken ownership of |handle_|.
void reset_handle_ownership() {
owns_handle_ = false;
handle_ = MX_HANDLE_INVALID;
}
private:
~HandleAttachmentFuchsia() override;
mx_handle_t handle_;
HandleFuchsia::Permissions permissions_;
// In the sender process, the attachment owns the mx_handle_t of a newly
// created message. The attachment broker will eventually take ownership, and
// set this member to |false|. In the destination process, the attachment owns
// the handle until a call to ParamTraits<HandleFuchsia>::Read() takes
// ownership.
bool owns_handle_;
};
} // namespace internal
} // namespace IPC
#endif // IPC_HANDLE_ATTACHMENT_FUCHSIA_H_