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 |