Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(81)

Side by Side Diff: webrtc/system_wrappers/source/cpu_info.cc

Issue 2578323005: Delete unused code from systeminfo. (Closed)
Patch Set: Delete systeminfo entirely Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « webrtc/media/base/videocapturer.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #include "webrtc/system_wrappers/include/cpu_info.h" 11 #include "webrtc/system_wrappers/include/cpu_info.h"
12 12
13 #include "webrtc/base/systeminfo.h" 13 #if defined(WEBRTC_WIN)
14 #include <winsock2.h>
15 #include <windows.h>
16 #ifndef EXCLUDE_D3D9
17 #include <d3d9.h>
18 #endif
19 #elif defined(WEBRTC_LINUX)
20 #include <unistd.h>
21 #endif
22 #if defined(WEBRTC_MAC)
23 #include <sys/sysctl.h>
24 #endif
25
26 #include "webrtc/base/logging.h"
27
28 namespace internal {
29 static int DetectNumberOfCores() {
30 // We fall back on assuming a single core in case of errors.
31 int number_of_cores = 1;
32
33 #if defined(WEBRTC_WIN)
34 SYSTEM_INFO si;
35 GetSystemInfo(&si);
36 number_of_cores = static_cast<int>(si.dwNumberOfProcessors);
37 #elif defined(WEBRTC_LINUX) || defined(WEBRTC_ANDROID)
38 number_of_cores = static_cast<int>(sysconf(_SC_NPROCESSORS_ONLN));
39 #elif defined(WEBRTC_MAC)
40 int name[] = {CTL_HW, HW_AVAILCPU};
41 size_t size = sizeof(number_of_cores);
42 if (0 != sysctl(name, 2, &number_of_cores, &size, NULL, 0)) {
43 LOG(LS_ERROR) << "Failed to get number of cores";
44 number_of_cores = 1;
45 }
46 #else
47 LOG(LS_ERROR) << "No function to get number of cores";
48 #endif
49
50 LOG(LS_INFO) << "Available number of cores: " << number_of_cores;
51
52 return number_of_cores;
53 }
54 }
14 55
15 namespace webrtc { 56 namespace webrtc {
16 57
17 uint32_t CpuInfo::DetectNumberOfCores() { 58 uint32_t CpuInfo::DetectNumberOfCores() {
18 return static_cast<uint32_t>(rtc::SystemInfo::GetMaxCpus()); 59 // Statically cache the number of system cores available since if the process
60 // is running in a sandbox, we may only be able to read the value once (before
61 // the sandbox is initialized) and not thereafter.
62 // For more information see crbug.com/176522.
63 static uint32_t logical_cpus = 0;
64 if (!logical_cpus)
65 logical_cpus = static_cast<uint32_t>(internal::DetectNumberOfCores());
66 return logical_cpus;
19 } 67 }
20 68
21 } // namespace webrtc 69 } // namespace webrtc
OLDNEW
« no previous file with comments | « webrtc/media/base/videocapturer.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698