summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/CodeExtractor/X86
diff options
context:
space:
mode:
authorSean Silva <chisophugis@gmail.com>2016-08-01 03:22:05 +0000
committerSean Silva <chisophugis@gmail.com>2016-08-01 03:22:05 +0000
commite5a5c966cd773c41f0b36ff6d4aa5e972f273ac5 (patch)
treebf22c554ad4ff76a73530e8669a6bfa71f7370cd /llvm/test/Transforms/CodeExtractor/X86
parenta0a802abe3eafe698d1304c4e8b187ab85fa3942 (diff)
downloadbcm5719-llvm-e5a5c966cd773c41f0b36ff6d4aa5e972f273ac5.tar.gz
bcm5719-llvm-e5a5c966cd773c41f0b36ff6d4aa5e972f273ac5.zip
Move this test to x86-specific directory.
No bots have yelled yet, but this test references an x86 intrinsic. Also, it invokes llc on x86 IR. Fixup to r277315. llvm-svn: 277316
Diffstat (limited to 'llvm/test/Transforms/CodeExtractor/X86')
-rw-r--r--llvm/test/Transforms/CodeExtractor/X86/InheritTargetAttributes.ll40
-rw-r--r--llvm/test/Transforms/CodeExtractor/X86/lit.local.cfg3
2 files changed, 43 insertions, 0 deletions
diff --git a/llvm/test/Transforms/CodeExtractor/X86/InheritTargetAttributes.ll b/llvm/test/Transforms/CodeExtractor/X86/InheritTargetAttributes.ll
new file mode 100644
index 00000000000..41d883c8c37
--- /dev/null
+++ b/llvm/test/Transforms/CodeExtractor/X86/InheritTargetAttributes.ll
@@ -0,0 +1,40 @@
+; RUN: opt < %s -partial-inliner | llc -filetype=null
+; RUN: opt < %s -partial-inliner -S | FileCheck %s
+; This testcase checks to see if CodeExtractor properly inherits
+; target specific attributes for the extracted function. This can
+; cause certain instructions that depend on the attributes to not
+; be lowered. Like in this test where we try to 'select' the blendvps
+; intrinsic on x86 that requires the +sse4.1 target feature.
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+; Function Attrs: nounwind readnone
+declare <4 x float> @llvm.x86.sse41.blendvps(<4 x float>, <4 x float>, <4 x float>) #0
+
+; Function Attrs: nounwind uwtable
+define <4 x float> @inlinedFunc(i1, <4 x float>, <4 x float>, <4 x float>) #1 {
+entry:
+ br i1 %0, label %if.then, label %return
+if.then:
+; Target intrinsic that requires sse4.1
+ %target.call = call <4 x float> @llvm.x86.sse41.blendvps(<4 x float> %1, <4 x float> %2, <4 x float> %3)
+ br label %return
+return: ; preds = %entry
+ %retval = phi <4 x float> [ zeroinitializer, %entry ], [ %target.call, %if.then ]
+ ret <4 x float> %retval
+}
+
+; Function Attrs: nounwind uwtable
+define <4 x float> @dummyCaller(i1, <4 x float>, <4 x float>, <4 x float>) #1 {
+entry:
+ %val = call <4 x float> @inlinedFunc(i1 %0, <4 x float> %1, <4 x float> %2, <4 x float> %3)
+ ret <4 x float> %val
+}
+
+
+attributes #0 = { nounwind readnone }
+attributes #1 = { nounwind uwtable "target-cpu"="x86-64" "target-features"="+sse4.1" }
+
+; CHECK: define {{.*}} @inlinedFunc.1_if.then{{.*}} [[COUNT1:#[0-9]+]]
+; CHECK: [[COUNT1]] = { {{.*}} "target-cpu"="x86-64" "target-features"="+sse4.1" }
diff --git a/llvm/test/Transforms/CodeExtractor/X86/lit.local.cfg b/llvm/test/Transforms/CodeExtractor/X86/lit.local.cfg
new file mode 100644
index 00000000000..e71f3cc4c41
--- /dev/null
+++ b/llvm/test/Transforms/CodeExtractor/X86/lit.local.cfg
@@ -0,0 +1,3 @@
+if not 'X86' in config.root.targets:
+ config.unsupported = True
+
OpenPOWER on IntegriCloud