-
Notifications
You must be signed in to change notification settings - Fork 12.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[clang] Add per-global code model attribute (#72078)
This patch adds a per-global code model attribute, which can override the target's code model to access global variables. Currently, the code model attribute is only supported on LoongArch. This patch also maps GCC's code model names to LLVM's, which allows for better compatibility between the two compilers. Suggested-by: Arthur Eubanks <[email protected]> Link: https://discourse.llvm.org/t/how-to-best-implement-code-model-overriding-for-certain-values/71816 Link: https://discourse.llvm.org/t/rfc-add-per-global-code-model-attribute/74944 --------- Signed-off-by: WANG Rui <[email protected]>
- Loading branch information
Showing
8 changed files
with
148 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
// RUN: %clang_cc1 -emit-llvm -triple loongarch64 %s -o - | FileCheck %s | ||
|
||
// CHECK: @_ZL2v1 ={{.*}} global i32 0, code_model "small" | ||
static int v1 __attribute__((model("normal"))); | ||
|
||
void use1() { | ||
v1 = 1; | ||
} | ||
|
||
// CHECK: @v2 ={{.*}} global i32 0, code_model "medium" | ||
int v2 __attribute__((model("medium"))); | ||
|
||
// CHECK: @v3 ={{.*}} global float 0.000000e+00, code_model "large" | ||
float v3 __attribute__((model("extreme"))); | ||
|
||
// CHECK: @_ZL2v4IiE ={{.*}} global i32 0, code_model "medium" | ||
template <typename T> | ||
static T v4 __attribute__((model("medium"))); | ||
|
||
void use2() { | ||
v4<int> = 1; | ||
} | ||
|
||
struct S { | ||
double d; | ||
}; | ||
|
||
// CHECK: @v5 ={{.*}} global {{.*}}, code_model "medium" | ||
S v5 __attribute__((model("medium"))); | ||
|
||
typedef void (*F)(); | ||
|
||
// CHECK: @v6 ={{.*}} global ptr null, code_model "large" | ||
F v6 __attribute__((model("extreme"))); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
// RUN: %clang_cc1 -triple aarch64 -verify=expected,aarch64 -fsyntax-only %s | ||
// RUN: %clang_cc1 -triple loongarch64 -verify=expected,loongarch64 -fsyntax-only %s | ||
// RUN: %clang_cc1 -triple mips64 -verify=expected,mips64 -fsyntax-only %s | ||
// RUN: %clang_cc1 -triple powerpc64 -verify=expected,powerpc64 -fsyntax-only %s | ||
// RUN: %clang_cc1 -triple riscv64 -verify=expected,riscv64 -fsyntax-only %s | ||
// RUN: %clang_cc1 -triple x86_64 -verify=expected,x86_64 -fsyntax-only %s | ||
|
||
#if defined(__loongarch__) && !__has_attribute(model) | ||
#error "Should support model attribute" | ||
#endif | ||
|
||
int a __attribute((model("tiny"))); // aarch64-warning {{unknown attribute 'model' ignored}} \ | ||
// loongarch64-error {{code model 'tiny' is not supported on this target}} \ | ||
// mips64-warning {{unknown attribute 'model' ignored}} \ | ||
// powerpc64-warning {{unknown attribute 'model' ignored}} \ | ||
// riscv64-warning {{unknown attribute 'model' ignored}} \ | ||
// x86_64-warning {{unknown attribute 'model' ignored}} | ||
int b __attribute((model("small"))); // aarch64-warning {{unknown attribute 'model' ignored}} \ | ||
// loongarch64-error {{code model 'small' is not supported on this target}} \ | ||
// mips64-warning {{unknown attribute 'model' ignored}} \ | ||
// powerpc64-warning {{unknown attribute 'model' ignored}} \ | ||
// riscv64-warning {{unknown attribute 'model' ignored}} \ | ||
// x86_64-warning {{unknown attribute 'model' ignored}} | ||
int c __attribute((model("normal"))); // aarch64-warning {{unknown attribute 'model' ignored}} \ | ||
// mips64-warning {{unknown attribute 'model' ignored}} \ | ||
// powerpc64-warning {{unknown attribute 'model' ignored}} \ | ||
// riscv64-warning {{unknown attribute 'model' ignored}} \ | ||
// x86_64-warning {{unknown attribute 'model' ignored}} | ||
int d __attribute((model("kernel"))); // aarch64-warning {{unknown attribute 'model' ignored}} \ | ||
// loongarch64-error {{code model 'kernel' is not supported on this target}} \ | ||
// mips64-warning {{unknown attribute 'model' ignored}} \ | ||
// powerpc64-warning {{unknown attribute 'model' ignored}} \ | ||
// riscv64-warning {{unknown attribute 'model' ignored}} \ | ||
// x86_64-warning {{unknown attribute 'model' ignored}} | ||
int e __attribute((model("medium"))); // aarch64-warning {{unknown attribute 'model' ignored}} \ | ||
// mips64-warning {{unknown attribute 'model' ignored}} \ | ||
// powerpc64-warning {{unknown attribute 'model' ignored}} \ | ||
// riscv64-warning {{unknown attribute 'model' ignored}} \ | ||
// x86_64-warning {{unknown attribute 'model' ignored}} | ||
int f __attribute((model("large"))); // aarch64-warning {{unknown attribute 'model' ignored}} \ | ||
// loongarch64-error {{code model 'large' is not supported on this target}} \ | ||
// mips64-warning {{unknown attribute 'model' ignored}} \ | ||
// powerpc64-warning {{unknown attribute 'model' ignored}} \ | ||
// riscv64-warning {{unknown attribute 'model' ignored}} \ | ||
// x86_64-warning {{unknown attribute 'model' ignored}} | ||
int g __attribute((model("extreme"))); // aarch64-warning {{unknown attribute 'model' ignored}} \ | ||
// mips64-warning {{unknown attribute 'model' ignored}} \ | ||
// powerpc64-warning {{unknown attribute 'model' ignored}} \ | ||
// riscv64-warning {{unknown attribute 'model' ignored}} \ | ||
// x86_64-warning {{unknown attribute 'model' ignored}} | ||
|
||
void __attribute((model("extreme"))) h() {} // aarch64-warning {{unknown attribute 'model' ignored}} \ | ||
// loongarch64-error {{'model' attribute only applies to non-TLS global variables}} \ | ||
// mips64-warning {{unknown attribute 'model' ignored}} \ | ||
// powerpc64-warning {{unknown attribute 'model' ignored}} \ | ||
// riscv64-warning {{unknown attribute 'model' ignored}} \ | ||
// x86_64-warning {{unknown attribute 'model' ignored}} | ||
|
||
thread_local int i __attribute((model("extreme"))); // aarch64-warning {{unknown attribute 'model' ignored}} \ | ||
// loongarch64-error {{'model' attribute only applies to non-TLS global variables}} \ | ||
// mips64-warning {{unknown attribute 'model' ignored}} \ | ||
// powerpc64-warning {{unknown attribute 'model' ignored}} \ | ||
// riscv64-warning {{unknown attribute 'model' ignored}} \ | ||
// x86_64-warning {{unknown attribute 'model' ignored}} |