mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-29 18:36:06 +00:00

This matches the implementation of the gcc support for the same feature, including checking the values set up by libgcc at runtime. The structure looks like this: unsigned int __cpu_vendor; unsigned int __cpu_type; unsigned int __cpu_subtype; unsigned int __cpu_features[1]; with a set of enums to match various fields that are field out after parsing the output of the cpuid instruction. This also adds a set of errors checking for valid input (and cpu). compiler-rt support for this and the other builtins in this family (__builtin_cpu_init and __builtin_cpu_is) are forthcoming. llvm-svn: 240994
22 lines
564 B
C
22 lines
564 B
C
// RUN: %clang_cc1 -fsyntax-only -triple x86_64-pc-linux-gnu -verify %s
|
|
// RUN: %clang_cc1 -fsyntax-only -triple powerpc64le-linux-gnu -verify %s
|
|
|
|
extern void a(const char *);
|
|
|
|
extern const char *str;
|
|
|
|
int main() {
|
|
#ifdef __x86_64__
|
|
if (__builtin_cpu_supports("ss")) // expected-error {{invalid cpu feature string}}
|
|
a("sse4.2");
|
|
|
|
if (__builtin_cpu_supports(str)) // expected-error {{expression is not a string literal}}
|
|
a(str);
|
|
#else
|
|
if (__builtin_cpu_supports("vsx")) // expected-error {{use of unknown builtin}}
|
|
a("vsx");
|
|
#endif
|
|
|
|
return 0;
|
|
}
|