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

Side by Side Diff: extensions/browser/api/system_cpu/cpu_info_provider.cc

Issue 389633002: Move system.* family of APIs to extensions/ (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebased Created 6 years, 3 months 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
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/extensions/api/system_cpu/cpu_info_provider.h" 5 #include "extensions/browser/api/system_cpu/cpu_info_provider.h"
6 6
7 #include "base/sys_info.h" 7 #include "base/sys_info.h"
8 8
9 namespace extensions { 9 namespace extensions {
10 10
11 using api::system_cpu::CpuInfo; 11 using core_api::system_cpu::CpuInfo;
12 12
13 // Static member intialization. 13 // Static member intialization.
14 base::LazyInstance<scoped_refptr<CpuInfoProvider> > 14 base::LazyInstance<scoped_refptr<CpuInfoProvider> > CpuInfoProvider::provider_ =
15 CpuInfoProvider::provider_ = LAZY_INSTANCE_INITIALIZER; 15 LAZY_INSTANCE_INITIALIZER;
16 16
17 CpuInfoProvider::CpuInfoProvider() {} 17 CpuInfoProvider::CpuInfoProvider() {
18 }
18 19
19 CpuInfoProvider::~CpuInfoProvider() {} 20 CpuInfoProvider::~CpuInfoProvider() {
20
21 const CpuInfo& CpuInfoProvider::cpu_info() const {
22 return info_;
23 } 21 }
24 22
25 void CpuInfoProvider::InitializeForTesting( 23 void CpuInfoProvider::InitializeForTesting(
26 scoped_refptr<CpuInfoProvider> provider) { 24 scoped_refptr<CpuInfoProvider> provider) {
27 DCHECK(provider.get() != NULL); 25 DCHECK(provider.get() != NULL);
28 provider_.Get() = provider; 26 provider_.Get() = provider;
29 } 27 }
30 28
31 bool CpuInfoProvider::QueryInfo() { 29 bool CpuInfoProvider::QueryInfo() {
32 info_.num_of_processors = base::SysInfo::NumberOfProcessors(); 30 info_.num_of_processors = base::SysInfo::NumberOfProcessors();
33 info_.arch_name = base::SysInfo::OperatingSystemArchitecture(); 31 info_.arch_name = base::SysInfo::OperatingSystemArchitecture();
34 info_.model_name = base::SysInfo::CPUModelName(); 32 info_.model_name = base::SysInfo::CPUModelName();
35 info_.features = GetFeatures(); 33 info_.features = GetFeatures();
36 34
37 info_.processors.clear(); 35 info_.processors.clear();
38 // Fill in the correct number of uninitialized ProcessorInfos. 36 // Fill in the correct number of uninitialized ProcessorInfos.
39 for (int i = 0; i < info_.num_of_processors; ++i) { 37 for (int i = 0; i < info_.num_of_processors; ++i) {
40 info_.processors.push_back(linked_ptr<api::system_cpu::ProcessorInfo>( 38 info_.processors.push_back(linked_ptr<core_api::system_cpu::ProcessorInfo>(
41 new api::system_cpu::ProcessorInfo())); 39 new core_api::system_cpu::ProcessorInfo()));
42 } 40 }
43 // Initialize the ProcessorInfos, or return an empty array if that fails. 41 // Initialize the ProcessorInfos, or return an empty array if that fails.
44 if (!QueryCpuTimePerProcessor(&info_.processors)) 42 if (!QueryCpuTimePerProcessor(&info_.processors))
45 info_.processors.clear(); 43 info_.processors.clear();
46 return true; 44 return true;
47 } 45 }
48 46
49 std::vector<std::string> CpuInfoProvider::GetFeatures() const { 47 std::vector<std::string> CpuInfoProvider::GetFeatures() const {
50 std::vector<std::string> features; 48 std::vector<std::string> features;
51 // These are the feature codes used by /proc/cpuinfo on Linux. 49 // These are the feature codes used by /proc/cpuinfo on Linux.
52 if (cpu_.has_mmx()) features.push_back("mmx"); 50 if (cpu_.has_mmx())
53 if (cpu_.has_sse()) features.push_back("sse"); 51 features.push_back("mmx");
54 if (cpu_.has_sse2()) features.push_back("sse2"); 52 if (cpu_.has_sse())
55 if (cpu_.has_sse3()) features.push_back("sse3"); 53 features.push_back("sse");
56 if (cpu_.has_ssse3()) features.push_back("ssse3"); 54 if (cpu_.has_sse2())
57 if (cpu_.has_sse41()) features.push_back("sse4_1"); 55 features.push_back("sse2");
58 if (cpu_.has_sse42()) features.push_back("sse4_2"); 56 if (cpu_.has_sse3())
59 if (cpu_.has_avx()) features.push_back("avx"); 57 features.push_back("sse3");
58 if (cpu_.has_ssse3())
59 features.push_back("ssse3");
60 if (cpu_.has_sse41())
61 features.push_back("sse4_1");
62 if (cpu_.has_sse42())
63 features.push_back("sse4_2");
64 if (cpu_.has_avx())
65 features.push_back("avx");
60 return features; 66 return features;
61 } 67 }
62 68
63 // static 69 // static
64 CpuInfoProvider* CpuInfoProvider::Get() { 70 CpuInfoProvider* CpuInfoProvider::Get() {
65 if (provider_.Get().get() == NULL) 71 if (provider_.Get().get() == NULL)
66 provider_.Get() = new CpuInfoProvider(); 72 provider_.Get() = new CpuInfoProvider();
67 return provider_.Get().get(); 73 return provider_.Get().get();
68 } 74 }
69 75
70 } // namespace extensions 76 } // namespace extensions
OLDNEW
« no previous file with comments | « extensions/browser/api/system_cpu/cpu_info_provider.h ('k') | extensions/browser/api/system_cpu/cpu_info_provider_linux.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698