[all-commits] [llvm/llvm-project] 28cb62: Change some addUsedGlobal to addUsedOrCompilerUsed...
Fangrui Song via All-commits
all-commits at lists.llvm.org
Fri Feb 26 10:42:25 PST 2021
Branch: refs/heads/main
Home: https://github.com/llvm/llvm-project
Commit: 28cb620321f5461255423f84c85e6891b5174c13
https://github.com/llvm/llvm-project/commit/28cb620321f5461255423f84c85e6891b5174c13
Author: Fangrui Song <i at maskray.me>
Date: 2021-02-26 (Fri, 26 Feb 2021)
Changed paths:
M clang/lib/CodeGen/CGDecl.cpp
M clang/lib/CodeGen/CodeGenModule.cpp
M clang/lib/CodeGen/CodeGenModule.h
M clang/test/CodeGen/2005-12-04-AttributeUsed.c
M clang/test/CodeGen/attr-msp430.c
M clang/test/CodeGen/attr-target-mv.c
M clang/test/CodeGen/attr-used.c
M clang/test/CodeGen/attr-x86-interrupt.c
M clang/test/CodeGen/keep-static-consts.cpp
M clang/test/CodeGenCUDA/llvm-used.cu
M clang/test/CodeGenCXX/attr-x86-interrupt.cpp
M clang/test/CodeGenCXX/extern-c.cpp
Log Message:
-----------
Change some addUsedGlobal to addUsedOrCompilerUsedGlobal
An global value in the `llvm.used` list does not have GC root semantics on ELF targets.
This will be changed in a subsequent backend patch.
Change some `llvm.used` in the ELF code path to use `llvm.compiler.used` to
prevent undesired GC root semantics.
Change one extern "C" alias (due to `__attribute__((used))` in extern "C") to use `llvm.compiler.used` on all targets.
GNU ld has a rule "`__start_/__stop_` references from a live input section retain the associated C identifier name sections",
which LLD may drop entirely (currently refined to exclude SHF_LINK_ORDER/SHF_GROUP) in a future release (the rule makes it clumsy to GC metadata sections; D96914 added a way to try the potential future behavior).
For `llvm.used` global values defined in a C identifier name section, keep using `llvm.used` so that
the future LLD change will not affect them.
rnk kindly categorized the changes:
```
ObjC/blocks: this wants GC root semantics, since ObjC mainly runs on Mac.
MS C++ ABI stuff: wants GC root semantics, no change
OpenMP: unsure, but GC root semantics probably don't hurt
CodeGenModule: affected in this patch to *not* use GC root semantics so that __attribute__((used)) behavior remains the same on ELF, plus two other minor use cases that don't want GC semantics
Coverage: Probably want GC root semantics
CGExpr.cpp: refers to LTO, wants GC root
CGDeclCXX.cpp: one is MS ABI specific, so yes GC root, one is some other C++ init functionality, which should form GC roots (C++ initializers can have side effects and must run)
CGDecl.cpp: Changed in this patch for __attribute__((used))
```
Differential Revision: https://reviews.llvm.org/D97446
More information about the All-commits
mailing list