OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "ipc/ipc_channel_proxy.h" | 5 #include "ipc/ipc_channel_proxy.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 #include <stdint.h> | 8 #include <stdint.h> |
9 | 9 |
10 #include <utility> | 10 #include <utility> |
(...skipping 29 matching lines...) Expand all Loading... |
40 | 40 |
41 //------------------------------------------------------------------------------ | 41 //------------------------------------------------------------------------------ |
42 | 42 |
43 ChannelProxy::Context::Context( | 43 ChannelProxy::Context::Context( |
44 Listener* listener, | 44 Listener* listener, |
45 const scoped_refptr<base::SingleThreadTaskRunner>& ipc_task_runner) | 45 const scoped_refptr<base::SingleThreadTaskRunner>& ipc_task_runner) |
46 : listener_task_runner_(base::ThreadTaskRunnerHandle::Get()), | 46 : listener_task_runner_(base::ThreadTaskRunnerHandle::Get()), |
47 listener_(listener), | 47 listener_(listener), |
48 ipc_task_runner_(ipc_task_runner), | 48 ipc_task_runner_(ipc_task_runner), |
49 channel_connected_called_(false), | 49 channel_connected_called_(false), |
50 channel_send_thread_safe_(false), | |
51 message_filter_router_(new MessageFilterRouter()), | 50 message_filter_router_(new MessageFilterRouter()), |
52 peer_pid_(base::kNullProcessId), | 51 peer_pid_(base::kNullProcessId), |
53 attachment_broker_endpoint_(false) { | 52 attachment_broker_endpoint_(false) { |
54 DCHECK(ipc_task_runner_.get()); | 53 DCHECK(ipc_task_runner_.get()); |
55 // The Listener thread where Messages are handled must be a separate thread | 54 // The Listener thread where Messages are handled must be a separate thread |
56 // to avoid oversubscribing the IO thread. If you trigger this error, you | 55 // to avoid oversubscribing the IO thread. If you trigger this error, you |
57 // need to either: | 56 // need to either: |
58 // 1) Create the ChannelProxy on a different thread, or | 57 // 1) Create the ChannelProxy on a different thread, or |
59 // 2) Just use Channel | 58 // 2) Just use Channel |
60 // Note, we currently make an exception for a NULL listener. That usage | 59 // Note, we currently make an exception for a NULL listener. That usage |
61 // basically works, but is outside the intent of ChannelProxy. This support | 60 // basically works, but is outside the intent of ChannelProxy. This support |
62 // will disappear, so please don't rely on it. See crbug.com/364241 | 61 // will disappear, so please don't rely on it. See crbug.com/364241 |
63 DCHECK(!listener || (ipc_task_runner_.get() != listener_task_runner_.get())); | 62 DCHECK(!listener || (ipc_task_runner_.get() != listener_task_runner_.get())); |
64 } | 63 } |
65 | 64 |
66 ChannelProxy::Context::~Context() { | 65 ChannelProxy::Context::~Context() { |
67 } | 66 } |
68 | 67 |
69 void ChannelProxy::Context::ClearIPCTaskRunner() { | 68 void ChannelProxy::Context::ClearIPCTaskRunner() { |
70 ipc_task_runner_ = NULL; | 69 ipc_task_runner_ = NULL; |
71 } | 70 } |
72 | 71 |
73 void ChannelProxy::Context::CreateChannel( | 72 void ChannelProxy::Context::CreateChannel( |
74 std::unique_ptr<ChannelFactory> factory) { | 73 std::unique_ptr<ChannelFactory> factory) { |
75 base::AutoLock l(channel_lifetime_lock_); | 74 base::AutoLock l(channel_lifetime_lock_); |
76 DCHECK(!channel_); | 75 DCHECK(!channel_); |
77 DCHECK_EQ(factory->GetIPCTaskRunner(), ipc_task_runner_); | 76 DCHECK_EQ(factory->GetIPCTaskRunner(), ipc_task_runner_); |
78 channel_id_ = factory->GetName(); | 77 channel_id_ = factory->GetName(); |
79 channel_ = factory->BuildChannel(this); | 78 channel_ = factory->BuildChannel(this); |
80 channel_send_thread_safe_ = channel_->IsSendThreadSafe(); | |
81 channel_->SetAttachmentBrokerEndpoint(attachment_broker_endpoint_); | 79 channel_->SetAttachmentBrokerEndpoint(attachment_broker_endpoint_); |
82 | 80 |
83 Channel::AssociatedInterfaceSupport* support = | 81 Channel::AssociatedInterfaceSupport* support = |
84 channel_->GetAssociatedInterfaceSupport(); | 82 channel_->GetAssociatedInterfaceSupport(); |
85 if (support) { | 83 if (support) { |
86 associated_group_ = *support->GetAssociatedGroup(); | 84 associated_group_ = *support->GetAssociatedGroup(); |
87 | 85 |
88 base::AutoLock l(pending_filters_lock_); | 86 base::AutoLock l(pending_filters_lock_); |
89 for (auto& entry : pending_interfaces_) | 87 for (auto& entry : pending_interfaces_) |
90 support->AddGenericAssociatedInterface(entry.first, entry.second); | 88 support->AddGenericAssociatedInterface(entry.first, entry.second); |
(...skipping 314 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
405 base::AutoLock l(pending_filters_lock_); | 403 base::AutoLock l(pending_filters_lock_); |
406 pending_interfaces_.emplace_back(name, factory); | 404 pending_interfaces_.emplace_back(name, factory); |
407 return; | 405 return; |
408 } | 406 } |
409 Channel::AssociatedInterfaceSupport* support = | 407 Channel::AssociatedInterfaceSupport* support = |
410 channel_->GetAssociatedInterfaceSupport(); | 408 channel_->GetAssociatedInterfaceSupport(); |
411 DCHECK(support); | 409 DCHECK(support); |
412 support->AddGenericAssociatedInterface(name, factory); | 410 support->AddGenericAssociatedInterface(name, factory); |
413 } | 411 } |
414 | 412 |
415 void ChannelProxy::Context::SendFromThisThread(Message* message) { | |
416 base::AutoLock l(channel_lifetime_lock_); | |
417 if (!channel_) | |
418 return; | |
419 DCHECK(channel_->IsSendThreadSafe()); | |
420 channel_->Send(message); | |
421 } | |
422 | |
423 void ChannelProxy::Context::Send(Message* message) { | 413 void ChannelProxy::Context::Send(Message* message) { |
424 if (channel_send_thread_safe_) { | |
425 SendFromThisThread(message); | |
426 return; | |
427 } | |
428 | |
429 ipc_task_runner()->PostTask( | 414 ipc_task_runner()->PostTask( |
430 FROM_HERE, base::Bind(&ChannelProxy::Context::OnSendMessage, this, | 415 FROM_HERE, base::Bind(&ChannelProxy::Context::OnSendMessage, this, |
431 base::Passed(base::WrapUnique(message)))); | 416 base::Passed(base::WrapUnique(message)))); |
432 } | 417 } |
433 | 418 |
434 bool ChannelProxy::Context::IsChannelSendThreadSafe() const { | |
435 return channel_send_thread_safe_; | |
436 } | |
437 | |
438 // Called on the IPC::Channel thread | 419 // Called on the IPC::Channel thread |
439 void ChannelProxy::Context::GetRemoteAssociatedInterface( | 420 void ChannelProxy::Context::GetRemoteAssociatedInterface( |
440 const std::string& name, | 421 const std::string& name, |
441 mojo::ScopedInterfaceEndpointHandle handle) { | 422 mojo::ScopedInterfaceEndpointHandle handle) { |
442 if (!channel_) | 423 if (!channel_) |
443 return; | 424 return; |
444 Channel::AssociatedInterfaceSupport* associated_interface_support = | 425 Channel::AssociatedInterfaceSupport* associated_interface_support = |
445 channel_->GetAssociatedInterfaceSupport(); | 426 channel_->GetAssociatedInterfaceSupport(); |
446 DCHECK(associated_interface_support); | 427 DCHECK(associated_interface_support); |
447 associated_interface_support->GetGenericRemoteAssociatedInterface( | 428 associated_interface_support->GetGenericRemoteAssociatedInterface( |
(...skipping 217 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
665 return channel->TakeClientFileDescriptor(); | 646 return channel->TakeClientFileDescriptor(); |
666 } | 647 } |
667 #endif | 648 #endif |
668 | 649 |
669 void ChannelProxy::OnChannelInit() { | 650 void ChannelProxy::OnChannelInit() { |
670 } | 651 } |
671 | 652 |
672 //----------------------------------------------------------------------------- | 653 //----------------------------------------------------------------------------- |
673 | 654 |
674 } // namespace IPC | 655 } // namespace IPC |
OLD | NEW |