xref: /aosp_15_r20/external/swiftshader/src/System/CPUID.hpp (revision 03ce13f70fcc45d86ee91b7ee4cab1936a95046e)
1*03ce13f7SAndroid Build Coastguard Worker // Copyright 2016 The SwiftShader Authors. All Rights Reserved.
2*03ce13f7SAndroid Build Coastguard Worker //
3*03ce13f7SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License");
4*03ce13f7SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License.
5*03ce13f7SAndroid Build Coastguard Worker // You may obtain a copy of the License at
6*03ce13f7SAndroid Build Coastguard Worker //
7*03ce13f7SAndroid Build Coastguard Worker //    http://www.apache.org/licenses/LICENSE-2.0
8*03ce13f7SAndroid Build Coastguard Worker //
9*03ce13f7SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*03ce13f7SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
11*03ce13f7SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*03ce13f7SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
13*03ce13f7SAndroid Build Coastguard Worker // limitations under the License.
14*03ce13f7SAndroid Build Coastguard Worker 
15*03ce13f7SAndroid Build Coastguard Worker #ifndef sw_CPUID_hpp
16*03ce13f7SAndroid Build Coastguard Worker #define sw_CPUID_hpp
17*03ce13f7SAndroid Build Coastguard Worker 
18*03ce13f7SAndroid Build Coastguard Worker namespace sw {
19*03ce13f7SAndroid Build Coastguard Worker 
20*03ce13f7SAndroid Build Coastguard Worker #if !defined(__i386__) && defined(_M_IX86)
21*03ce13f7SAndroid Build Coastguard Worker #	define __i386__ 1
22*03ce13f7SAndroid Build Coastguard Worker #endif
23*03ce13f7SAndroid Build Coastguard Worker 
24*03ce13f7SAndroid Build Coastguard Worker #if !defined(__x86_64__) && (defined(_M_AMD64) || defined(_M_X64))
25*03ce13f7SAndroid Build Coastguard Worker #	define __x86_64__ 1
26*03ce13f7SAndroid Build Coastguard Worker #endif
27*03ce13f7SAndroid Build Coastguard Worker 
28*03ce13f7SAndroid Build Coastguard Worker class CPUID
29*03ce13f7SAndroid Build Coastguard Worker {
30*03ce13f7SAndroid Build Coastguard Worker public:
31*03ce13f7SAndroid Build Coastguard Worker 	static bool supportsMMX();
32*03ce13f7SAndroid Build Coastguard Worker 	static bool supportsCMOV();
33*03ce13f7SAndroid Build Coastguard Worker 	static bool supportsMMX2();  // MMX instructions added by SSE: pshufw, pmulhuw, pmovmskb, pavgw/b, pextrw, pinsrw, pmaxsw/ub, etc.
34*03ce13f7SAndroid Build Coastguard Worker 	static bool supportsSSE();
35*03ce13f7SAndroid Build Coastguard Worker 	static bool supportsSSE2();
36*03ce13f7SAndroid Build Coastguard Worker 	static bool supportsSSE3();
37*03ce13f7SAndroid Build Coastguard Worker 	static bool supportsSSSE3();
38*03ce13f7SAndroid Build Coastguard Worker 	static bool supportsSSE4_1();
39*03ce13f7SAndroid Build Coastguard Worker 	static int coreCount();
40*03ce13f7SAndroid Build Coastguard Worker 	static int processAffinity();
41*03ce13f7SAndroid Build Coastguard Worker 
42*03ce13f7SAndroid Build Coastguard Worker 	static void setFlushToZero(bool enable);       // Denormal results are written as zero
43*03ce13f7SAndroid Build Coastguard Worker 	static void setDenormalsAreZero(bool enable);  // Denormal inputs are read as zero
44*03ce13f7SAndroid Build Coastguard Worker };
45*03ce13f7SAndroid Build Coastguard Worker 
46*03ce13f7SAndroid Build Coastguard Worker }  // namespace sw
47*03ce13f7SAndroid Build Coastguard Worker 
48*03ce13f7SAndroid Build Coastguard Worker #endif  // sw_CPUID_hpp
49