summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2008-04-23 20:21:29 +0000
committerDan Gohman <gohman@apple.com>2008-04-23 20:21:29 +0000
commitb418aafabf6a3199133346fd56379c776c4ea743 (patch)
tree8f33e869a9689f4a28814e694e315b4c74a48239 /llvm
parent8f83081fea05f1a421bd2545f5b1cdc8d4f4af8f (diff)
downloadbcm5719-llvm-b418aafabf6a3199133346fd56379c776c4ea743.tar.gz
bcm5719-llvm-b418aafabf6a3199133346fd56379c776c4ea743.zip
Add support to codegen for getresult instructions with undef operands.
llvm-svn: 50180
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp9
-rw-r--r--llvm/test/CodeGen/Generic/getresult-undef.ll6
2 files changed, 13 insertions, 2 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
index c9b334fc22c..7e7a2f41193 100644
--- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
@@ -3311,8 +3311,13 @@ void SelectionDAGLowering::visitCall(CallInst &I) {
void SelectionDAGLowering::visitGetResult(GetResultInst &I) {
- SDOperand Call = getValue(I.getOperand(0));
- setValue(&I, SDOperand(Call.Val, I.getIndex()));
+ if (UndefValue *UV = dyn_cast<UndefValue>(I.getOperand(0))) {
+ SDOperand Undef = DAG.getNode(ISD::UNDEF, TLI.getValueType(I.getType()));
+ setValue(&I, Undef);
+ } else {
+ SDOperand Call = getValue(I.getOperand(0));
+ setValue(&I, SDOperand(Call.Val, I.getIndex()));
+ }
}
diff --git a/llvm/test/CodeGen/Generic/getresult-undef.ll b/llvm/test/CodeGen/Generic/getresult-undef.ll
new file mode 100644
index 00000000000..7905ff52ef6
--- /dev/null
+++ b/llvm/test/CodeGen/Generic/getresult-undef.ll
@@ -0,0 +1,6 @@
+; RUN: llvm-as < %s | llc
+
+define double @foo() {
+ %t = getresult {double, double} undef, 1
+ ret double %t
+}
OpenPOWER on IntegriCloud