llvm-project/clang/test/CodeGen/ms-annotation.c
Rafael Espindola 922f2aa9b2 Bring r325915 back.
The tests that failed on a windows host have been fixed.

Original message:

Start setting dso_local for COFF.

With this there are still some GVs where we don't set dso_local
because setGVProperties is never called. I intend to fix that in
followup commits. This is just the bare minimum to teach
shouldAssumeDSOLocal what it should do for COFF.

llvm-svn: 325940
2018-02-23 19:30:48 +00:00

27 lines
1.1 KiB
C

// RUN: %clang_cc1 -triple i686-windows %s -fms-extensions -emit-llvm -o - | FileCheck %s
//
// Test that LLVM optimizations leave these intrinsics alone, for the most part.
// RUN: %clang_cc1 -O2 -triple i686-windows %s -fms-extensions -emit-llvm -o - | FileCheck %s
void test1(void) {
__annotation(L"a1");
__annotation(L"a1", L"a2");
__annotation(L"a1", L"a2", L"a3");
__annotation(L"multi " L"part " L"string");
__annotation(L"unicode: \u0ca0_\u0ca0");
}
// CHECK-LABEL: define dso_local void @test1()
// CHECK: call void @llvm.codeview.annotation(metadata ![[A1:[0-9]+]])
// CHECK: call void @llvm.codeview.annotation(metadata ![[A2:[0-9]+]])
// CHECK: call void @llvm.codeview.annotation(metadata ![[A3:[0-9]+]])
// CHECK: call void @llvm.codeview.annotation(metadata ![[A4:[0-9]+]])
// CHECK: call void @llvm.codeview.annotation(metadata ![[A5:[0-9]+]])
// CHECK: ret void
// CHECK: ![[A1]] = !{!"a1"}
// CHECK: ![[A2]] = !{!"a1", !"a2"}
// CHECK: ![[A3]] = !{!"a1", !"a2", !"a3"}
// CHECK: ![[A4]] = !{!"multi part string"}
// CHECK: ![[A5]] = !{!"unicode: \E0\B2\A0_\E0\B2\A0"}