summaryrefslogtreecommitdiffstats
path: root/clang/test/CodeGen/ms-inline-asm-align.c
diff options
context:
space:
mode:
authorReid Kleckner <rnk@google.com>2015-10-27 17:34:29 +0000
committerReid Kleckner <rnk@google.com>2015-10-27 17:34:29 +0000
commit012f1acca7b63e408bab14cc21ad73c54e2dca08 (patch)
tree2b572536641c0744b33b1c4c5af7832e85a964e3 /clang/test/CodeGen/ms-inline-asm-align.c
parentfb1c1c7e4dad1010f786004205c5770e2cb8569b (diff)
downloadbcm5719-llvm-012f1acca7b63e408bab14cc21ad73c54e2dca08.tar.gz
bcm5719-llvm-012f1acca7b63e408bab14cc21ad73c54e2dca08.zip
[ms-inline-asm] Test case for alignment directive change in LLVM r251418
llvm-svn: 251419
Diffstat (limited to 'clang/test/CodeGen/ms-inline-asm-align.c')
-rw-r--r--clang/test/CodeGen/ms-inline-asm-align.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/clang/test/CodeGen/ms-inline-asm-align.c b/clang/test/CodeGen/ms-inline-asm-align.c
new file mode 100644
index 00000000000..de896b8e60d
--- /dev/null
+++ b/clang/test/CodeGen/ms-inline-asm-align.c
@@ -0,0 +1,30 @@
+// REQUIRES: x86-registered-target
+// RUN: %clang_cc1 %s -triple i386-apple-darwin10 -fasm-blocks -emit-llvm -o - | FileCheck %s --check-prefix=DARWIN
+// RUN: %clang_cc1 %s -triple i686-pc-win32 -fasm-blocks -emit-llvm -o - | FileCheck %s --check-prefix=WINDOWS
+
+// On Windows, .align is in bytes, and on Darwin, .align is in log2 form. The
+// Intel inline assembly parser should rewrite to the appropriate form depending
+// on the platform.
+
+void align_test() {
+ __asm align 8
+ __asm align 16;
+ __asm align 128;
+ __asm ALIGN 256;
+}
+
+// DARWIN-LABEL: define void @align_test()
+// DARWIN: call void asm sideeffect inteldialect
+// DARWIN-SAME: .align 3
+// DARWIN-SAME: .align 4
+// DARWIN-SAME: .align 7
+// DARWIN-SAME: .align 8
+// DARWIN-SAME: "~{dirflag},~{fpsr},~{flags}"()
+
+// WINDOWS-LABEL: define void @align_test()
+// WINDOWS: call void asm sideeffect inteldialect
+// WINDOWS-SAME: .align 8
+// WINDOWS-SAME: .align 16
+// WINDOWS-SAME: .align 128
+// WINDOWS-SAME: .align 256
+// WINDOWS-SAME: "~{dirflag},~{fpsr},~{flags}"()
OpenPOWER on IntegriCloud