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 "chrome/browser/service_process/service_process_control.h" | 5 #include "chrome/browser/service_process/service_process_control.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
10 #include "base/files/file_path.h" | 10 #include "base/files/file_path.h" |
11 #include "base/metrics/histogram_base.h" | 11 #include "base/metrics/histogram_base.h" |
12 #include "base/metrics/histogram_delta_serialization.h" | 12 #include "base/metrics/histogram_delta_serialization.h" |
13 #include "base/process/kill.h" | 13 #include "base/process/kill.h" |
14 #include "base/process/launch.h" | 14 #include "base/process/launch.h" |
15 #include "base/stl_util.h" | 15 #include "base/stl_util.h" |
16 #include "base/threading/thread.h" | 16 #include "base/threading/thread.h" |
17 #include "base/threading/thread_restrictions.h" | 17 #include "base/threading/thread_restrictions.h" |
18 #include "chrome/browser/browser_process.h" | 18 #include "chrome/browser/browser_process.h" |
19 #include "chrome/browser/chrome_notification_types.h" | 19 #include "chrome/browser/chrome_notification_types.h" |
20 #include "chrome/browser/upgrade_detector.h" | 20 #include "chrome/browser/upgrade_detector.h" |
21 #include "chrome/common/service_messages.h" | 21 #include "chrome/common/service_messages.h" |
22 #include "chrome/common/service_process_util.h" | 22 #include "chrome/common/service_process_util.h" |
23 #include "content/public/browser/browser_thread.h" | 23 #include "content/public/browser/browser_thread.h" |
24 #include "content/public/browser/notification_service.h" | 24 #include "content/public/browser/notification_service.h" |
25 | 25 |
26 using content::BrowserThread; | 26 using content::BrowserThread; |
27 | 27 |
28 namespace { | |
29 | |
30 // Test: On Mac, launchd_msg_send tries to allocate a 10MB buffer, but doesn't | |
31 // handle errors and makes ugly crash dumps when close to OOM. | |
32 // TODO(vitalybuka): Remove after few Canary builds. | |
33 // See http://crbug.com/406227 | |
34 void AllocDebugTest() { | |
35 #if defined(OS_MACOSX) | |
36 void* buffer = malloc(20 * 1024 * 1024); | |
37 CHECK(buffer); | |
38 free(buffer); | |
39 #endif // OS_MACOSX | |
40 } | |
41 | |
42 } // namespace | |
43 | |
44 // ServiceProcessControl implementation. | 28 // ServiceProcessControl implementation. |
45 ServiceProcessControl::ServiceProcessControl() { | 29 ServiceProcessControl::ServiceProcessControl() { |
46 } | 30 } |
47 | 31 |
48 ServiceProcessControl::~ServiceProcessControl() { | 32 ServiceProcessControl::~ServiceProcessControl() { |
49 } | 33 } |
50 | 34 |
51 void ServiceProcessControl::ConnectInternal() { | 35 void ServiceProcessControl::ConnectInternal() { |
52 // If the channel has already been established then we run the task | 36 // If the channel has already been established then we run the task |
53 // and return. | 37 // and return. |
(...skipping 178 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
232 const std::vector<std::string>& pickled_histograms) { | 216 const std::vector<std::string>& pickled_histograms) { |
233 UMA_HISTOGRAM_ENUMERATION("CloudPrint.ServiceEvents", | 217 UMA_HISTOGRAM_ENUMERATION("CloudPrint.ServiceEvents", |
234 SERVICE_EVENT_HISTOGRAMS_REPLY, SERVICE_EVENT_MAX); | 218 SERVICE_EVENT_HISTOGRAMS_REPLY, SERVICE_EVENT_MAX); |
235 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 219 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
236 base::HistogramDeltaSerialization::DeserializeAndAddSamples( | 220 base::HistogramDeltaSerialization::DeserializeAndAddSamples( |
237 pickled_histograms); | 221 pickled_histograms); |
238 RunHistogramsCallback(); | 222 RunHistogramsCallback(); |
239 } | 223 } |
240 | 224 |
241 void ServiceProcessControl::RunHistogramsCallback() { | 225 void ServiceProcessControl::RunHistogramsCallback() { |
242 AllocDebugTest(); | |
243 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 226 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
244 if (!histograms_callback_.is_null()) { | 227 if (!histograms_callback_.is_null()) { |
245 histograms_callback_.Run(); | 228 histograms_callback_.Run(); |
246 histograms_callback_.Reset(); | 229 histograms_callback_.Reset(); |
247 } | 230 } |
248 histograms_timeout_callback_.Cancel(); | 231 histograms_timeout_callback_.Cancel(); |
249 } | 232 } |
250 | 233 |
251 void ServiceProcessControl::OnPrinters( | 234 void ServiceProcessControl::OnPrinters( |
252 const std::vector<std::string>& printers) { | 235 const std::vector<std::string>& printers) { |
(...skipping 16 matching lines...) Expand all Loading... |
269 SERVICE_EVENT_INFO_REQUEST, SERVICE_EVENT_MAX); | 252 SERVICE_EVENT_INFO_REQUEST, SERVICE_EVENT_MAX); |
270 if (!Send(new ServiceMsg_GetCloudPrintProxyInfo())) | 253 if (!Send(new ServiceMsg_GetCloudPrintProxyInfo())) |
271 return false; | 254 return false; |
272 cloud_print_info_callback_ = cloud_print_info_callback; | 255 cloud_print_info_callback_ = cloud_print_info_callback; |
273 return true; | 256 return true; |
274 } | 257 } |
275 | 258 |
276 bool ServiceProcessControl::GetHistograms( | 259 bool ServiceProcessControl::GetHistograms( |
277 const base::Closure& histograms_callback, | 260 const base::Closure& histograms_callback, |
278 const base::TimeDelta& timeout) { | 261 const base::TimeDelta& timeout) { |
279 AllocDebugTest(); | |
280 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 262 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
281 DCHECK(!histograms_callback.is_null()); | 263 DCHECK(!histograms_callback.is_null()); |
282 histograms_callback_.Reset(); | 264 histograms_callback_.Reset(); |
283 | 265 |
284 // If the service process is already running then connect to it. | 266 // If the service process is already running then connect to it. |
285 if (!CheckServiceProcessReady()) | 267 if (!CheckServiceProcessReady()) |
286 return false; | 268 return false; |
287 ConnectInternal(); | 269 ConnectInternal(); |
288 | 270 |
289 UMA_HISTOGRAM_ENUMERATION("CloudPrint.ServiceEvents", | 271 UMA_HISTOGRAM_ENUMERATION("CloudPrint.ServiceEvents", |
(...skipping 113 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
403 if (base::LaunchProcess(*cmd_line_, options, &process_handle_)) { | 385 if (base::LaunchProcess(*cmd_line_, options, &process_handle_)) { |
404 BrowserThread::PostTask( | 386 BrowserThread::PostTask( |
405 BrowserThread::IO, FROM_HERE, | 387 BrowserThread::IO, FROM_HERE, |
406 base::Bind(&Launcher::DoDetectLaunched, this)); | 388 base::Bind(&Launcher::DoDetectLaunched, this)); |
407 } else { | 389 } else { |
408 BrowserThread::PostTask( | 390 BrowserThread::PostTask( |
409 BrowserThread::UI, FROM_HERE, base::Bind(&Launcher::Notify, this)); | 391 BrowserThread::UI, FROM_HERE, base::Bind(&Launcher::Notify, this)); |
410 } | 392 } |
411 } | 393 } |
412 #endif // !OS_MACOSX | 394 #endif // !OS_MACOSX |
OLD | NEW |