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 #include "content/child/npapi/np_channel_base.h" | 5 #include "content/child/npapi/np_channel_base.h" |
6 | 6 |
7 #include "base/auto_reset.h" | 7 #include "base/auto_reset.h" |
8 #include "base/containers/hash_tables.h" | 8 #include "base/containers/hash_tables.h" |
9 #include "base/files/scoped_file.h" | 9 #include "base/files/scoped_file.h" |
10 #include "base/lazy_instance.h" | 10 #include "base/lazy_instance.h" |
| 11 #include "base/single_thread_task_runner.h" |
11 #include "base/strings/string_number_conversions.h" | 12 #include "base/strings/string_number_conversions.h" |
12 #include "base/threading/thread_local.h" | 13 #include "base/threading/thread_local.h" |
13 #include "ipc/ipc_sync_message.h" | 14 #include "ipc/ipc_sync_message.h" |
14 | 15 |
15 #if defined(OS_POSIX) | 16 #if defined(OS_POSIX) |
16 #include "base/files/file_util.h" | 17 #include "base/files/file_util.h" |
17 #include "ipc/ipc_channel_posix.h" | 18 #include "ipc/ipc_channel_posix.h" |
18 #endif | 19 #endif |
19 | 20 |
20 namespace content { | 21 namespace content { |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
55 | 56 |
56 #endif // OS_ANDROID | 57 #endif // OS_ANDROID |
57 | 58 |
58 ChannelMap* GetChannelMap() { | 59 ChannelMap* GetChannelMap() { |
59 return &GetChannelGlobals()->channel_map; | 60 return &GetChannelGlobals()->channel_map; |
60 } | 61 } |
61 | 62 |
62 } // namespace | 63 } // namespace |
63 | 64 |
64 NPChannelBase* NPChannelBase::GetChannel( | 65 NPChannelBase* NPChannelBase::GetChannel( |
65 const IPC::ChannelHandle& channel_handle, IPC::Channel::Mode mode, | 66 const IPC::ChannelHandle& channel_handle, |
66 ChannelFactory factory, base::MessageLoopProxy* ipc_message_loop, | 67 IPC::Channel::Mode mode, |
67 bool create_pipe_now, base::WaitableEvent* shutdown_event) { | 68 ChannelFactory factory, |
| 69 base::SingleThreadTaskRunner* ipc_task_runner, |
| 70 bool create_pipe_now, |
| 71 base::WaitableEvent* shutdown_event) { |
68 #if defined(OS_POSIX) | 72 #if defined(OS_POSIX) |
69 // On POSIX the channel_handle conveys an FD (socket) which is duped by the | 73 // On POSIX the channel_handle conveys an FD (socket) which is duped by the |
70 // kernel during the IPC message exchange (via the SCM_RIGHTS mechanism). | 74 // kernel during the IPC message exchange (via the SCM_RIGHTS mechanism). |
71 // Ensure we do not leak this FD. | 75 // Ensure we do not leak this FD. |
72 base::ScopedFD fd(channel_handle.socket.auto_close ? | 76 base::ScopedFD fd(channel_handle.socket.auto_close ? |
73 channel_handle.socket.fd : -1); | 77 channel_handle.socket.fd : -1); |
74 #endif | 78 #endif |
75 | 79 |
76 scoped_refptr<NPChannelBase> channel; | 80 scoped_refptr<NPChannelBase> channel; |
77 std::string channel_key = channel_handle.name; | 81 std::string channel_key = channel_handle.name; |
78 ChannelMap::const_iterator iter = GetChannelMap()->find(channel_key); | 82 ChannelMap::const_iterator iter = GetChannelMap()->find(channel_key); |
79 if (iter == GetChannelMap()->end()) { | 83 if (iter == GetChannelMap()->end()) { |
80 channel = factory(); | 84 channel = factory(); |
81 } else { | 85 } else { |
82 channel = iter->second; | 86 channel = iter->second; |
83 } | 87 } |
84 | 88 |
85 DCHECK(channel.get() != NULL); | 89 DCHECK(channel.get() != NULL); |
86 | 90 |
87 if (!channel->channel_valid()) { | 91 if (!channel->channel_valid()) { |
88 channel->channel_handle_ = channel_handle; | 92 channel->channel_handle_ = channel_handle; |
89 #if defined(OS_POSIX) | 93 #if defined(OS_POSIX) |
90 ignore_result(fd.release()); | 94 ignore_result(fd.release()); |
91 #endif | 95 #endif |
92 if (mode & IPC::Channel::MODE_SERVER_FLAG) { | 96 if (mode & IPC::Channel::MODE_SERVER_FLAG) { |
93 channel->channel_handle_.name = | 97 channel->channel_handle_.name = |
94 IPC::Channel::GenerateVerifiedChannelID(channel_key); | 98 IPC::Channel::GenerateVerifiedChannelID(channel_key); |
95 } | 99 } |
96 channel->mode_ = mode; | 100 channel->mode_ = mode; |
97 if (channel->Init(ipc_message_loop, create_pipe_now, shutdown_event)) { | 101 if (channel->Init(ipc_task_runner, create_pipe_now, shutdown_event)) { |
98 (*GetChannelMap())[channel_key] = channel; | 102 (*GetChannelMap())[channel_key] = channel; |
99 } else { | 103 } else { |
100 channel = NULL; | 104 channel = NULL; |
101 } | 105 } |
102 } | 106 } |
103 | 107 |
104 return channel.get(); | 108 return channel.get(); |
105 } | 109 } |
106 | 110 |
107 void NPChannelBase::Broadcast(IPC::Message* message) { | 111 void NPChannelBase::Broadcast(IPC::Message* message) { |
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
161 DLOG(WARNING) << "Invalid route id passed in:" << route_id; | 165 DLOG(WARNING) << "Invalid route id passed in:" << route_id; |
162 return NULL; | 166 return NULL; |
163 } | 167 } |
164 return iter->second; | 168 return iter->second; |
165 } | 169 } |
166 | 170 |
167 base::WaitableEvent* NPChannelBase::GetModalDialogEvent(int render_view_id) { | 171 base::WaitableEvent* NPChannelBase::GetModalDialogEvent(int render_view_id) { |
168 return NULL; | 172 return NULL; |
169 } | 173 } |
170 | 174 |
171 bool NPChannelBase::Init(base::MessageLoopProxy* ipc_message_loop, | 175 bool NPChannelBase::Init(base::SingleThreadTaskRunner* ipc_task_runner, |
172 bool create_pipe_now, | 176 bool create_pipe_now, |
173 base::WaitableEvent* shutdown_event) { | 177 base::WaitableEvent* shutdown_event) { |
174 #if defined(OS_POSIX) | 178 #if defined(OS_POSIX) |
175 // Attempting to initialize with an invalid channel handle. | 179 // Attempting to initialize with an invalid channel handle. |
176 // See http://crbug.com/97285 for details. | 180 // See http://crbug.com/97285 for details. |
177 if (mode_ == IPC::Channel::MODE_CLIENT && -1 == channel_handle_.socket.fd) | 181 if (mode_ == IPC::Channel::MODE_CLIENT && -1 == channel_handle_.socket.fd) |
178 return false; | 182 return false; |
179 #endif | 183 #endif |
180 | 184 |
181 channel_ = IPC::SyncChannel::Create( | 185 channel_ = |
182 channel_handle_, mode_, this, ipc_message_loop, create_pipe_now, | 186 IPC::SyncChannel::Create(channel_handle_, mode_, this, ipc_task_runner, |
183 shutdown_event); | 187 create_pipe_now, shutdown_event); |
184 | 188 |
185 #if defined(OS_POSIX) | 189 #if defined(OS_POSIX) |
186 // Check the validity of fd for bug investigation. Remove after fixed. | 190 // Check the validity of fd for bug investigation. Remove after fixed. |
187 // See crbug.com/97285 for details. | 191 // See crbug.com/97285 for details. |
188 if (mode_ == IPC::Channel::MODE_SERVER) | 192 if (mode_ == IPC::Channel::MODE_SERVER) |
189 CHECK_NE(-1, channel_->GetClientFileDescriptor()); | 193 CHECK_NE(-1, channel_->GetClientFileDescriptor()); |
190 #endif | 194 #endif |
191 | 195 |
192 channel_valid_ = true; | 196 channel_valid_ = true; |
193 return true; | 197 return true; |
(...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
377 RouteToOwnerMap::iterator iter = route_to_owner_.find(route_id); | 381 RouteToOwnerMap::iterator iter = route_to_owner_.find(route_id); |
378 return iter != route_to_owner_.end() ? iter->second : default_owner_; | 382 return iter != route_to_owner_.end() ? iter->second : default_owner_; |
379 } | 383 } |
380 | 384 |
381 int NPChannelBase::GetExistingRouteForNPObjectOwner(NPP owner) { | 385 int NPChannelBase::GetExistingRouteForNPObjectOwner(NPP owner) { |
382 OwnerToRouteMap::iterator iter = owner_to_route_.find(owner); | 386 OwnerToRouteMap::iterator iter = owner_to_route_.find(owner); |
383 return iter != owner_to_route_.end() ? iter->second : MSG_ROUTING_NONE; | 387 return iter != owner_to_route_.end() ? iter->second : MSG_ROUTING_NONE; |
384 } | 388 } |
385 | 389 |
386 } // namespace content | 390 } // namespace content |
OLD | NEW |