| OLD | NEW |
| 1 // Copyright (c) 2014 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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 #include "content/child/resource_scheduling_filter.h" | 5 #include "content/child/resource_scheduling_filter.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/location.h" | 10 #include "base/location.h" |
| 11 #include "content/child/resource_dispatcher.h" | 11 #include "content/child/resource_dispatcher.h" |
| 12 #include "ipc/ipc_message.h" | 12 #include "ipc/ipc_message.h" |
| 13 #include "ipc/ipc_message_start.h" | 13 #include "ipc/ipc_message_start.h" |
| 14 #include "third_party/WebKit/public/platform/WebTaskRunner.h" | |
| 15 #include "third_party/WebKit/public/platform/WebTraceLocation.h" | |
| 16 | 14 |
| 17 namespace content { | 15 namespace content { |
| 18 | 16 |
| 19 namespace { | |
| 20 class DispatchMessageTask : public blink::WebTaskRunner::Task { | |
| 21 public: | |
| 22 DispatchMessageTask( | |
| 23 base::WeakPtr<ResourceSchedulingFilter> resource_scheduling_filter, | |
| 24 const IPC::Message& message) | |
| 25 : resource_scheduling_filter_(resource_scheduling_filter), | |
| 26 message_(message) {} | |
| 27 | |
| 28 void run() override { | |
| 29 if (!resource_scheduling_filter_.get()) | |
| 30 return; | |
| 31 resource_scheduling_filter_->DispatchMessage(message_); | |
| 32 } | |
| 33 | |
| 34 private: | |
| 35 base::WeakPtr<ResourceSchedulingFilter> resource_scheduling_filter_; | |
| 36 const IPC::Message message_; | |
| 37 }; | |
| 38 } // namespace | |
| 39 | |
| 40 ResourceSchedulingFilter::ResourceSchedulingFilter( | 17 ResourceSchedulingFilter::ResourceSchedulingFilter( |
| 41 const scoped_refptr<base::SingleThreadTaskRunner>& main_thread_task_runner, | 18 const scoped_refptr<base::SingleThreadTaskRunner>& main_thread_task_runner, |
| 42 ResourceDispatcher* resource_dispatcher) | 19 ResourceDispatcher* resource_dispatcher) |
| 43 : main_thread_task_runner_(main_thread_task_runner), | 20 : main_thread_task_runner_(main_thread_task_runner), |
| 44 resource_dispatcher_(resource_dispatcher), | 21 resource_dispatcher_(resource_dispatcher), |
| 45 weak_ptr_factory_(this) { | 22 weak_ptr_factory_(this) { |
| 46 DCHECK(main_thread_task_runner_.get()); | 23 DCHECK(main_thread_task_runner_.get()); |
| 47 DCHECK(resource_dispatcher_); | 24 DCHECK(resource_dispatcher_); |
| 48 } | 25 } |
| 49 | 26 |
| 50 ResourceSchedulingFilter::~ResourceSchedulingFilter() { | 27 ResourceSchedulingFilter::~ResourceSchedulingFilter() { |
| 51 } | 28 } |
| 52 | 29 |
| 53 bool ResourceSchedulingFilter::OnMessageReceived(const IPC::Message& message) { | 30 bool ResourceSchedulingFilter::OnMessageReceived(const IPC::Message& message) { |
| 54 base::AutoLock lock(request_id_to_task_runner_map_lock_); | 31 base::AutoLock lock(request_id_to_task_runner_map_lock_); |
| 55 int request_id; | 32 int request_id; |
| 56 | 33 |
| 57 base::PickleIterator pickle_iterator(message); | 34 base::PickleIterator pickle_iterator(message); |
| 58 if (!pickle_iterator.ReadInt(&request_id)) { | 35 if (!pickle_iterator.ReadInt(&request_id)) { |
| 59 NOTREACHED() << "malformed resource message"; | 36 NOTREACHED() << "malformed resource message"; |
| 60 return true; | 37 return true; |
| 61 } | 38 } |
| 62 // Dispatch the message on the request id specific task runner, if there is | 39 // Dispatch the message on the request id specific task runner, if there is |
| 63 // one, or on the general main_thread_task_runner if there isn't. | 40 // one, or on the general main_thread_task_runner if there isn't. |
| 64 RequestIdToTaskRunnerMap::const_iterator iter = | 41 RequestIdToTaskRunnerMap::const_iterator iter = |
| 65 request_id_to_task_runner_map_.find(request_id); | 42 request_id_to_task_runner_map_.find(request_id); |
| 43 scoped_refptr<base::SingleThreadTaskRunner> task_runner; |
| 66 if (iter != request_id_to_task_runner_map_.end()) { | 44 if (iter != request_id_to_task_runner_map_.end()) { |
| 67 // TODO(alexclarke): Find a way to let blink and chromium FROM_HERE coexist. | 45 task_runner = iter->second; |
| 68 iter->second->postTask( | |
| 69 BLINK_FROM_HERE, | |
| 70 new DispatchMessageTask(weak_ptr_factory_.GetWeakPtr(), message)); | |
| 71 } else { | 46 } else { |
| 72 main_thread_task_runner_->PostTask( | 47 task_runner = main_thread_task_runner_; |
| 73 FROM_HERE, base::Bind(&ResourceSchedulingFilter::DispatchMessage, | |
| 74 weak_ptr_factory_.GetWeakPtr(), message)); | |
| 75 } | 48 } |
| 49 task_runner->PostTask(FROM_HERE, |
| 50 base::Bind(&ResourceSchedulingFilter::DispatchMessage, |
| 51 weak_ptr_factory_.GetWeakPtr(), message)); |
| 76 return true; | 52 return true; |
| 77 } | 53 } |
| 78 | 54 |
| 79 void ResourceSchedulingFilter::SetRequestIdTaskRunner( | 55 void ResourceSchedulingFilter::SetRequestIdTaskRunner( |
| 80 int id, | 56 int id, |
| 81 std::unique_ptr<blink::WebTaskRunner> web_task_runner) { | 57 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner) { |
| 82 base::AutoLock lock(request_id_to_task_runner_map_lock_); | 58 base::AutoLock lock(request_id_to_task_runner_map_lock_); |
| 83 request_id_to_task_runner_map_.insert( | 59 request_id_to_task_runner_map_.insert(std::make_pair(id, task_runner)); |
| 84 std::make_pair(id, std::move(web_task_runner))); | |
| 85 } | 60 } |
| 86 | 61 |
| 87 void ResourceSchedulingFilter::ClearRequestIdTaskRunner(int id) { | 62 void ResourceSchedulingFilter::ClearRequestIdTaskRunner(int id) { |
| 88 base::AutoLock lock(request_id_to_task_runner_map_lock_); | 63 base::AutoLock lock(request_id_to_task_runner_map_lock_); |
| 89 request_id_to_task_runner_map_.erase(id); | 64 request_id_to_task_runner_map_.erase(id); |
| 90 } | 65 } |
| 91 | 66 |
| 92 bool ResourceSchedulingFilter::GetSupportedMessageClasses( | 67 bool ResourceSchedulingFilter::GetSupportedMessageClasses( |
| 93 std::vector<uint32_t>* supported_message_classes) const { | 68 std::vector<uint32_t>* supported_message_classes) const { |
| 94 supported_message_classes->push_back(ResourceMsgStart); | 69 supported_message_classes->push_back(ResourceMsgStart); |
| 95 return true; | 70 return true; |
| 96 } | 71 } |
| 97 | 72 |
| 98 void ResourceSchedulingFilter::DispatchMessage(const IPC::Message& message) { | 73 void ResourceSchedulingFilter::DispatchMessage(const IPC::Message& message) { |
| 99 resource_dispatcher_->OnMessageReceived(message); | 74 resource_dispatcher_->OnMessageReceived(message); |
| 100 } | 75 } |
| 101 | 76 |
| 102 } // namespace content | 77 } // namespace content |
| OLD | NEW |