diff options
Diffstat (limited to 'test/CodeGen/ms-inline-asm-align.c')
-rw-r--r-- | test/CodeGen/ms-inline-asm-align.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/test/CodeGen/ms-inline-asm-align.c b/test/CodeGen/ms-inline-asm-align.c new file mode 100644 index 0000000..de896b8 --- /dev/null +++ b/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}"() |