From 3dc34f682dfdfbf75c2b883e21a953d41df4f3a0 Mon Sep 17 00:00:00 2001 From: Dan Gohman Date: Wed, 23 Apr 2008 20:21:29 +0000 Subject: [PATCH] Add support to codegen for getresult instructions with undef operands. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@50180 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp | 9 +++++++-- test/CodeGen/Generic/getresult-undef.ll | 6 ++++++ 2 files changed, 13 insertions(+), 2 deletions(-) create mode 100644 test/CodeGen/Generic/getresult-undef.ll diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp index c9b334fc22c..7e7a2f41193 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp +++ b/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(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/test/CodeGen/Generic/getresult-undef.ll b/test/CodeGen/Generic/getresult-undef.ll new file mode 100644 index 00000000000..7905ff52ef6 --- /dev/null +++ b/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 +}