OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 MOJO_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ | 5 #ifndef MOJO_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ |
6 #define MOJO_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ | 6 #define MOJO_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ |
7 | 7 |
8 #include "base/macros.h" | 8 #include "base/macros.h" |
9 #include "base/memory/ref_counted.h" | 9 #include "base/memory/ref_counted.h" |
10 #include "mojo/system/dispatcher.h" | 10 #include "mojo/system/dispatcher.h" |
(...skipping 25 matching lines...) Expand all Loading... |
36 // |MojoCreateMessagePipeOptions| and will be entirely overwritten on success | 36 // |MojoCreateMessagePipeOptions| and will be entirely overwritten on success |
37 // (it may be partly overwritten on failure). | 37 // (it may be partly overwritten on failure). |
38 static MojoResult ValidateCreateOptions( | 38 static MojoResult ValidateCreateOptions( |
39 UserPointer<const MojoCreateMessagePipeOptions> in_options, | 39 UserPointer<const MojoCreateMessagePipeOptions> in_options, |
40 MojoCreateMessagePipeOptions* out_options); | 40 MojoCreateMessagePipeOptions* out_options); |
41 | 41 |
42 // Must be called before any other methods. (This method is not thread-safe.) | 42 // Must be called before any other methods. (This method is not thread-safe.) |
43 void Init(scoped_refptr<MessagePipe> message_pipe, unsigned port); | 43 void Init(scoped_refptr<MessagePipe> message_pipe, unsigned port); |
44 | 44 |
45 // |Dispatcher| public methods: | 45 // |Dispatcher| public methods: |
46 virtual Type GetType() const OVERRIDE; | 46 virtual Type GetType() const override; |
47 | 47 |
48 // Creates a |MessagePipe| with a local endpoint (at port 0) and a proxy | 48 // Creates a |MessagePipe| with a local endpoint (at port 0) and a proxy |
49 // endpoint, and creates/initializes a |MessagePipeDispatcher| (attached to | 49 // endpoint, and creates/initializes a |MessagePipeDispatcher| (attached to |
50 // the message pipe, port 0). | 50 // the message pipe, port 0). |
51 // TODO(vtl): This currently uses |kDefaultCreateOptions|, which is okay since | 51 // TODO(vtl): This currently uses |kDefaultCreateOptions|, which is okay since |
52 // there aren't any options, but eventually options should be plumbed through. | 52 // there aren't any options, but eventually options should be plumbed through. |
53 static scoped_refptr<MessagePipeDispatcher> CreateRemoteMessagePipe( | 53 static scoped_refptr<MessagePipeDispatcher> CreateRemoteMessagePipe( |
54 scoped_refptr<ChannelEndpoint>* channel_endpoint); | 54 scoped_refptr<ChannelEndpoint>* channel_endpoint); |
55 | 55 |
56 // The "opposite" of |SerializeAndClose()|. (Typically this is called by | 56 // The "opposite" of |SerializeAndClose()|. (Typically this is called by |
57 // |Dispatcher::Deserialize()|.) | 57 // |Dispatcher::Deserialize()|.) |
58 static scoped_refptr<MessagePipeDispatcher> Deserialize(Channel* channel, | 58 static scoped_refptr<MessagePipeDispatcher> Deserialize(Channel* channel, |
59 const void* source, | 59 const void* source, |
60 size_t size); | 60 size_t size); |
61 | 61 |
62 private: | 62 private: |
63 friend class MessagePipeDispatcherTransport; | 63 friend class MessagePipeDispatcherTransport; |
64 | 64 |
65 virtual ~MessagePipeDispatcher(); | 65 virtual ~MessagePipeDispatcher(); |
66 | 66 |
67 // Gets a dumb pointer to |message_pipe_|. This must be called under the | 67 // Gets a dumb pointer to |message_pipe_|. This must be called under the |
68 // |Dispatcher| lock (that it's a dumb pointer is okay since it's under lock). | 68 // |Dispatcher| lock (that it's a dumb pointer is okay since it's under lock). |
69 // This is needed when sending handles across processes, where nontrivial, | 69 // This is needed when sending handles across processes, where nontrivial, |
70 // invasive work needs to be done. | 70 // invasive work needs to be done. |
71 MessagePipe* GetMessagePipeNoLock() const; | 71 MessagePipe* GetMessagePipeNoLock() const; |
72 // Similarly for the port. | 72 // Similarly for the port. |
73 unsigned GetPortNoLock() const; | 73 unsigned GetPortNoLock() const; |
74 | 74 |
75 // |Dispatcher| protected methods: | 75 // |Dispatcher| protected methods: |
76 virtual void CancelAllWaitersNoLock() OVERRIDE; | 76 virtual void CancelAllWaitersNoLock() override; |
77 virtual void CloseImplNoLock() OVERRIDE; | 77 virtual void CloseImplNoLock() override; |
78 virtual scoped_refptr<Dispatcher> | 78 virtual scoped_refptr<Dispatcher> |
79 CreateEquivalentDispatcherAndCloseImplNoLock() OVERRIDE; | 79 CreateEquivalentDispatcherAndCloseImplNoLock() override; |
80 virtual MojoResult WriteMessageImplNoLock( | 80 virtual MojoResult WriteMessageImplNoLock( |
81 UserPointer<const void> bytes, | 81 UserPointer<const void> bytes, |
82 uint32_t num_bytes, | 82 uint32_t num_bytes, |
83 std::vector<DispatcherTransport>* transports, | 83 std::vector<DispatcherTransport>* transports, |
84 MojoWriteMessageFlags flags) OVERRIDE; | 84 MojoWriteMessageFlags flags) override; |
85 virtual MojoResult ReadMessageImplNoLock(UserPointer<void> bytes, | 85 virtual MojoResult ReadMessageImplNoLock(UserPointer<void> bytes, |
86 UserPointer<uint32_t> num_bytes, | 86 UserPointer<uint32_t> num_bytes, |
87 DispatcherVector* dispatchers, | 87 DispatcherVector* dispatchers, |
88 uint32_t* num_dispatchers, | 88 uint32_t* num_dispatchers, |
89 MojoReadMessageFlags flags) OVERRIDE; | 89 MojoReadMessageFlags flags) override; |
90 virtual HandleSignalsState GetHandleSignalsStateImplNoLock() const OVERRIDE; | 90 virtual HandleSignalsState GetHandleSignalsStateImplNoLock() const override; |
91 virtual MojoResult AddWaiterImplNoLock( | 91 virtual MojoResult AddWaiterImplNoLock( |
92 Waiter* waiter, | 92 Waiter* waiter, |
93 MojoHandleSignals signals, | 93 MojoHandleSignals signals, |
94 uint32_t context, | 94 uint32_t context, |
95 HandleSignalsState* signals_state) OVERRIDE; | 95 HandleSignalsState* signals_state) override; |
96 virtual void RemoveWaiterImplNoLock( | 96 virtual void RemoveWaiterImplNoLock( |
97 Waiter* waiter, | 97 Waiter* waiter, |
98 HandleSignalsState* signals_state) OVERRIDE; | 98 HandleSignalsState* signals_state) override; |
99 virtual void StartSerializeImplNoLock(Channel* channel, | 99 virtual void StartSerializeImplNoLock(Channel* channel, |
100 size_t* max_size, | 100 size_t* max_size, |
101 size_t* max_platform_handles) OVERRIDE; | 101 size_t* max_platform_handles) override; |
102 virtual bool EndSerializeAndCloseImplNoLock( | 102 virtual bool EndSerializeAndCloseImplNoLock( |
103 Channel* channel, | 103 Channel* channel, |
104 void* destination, | 104 void* destination, |
105 size_t* actual_size, | 105 size_t* actual_size, |
106 embedder::PlatformHandleVector* platform_handles) OVERRIDE; | 106 embedder::PlatformHandleVector* platform_handles) override; |
107 | 107 |
108 // Protected by |lock()|: | 108 // Protected by |lock()|: |
109 scoped_refptr<MessagePipe> message_pipe_; // This will be null if closed. | 109 scoped_refptr<MessagePipe> message_pipe_; // This will be null if closed. |
110 unsigned port_; | 110 unsigned port_; |
111 | 111 |
112 DISALLOW_COPY_AND_ASSIGN(MessagePipeDispatcher); | 112 DISALLOW_COPY_AND_ASSIGN(MessagePipeDispatcher); |
113 }; | 113 }; |
114 | 114 |
115 class MessagePipeDispatcherTransport : public DispatcherTransport { | 115 class MessagePipeDispatcherTransport : public DispatcherTransport { |
116 public: | 116 public: |
117 explicit MessagePipeDispatcherTransport(DispatcherTransport transport); | 117 explicit MessagePipeDispatcherTransport(DispatcherTransport transport); |
118 | 118 |
119 MessagePipe* GetMessagePipe() { | 119 MessagePipe* GetMessagePipe() { |
120 return message_pipe_dispatcher()->GetMessagePipeNoLock(); | 120 return message_pipe_dispatcher()->GetMessagePipeNoLock(); |
121 } | 121 } |
122 unsigned GetPort() { return message_pipe_dispatcher()->GetPortNoLock(); } | 122 unsigned GetPort() { return message_pipe_dispatcher()->GetPortNoLock(); } |
123 | 123 |
124 private: | 124 private: |
125 MessagePipeDispatcher* message_pipe_dispatcher() { | 125 MessagePipeDispatcher* message_pipe_dispatcher() { |
126 return static_cast<MessagePipeDispatcher*>(dispatcher()); | 126 return static_cast<MessagePipeDispatcher*>(dispatcher()); |
127 } | 127 } |
128 | 128 |
129 // Copy and assign allowed. | 129 // Copy and assign allowed. |
130 }; | 130 }; |
131 | 131 |
132 } // namespace system | 132 } // namespace system |
133 } // namespace mojo | 133 } // namespace mojo |
134 | 134 |
135 #endif // MOJO_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ | 135 #endif // MOJO_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ |
OLD | NEW |