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