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.
17 lines
405 B
C
17 lines
405 B
C
// RUN: %clang_cc1 -triple x86_64-apple-macosx10.9.0 -emit-llvm -O1 -mdisable-tail-calls -o - < %s | FileCheck %s
|
|
|
|
typedef struct List {
|
|
struct List *next;
|
|
int data;
|
|
} List;
|
|
|
|
// CHECK-LABEL: define{{.*}} %struct.List* @find
|
|
List *find(List *head, int data) {
|
|
if (!head)
|
|
return 0;
|
|
if (head->data == data)
|
|
return head;
|
|
// CHECK: call %struct.List* @find
|
|
return find(head->next, data);
|
|
}
|