Webkit roll 143935:143980
[chromium-blink-merge.git] / base / cpu.h
blob65fda47950c9dae97dcd9a288d3d65c2affac79b
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
3 // found in the LICENSE file.
5 #ifndef BASE_CPU_H_
6 #define BASE_CPU_H_
8 #include <string>
10 #include "base/base_export.h"
12 namespace base {
14 // Query information about the processor.
15 class BASE_EXPORT CPU {
16 public:
17 // Constructor
18 CPU();
20 enum IntelMicroArchitecture {
21 PENTIUM,
22 SSE,
23 SSE2,
24 SSE3,
25 SSSE3,
26 SSE41,
27 SSE42,
28 AVX,
29 MAX_INTEL_MICRO_ARCHITECTURE
32 // Accessors for CPU information.
33 const std::string& vendor_name() const { return cpu_vendor_; }
34 int stepping() const { return stepping_; }
35 int model() const { return model_; }
36 int family() const { return family_; }
37 int type() const { return type_; }
38 int extended_model() const { return ext_model_; }
39 int extended_family() const { return ext_family_; }
40 bool has_mmx() const { return has_mmx_; }
41 bool has_sse() const { return has_sse_; }
42 bool has_sse2() const { return has_sse2_; }
43 bool has_sse3() const { return has_sse3_; }
44 bool has_ssse3() const { return has_ssse3_; }
45 bool has_sse41() const { return has_sse41_; }
46 bool has_sse42() const { return has_sse42_; }
47 bool has_avx() const { return has_avx_; }
48 IntelMicroArchitecture GetIntelMicroArchitecture() const;
49 const std::string& cpu_brand() const { return cpu_brand_; }
51 private:
52 // Query the processor for CPUID information.
53 void Initialize();
55 int type_; // process type
56 int family_; // family of the processor
57 int model_; // model of processor
58 int stepping_; // processor revision number
59 int ext_model_;
60 int ext_family_;
61 bool has_mmx_;
62 bool has_sse_;
63 bool has_sse2_;
64 bool has_sse3_;
65 bool has_ssse3_;
66 bool has_sse41_;
67 bool has_sse42_;
68 bool has_avx_;
69 std::string cpu_vendor_;
70 std::string cpu_brand_;
73 } // namespace base
75 #endif // BASE_CPU_H_