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

Unified 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « webrtc/media/base/videocapturer.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: webrtc/system_wrappers/source/cpu_info.cc
diff --git a/webrtc/system_wrappers/source/cpu_info.cc b/webrtc/system_wrappers/source/cpu_info.cc
index 40231b65afcabf3c356b954a739b71b38f8674be..4a61c7a6f3a00e9fdaf4af4235fb7fce4e98b7de 100644
--- a/webrtc/system_wrappers/source/cpu_info.cc
+++ b/webrtc/system_wrappers/source/cpu_info.cc
@@ -10,12 +10,60 @@
#include "webrtc/system_wrappers/include/cpu_info.h"
-#include "webrtc/base/systeminfo.h"
+#if defined(WEBRTC_WIN)
+#include <winsock2.h>
+#include <windows.h>
+#ifndef EXCLUDE_D3D9
+#include <d3d9.h>
+#endif
+#elif defined(WEBRTC_LINUX)
+#include <unistd.h>
+#endif
+#if defined(WEBRTC_MAC)
+#include <sys/sysctl.h>
+#endif
+
+#include "webrtc/base/logging.h"
+
+namespace internal {
+static int DetectNumberOfCores() {
+ // We fall back on assuming a single core in case of errors.
+ int number_of_cores = 1;
+
+#if defined(WEBRTC_WIN)
+ SYSTEM_INFO si;
+ GetSystemInfo(&si);
+ number_of_cores = static_cast<int>(si.dwNumberOfProcessors);
+#elif defined(WEBRTC_LINUX) || defined(WEBRTC_ANDROID)
+ number_of_cores = static_cast<int>(sysconf(_SC_NPROCESSORS_ONLN));
+#elif defined(WEBRTC_MAC)
+ int name[] = {CTL_HW, HW_AVAILCPU};
+ size_t size = sizeof(number_of_cores);
+ if (0 != sysctl(name, 2, &number_of_cores, &size, NULL, 0)) {
+ LOG(LS_ERROR) << "Failed to get number of cores";
+ number_of_cores = 1;
+ }
+#else
+ LOG(LS_ERROR) << "No function to get number of cores";
+#endif
+
+ LOG(LS_INFO) << "Available number of cores: " << number_of_cores;
+
+ return number_of_cores;
+}
+}
namespace webrtc {
uint32_t CpuInfo::DetectNumberOfCores() {
- return static_cast<uint32_t>(rtc::SystemInfo::GetMaxCpus());
+ // Statically cache the number of system cores available since if the process
+ // is running in a sandbox, we may only be able to read the value once (before
+ // the sandbox is initialized) and not thereafter.
+ // For more information see crbug.com/176522.
+ static uint32_t logical_cpus = 0;
+ if (!logical_cpus)
+ logical_cpus = static_cast<uint32_t>(internal::DetectNumberOfCores());
+ return logical_cpus;
}
} // namespace webrtc
« 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