Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(94)

Side by Side Diff: ipc/ipc_message_pipe_reader.h

Issue 2167973002: Revert of Support early associated interface binding on ChannelMojo (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@explicit-channel-ipc-task-runner
Patch Set: Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « ipc/ipc_channel_proxy.cc ('k') | ipc/ipc_message_pipe_reader.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef IPC_IPC_MESSAGE_PIPE_READER_H_ 5 #ifndef IPC_IPC_MESSAGE_PIPE_READER_H_
6 #define IPC_IPC_MESSAGE_PIPE_READER_H_ 6 #define IPC_IPC_MESSAGE_PIPE_READER_H_
7 7
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include <memory> 10 #include <memory>
11 #include <vector> 11 #include <vector>
12 12
13 #include "base/atomicops.h" 13 #include "base/atomicops.h"
14 #include "base/compiler_specific.h" 14 #include "base/compiler_specific.h"
15 #include "base/macros.h" 15 #include "base/macros.h"
16 #include "base/process/process_handle.h"
17 #include "base/threading/thread_checker.h" 16 #include "base/threading/thread_checker.h"
18 #include "ipc/ipc.mojom.h" 17 #include "ipc/ipc.mojom.h"
19 #include "ipc/ipc_export.h" 18 #include "ipc/ipc_export.h"
20 #include "ipc/ipc_message.h" 19 #include "ipc/ipc_message.h"
21 #include "mojo/public/cpp/bindings/associated_binding.h" 20 #include "mojo/public/cpp/bindings/associated_binding.h"
22 #include "mojo/public/cpp/bindings/scoped_interface_endpoint_handle.h" 21 #include "mojo/public/cpp/bindings/scoped_interface_endpoint_handle.h"
23 #include "mojo/public/cpp/system/core.h" 22 #include "mojo/public/cpp/system/core.h"
24 #include "mojo/public/cpp/system/message_pipe.h" 23 #include "mojo/public/cpp/system/message_pipe.h"
25 24
26 namespace IPC { 25 namespace IPC {
(...skipping 14 matching lines...) Expand all
41 // The constructor automatically start listening on the pipe. 40 // The constructor automatically start listening on the pipe.
42 // 41 //
43 // All functions must be called on the IO thread, except for Send(), which can 42 // All functions must be called on the IO thread, except for Send(), which can
44 // be called on any thread. All |Delegate| functions will be called on the IO 43 // be called on any thread. All |Delegate| functions will be called on the IO
45 // thread. 44 // thread.
46 // 45 //
47 class IPC_EXPORT MessagePipeReader : public NON_EXPORTED_BASE(mojom::Channel) { 46 class IPC_EXPORT MessagePipeReader : public NON_EXPORTED_BASE(mojom::Channel) {
48 public: 47 public:
49 class Delegate { 48 class Delegate {
50 public: 49 public:
51 virtual void OnPeerPidReceived() = 0;
52 virtual void OnMessageReceived(const Message& message) = 0; 50 virtual void OnMessageReceived(const Message& message) = 0;
53 virtual void OnPipeError() = 0; 51 virtual void OnPipeError() = 0;
54 virtual void OnAssociatedInterfaceRequest( 52 virtual void OnAssociatedInterfaceRequest(
55 const std::string& name, 53 const std::string& name,
56 mojo::ScopedInterfaceEndpointHandle handle) = 0; 54 mojo::ScopedInterfaceEndpointHandle handle) = 0;
57 }; 55 };
58 56
57 // Delay the object deletion using the current message loop.
58 // This is intended to used by MessagePipeReader owners.
59 class DelayedDeleter {
60 public:
61 typedef std::default_delete<MessagePipeReader> DefaultType;
62
63 static void DeleteNow(MessagePipeReader* ptr) { delete ptr; }
64
65 DelayedDeleter() {}
66 explicit DelayedDeleter(const DefaultType&) {}
67 DelayedDeleter& operator=(const DefaultType&) { return *this; }
68
69 void operator()(MessagePipeReader* ptr) const;
70 };
71
59 // Builds a reader that reads messages from |receive_handle| and lets 72 // Builds a reader that reads messages from |receive_handle| and lets
60 // |delegate| know. 73 // |delegate| know.
61 // 74 //
62 // |pipe| is the message pipe handle corresponding to the channel's master 75 // |pipe| is the message pipe handle corresponding to the channel's master
63 // interface. This is the message pipe underlying both |sender| and 76 // interface. This is the message pipe underlying both |sender| and
64 // |receiver|. 77 // |receiver|.
65 // 78 //
66 // Both |sender| and |receiver| must be non-null. 79 // Both |sender| and |receiver| must be non-null.
67 // 80 //
68 // Note that MessagePipeReader doesn't delete |delegate|. 81 // Note that MessagePipeReader doesn't delete |delegate|.
69 MessagePipeReader(mojo::MessagePipeHandle pipe, 82 MessagePipeReader(mojo::MessagePipeHandle pipe,
70 mojom::ChannelAssociatedPtr sender, 83 mojom::ChannelAssociatedPtr sender,
71 mojo::AssociatedInterfaceRequest<mojom::Channel> receiver, 84 mojo::AssociatedInterfaceRequest<mojom::Channel> receiver,
85 base::ProcessId peer_pid,
72 Delegate* delegate); 86 Delegate* delegate);
73 ~MessagePipeReader() override; 87 ~MessagePipeReader() override;
74 88
75 // Close and destroy the MessagePipe. 89 // Close and destroy the MessagePipe.
76 void Close(); 90 void Close();
77 91
78 // Return true if the MessagePipe is alive. 92 // Return true if the MessagePipe is alive.
79 bool IsValid() { return sender_; } 93 bool IsValid() { return sender_; }
80 94
81 // Sends an IPC::Message to the other end of the pipe. Safe to call from any 95 // Sends an IPC::Message to the other end of the pipe. Safe to call from any
82 // thread. 96 // thread.
83 bool Send(std::unique_ptr<Message> message); 97 bool Send(std::unique_ptr<Message> message);
84 98
85 // Requests an associated interface from the other end of the pipe. 99 // Requests an associated interface from the other end of the pipe.
86 void GetRemoteInterface(const std::string& name, 100 void GetRemoteInterface(const std::string& name,
87 mojo::ScopedInterfaceEndpointHandle handle); 101 mojo::ScopedInterfaceEndpointHandle handle);
88 102
89 base::ProcessId GetPeerPid() const { return peer_pid_; } 103 base::ProcessId GetPeerPid() const { return peer_pid_; }
90 104
91 protected: 105 protected:
92 void OnPipeClosed(); 106 void OnPipeClosed();
93 void OnPipeError(MojoResult error); 107 void OnPipeError(MojoResult error);
94 108
95 private: 109 private:
96 // mojom::Channel: 110 // mojom::Channel:
97 void SetPeerPid(int32_t peer_pid) override;
98 void Receive(mojo::Array<uint8_t> data, 111 void Receive(mojo::Array<uint8_t> data,
99 mojo::Array<mojom::SerializedHandlePtr> handles) override; 112 mojo::Array<mojom::SerializedHandlePtr> handles) override;
100 void GetAssociatedInterface( 113 void GetAssociatedInterface(
101 const mojo::String& name, 114 const mojo::String& name,
102 mojom::GenericInterfaceAssociatedRequest request) override; 115 mojom::GenericInterfaceAssociatedRequest request) override;
103 116
104 // |delegate_| is null once the message pipe is closed. 117 // |delegate_| is null once the message pipe is closed.
105 Delegate* delegate_; 118 Delegate* delegate_;
106 base::ProcessId peer_pid_ = base::kNullProcessId; 119 base::ProcessId peer_pid_;
107 mojom::ChannelAssociatedPtr sender_; 120 mojom::ChannelAssociatedPtr sender_;
108 mojo::AssociatedBinding<mojom::Channel> binding_; 121 mojo::AssociatedBinding<mojom::Channel> binding_;
109 122
110 // Raw message pipe handle and interface ID we use to send legacy IPC messages 123 // Raw message pipe handle and interface ID we use to send legacy IPC messages
111 // over the associated pipe. 124 // over the associated pipe.
112 const uint32_t sender_interface_id_; 125 const uint32_t sender_interface_id_;
113 const mojo::MessagePipeHandle sender_pipe_; 126 const mojo::MessagePipeHandle sender_pipe_;
114 127
115 base::ThreadChecker thread_checker_; 128 base::ThreadChecker thread_checker_;
116 129
117 DISALLOW_COPY_AND_ASSIGN(MessagePipeReader); 130 DISALLOW_COPY_AND_ASSIGN(MessagePipeReader);
118 }; 131 };
119 132
120 } // namespace internal 133 } // namespace internal
121 } // namespace IPC 134 } // namespace IPC
122 135
123 #endif // IPC_IPC_MESSAGE_PIPE_READER_H_ 136 #endif // IPC_IPC_MESSAGE_PIPE_READER_H_
OLDNEW
« no previous file with comments | « ipc/ipc_channel_proxy.cc ('k') | ipc/ipc_message_pipe_reader.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698