For a definition (of most linkage types), dso_local is set for ELF -fno-pic/-fpie
and COFF, but not for Mach-O. This nuance causes unneeded binary format differences.
This patch replaces (function) `define ` with `define{{.*}} `,
(variable/constant/alias) `= ` with `={{.*}} `, or inserts appropriate `{{.*}} `
if there is an explicit linkage.
* Clang will set dso_local for Mach-O, which is currently implied by TargetMachine.cpp. This will make COFF/Mach-O and executable ELF similar.
* Eventually I hope we can make dso_local the textual LLVM IR default (write explicit "dso_preemptable" when applicable) and -fpic ELF will be similar to everything else. This patch helps move toward that goal.
12 lines
275 B
C
12 lines
275 B
C
// RUN: %clang_cc1 -triple x86_64-apple-darwin %s -emit-llvm -O1 -relaxed-aliasing -o - | FileCheck %s
|
|
|
|
enum e1 {e1_a = -1 };
|
|
enum e1 g1(enum e1 *x) {
|
|
return *x;
|
|
}
|
|
|
|
// CHECK-LABEL: define{{.*}} i32 @g1
|
|
// CHECK: load i32, i32* %x, align 4
|
|
// CHECK-NOT: range
|
|
// CHECK: ret
|