summaryrefslogtreecommitdiffstats
path: root/test/CodeGen/nvptx-inlineasm.c
diff options
context:
space:
mode:
authordim <dim@FreeBSD.org>2012-08-15 20:02:54 +0000
committerdim <dim@FreeBSD.org>2012-08-15 20:02:54 +0000
commit554bcb69c2d785a011a30e7db87a36a87fe7db10 (patch)
tree9abb1a658a297776086f4e0dfa6ca533de02104e /test/CodeGen/nvptx-inlineasm.c
parentbb67ca86b31f67faee50bd10c3b036d65751745a (diff)
downloadFreeBSD-src-554bcb69c2d785a011a30e7db87a36a87fe7db10.zip
FreeBSD-src-554bcb69c2d785a011a30e7db87a36a87fe7db10.tar.gz
Vendor import of clang trunk r161861:
http://llvm.org/svn/llvm-project/cfe/trunk@161861
Diffstat (limited to 'test/CodeGen/nvptx-inlineasm.c')
-rw-r--r--test/CodeGen/nvptx-inlineasm.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/test/CodeGen/nvptx-inlineasm.c b/test/CodeGen/nvptx-inlineasm.c
new file mode 100644
index 0000000..860b50f
--- /dev/null
+++ b/test/CodeGen/nvptx-inlineasm.c
@@ -0,0 +1,15 @@
+// RUN: %clang_cc1 -triple nvptx-unknown-unknown -O3 -S -o - %s -emit-llvm | FileCheck %s
+// RUN: %clang_cc1 -triple nvptx64-unknown-unknown -O3 -S -o - %s -emit-llvm | FileCheck %s
+
+int bar(int a) {
+ int result;
+ // CHECK: call i32 asm sideeffect "{ {{.*}}
+ asm __volatile__ ("{ \n\t"
+ ".reg .pred \t%%p1; \n\t"
+ ".reg .pred \t%%p2; \n\t"
+ "setp.ne.u32 \t%%p1, %1, 0; \n\t"
+ "vote.any.pred \t%%p2, %%p1; \n\t"
+ "selp.s32 \t%0, 1, 0, %%p2; \n\t"
+ "}" : "=r"(result) : "r"(a));
+ return result;
+}
OpenPOWER on IntegriCloud