Fix a crash I introduced into the IA64 backend with my copyfromreg change.
authorChris Lattner <sabre@nondot.org>
Mon, 22 Aug 2005 21:33:11 +0000 (21:33 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 22 Aug 2005 21:33:11 +0000 (21:33 +0000)
It used to crash on any function that took float arguments.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@22973 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/IA64/IA64ISelPattern.cpp

index 1ca4176c3a5a218a43e6daa728392b71785a16f3..cb815212c1923f74c5a6da13bc714e166d12287c 100644 (file)
@@ -202,7 +202,9 @@ IA64TargetLowering::LowerArguments(Function &F, SelectionDAG &DAG) {
             argPreg[count] = args_FP[used_FPArgs++];
             argOpc[count] = IA64::FMOV;
             argt = newroot = DAG.getCopyFromReg(DAG.getRoot(), argVreg[count],
-                                                getValueType(I->getType()));
+                                                MVT::f64);
+            if (I->getType() == Type::FloatTy)
+              argt = DAG.getNode(ISD::FP_ROUND, MVT::f32, argt);
             break;
           case MVT::i1: // NOTE: as far as C abi stuff goes,
                         // bools are just boring old ints