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 // See http://dev.chromium.org/developers/design-documents/multi-process-resourc
e-loading | 5 // See http://dev.chromium.org/developers/design-documents/multi-process-resourc
e-loading |
6 | 6 |
7 #include "content/child/resource_dispatcher.h" | 7 #include "content/child/resource_dispatcher.h" |
8 | 8 |
9 #include "base/basictypes.h" | 9 #include "base/basictypes.h" |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
73 delegate_(NULL), | 73 delegate_(NULL), |
74 io_timestamp_(base::TimeTicks()), | 74 io_timestamp_(base::TimeTicks()), |
75 main_thread_task_runner_(main_thread_task_runner), | 75 main_thread_task_runner_(main_thread_task_runner), |
76 weak_factory_(this) { | 76 weak_factory_(this) { |
77 } | 77 } |
78 | 78 |
79 ResourceDispatcher::~ResourceDispatcher() { | 79 ResourceDispatcher::~ResourceDispatcher() { |
80 } | 80 } |
81 | 81 |
82 bool ResourceDispatcher::OnMessageReceived(const IPC::Message& message) { | 82 bool ResourceDispatcher::OnMessageReceived(const IPC::Message& message) { |
| 83 // TODO(erikchen): Temporary code to help track http://crbug.com/527588. |
| 84 content::CheckContentsOfDataReceivedMessage(&message); |
| 85 |
83 if (!IsResourceDispatcherMessage(message)) { | 86 if (!IsResourceDispatcherMessage(message)) { |
84 return false; | 87 return false; |
85 } | 88 } |
86 | 89 |
87 int request_id; | 90 int request_id; |
88 | 91 |
89 base::PickleIterator iter(message); | 92 base::PickleIterator iter(message); |
90 if (!iter.ReadInt(&request_id)) { | 93 if (!iter.ReadInt(&request_id)) { |
91 NOTREACHED() << "malformed resource message"; | 94 NOTREACHED() << "malformed resource message"; |
92 return true; | 95 return true; |
(...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
212 | 215 |
213 void ResourceDispatcher::OnReceivedData(int request_id, | 216 void ResourceDispatcher::OnReceivedData(int request_id, |
214 int data_offset, | 217 int data_offset, |
215 int data_length, | 218 int data_length, |
216 int encoded_data_length) { | 219 int encoded_data_length) { |
217 TRACE_EVENT0("loader", "ResourceDispatcher::OnReceivedData"); | 220 TRACE_EVENT0("loader", "ResourceDispatcher::OnReceivedData"); |
218 DCHECK_GT(data_length, 0); | 221 DCHECK_GT(data_length, 0); |
219 PendingRequestInfo* request_info = GetPendingRequestInfo(request_id); | 222 PendingRequestInfo* request_info = GetPendingRequestInfo(request_id); |
220 bool send_ack = true; | 223 bool send_ack = true; |
221 if (request_info && data_length > 0) { | 224 if (request_info && data_length > 0) { |
| 225 // TODO(erikchen): Temporary code to help track http://crbug.com/527588. |
| 226 int buffer_size = request_info->buffer_size; |
| 227 |
222 CHECK(base::SharedMemory::IsHandleValid(request_info->buffer->handle())); | 228 CHECK(base::SharedMemory::IsHandleValid(request_info->buffer->handle())); |
223 CHECK_GE(request_info->buffer_size, data_offset + data_length); | 229 CHECK_GE(request_info->buffer_size, data_offset + data_length); |
224 | 230 |
| 231 // TODO(erikchen): Temporary code to help track http://crbug.com/527588. |
| 232 base::debug::Alias(request_info); |
| 233 base::debug::Alias(&buffer_size); |
| 234 |
225 // Ensure that the SHM buffer remains valid for the duration of this scope. | 235 // Ensure that the SHM buffer remains valid for the duration of this scope. |
226 // It is possible for Cancel() to be called before we exit this scope. | 236 // It is possible for Cancel() to be called before we exit this scope. |
227 // SharedMemoryReceivedDataFactory stores the SHM buffer inside it. | 237 // SharedMemoryReceivedDataFactory stores the SHM buffer inside it. |
228 scoped_refptr<SharedMemoryReceivedDataFactory> factory( | 238 scoped_refptr<SharedMemoryReceivedDataFactory> factory( |
229 request_info->received_data_factory); | 239 request_info->received_data_factory); |
230 | 240 |
231 base::TimeTicks time_start = base::TimeTicks::Now(); | 241 base::TimeTicks time_start = base::TimeTicks::Now(); |
232 | 242 |
233 const char* data_start = static_cast<char*>(request_info->buffer->memory()); | 243 const char* data_start = static_cast<char*>(request_info->buffer->memory()); |
234 CHECK(data_start); | 244 CHECK(data_start); |
(...skipping 553 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
788 extra_data->transferred_request_request_id(); | 798 extra_data->transferred_request_request_id(); |
789 request->service_worker_provider_id = | 799 request->service_worker_provider_id = |
790 extra_data->service_worker_provider_id(); | 800 extra_data->service_worker_provider_id(); |
791 request->request_body = request_body; | 801 request->request_body = request_body; |
792 if (frame_origin) | 802 if (frame_origin) |
793 *frame_origin = extra_data->frame_origin(); | 803 *frame_origin = extra_data->frame_origin(); |
794 return request.Pass(); | 804 return request.Pass(); |
795 } | 805 } |
796 | 806 |
797 } // namespace content | 807 } // namespace content |
OLD | NEW |