From f679bdf121bc7606770256afa71de61b2c7c9230 Mon Sep 17 00:00:00 2001 From: Rafael Espindola Date: Fri, 6 Oct 2006 12:50:22 +0000 Subject: [PATCH] add support for calling functions that have double arguments llvm-svn: 30765 --- lib/Target/ARM/ARMISelDAGToDAG.cpp | 29 ++++++++++++++++++++++------- test/Regression/CodeGen/ARM/fp.ll | 10 ++++++++-- 2 files changed, 30 insertions(+), 9 deletions(-) diff --git a/lib/Target/ARM/ARMISelDAGToDAG.cpp b/lib/Target/ARM/ARMISelDAGToDAG.cpp index 25892d83c60..107ce5c543d 100644 --- a/lib/Target/ARM/ARMISelDAGToDAG.cpp +++ b/lib/Target/ARM/ARMISelDAGToDAG.cpp @@ -265,16 +265,31 @@ static SDOperand LowerCALL(SDOperand Op, SelectionDAG &DAG) { // and flag operands which copy the outgoing args into the appropriate regs. SDOperand InFlag; for (unsigned i = 0, e = Layout.lastRegArg(); i <= e; ++i) { - SDOperand Arg = Op.getOperand(5+2*i); - unsigned Reg = regs[Layout.getRegisterNum(i)]; - assert(Layout.getType(i) == Arg.getValueType()); - assert(Layout.getType(i) == MVT::i32); - Chain = DAG.getCopyToReg(Chain, Reg, Arg, InFlag); - InFlag = Chain.getValue(1); + SDOperand Arg = Op.getOperand(5+2*i); + unsigned RegNum = Layout.getRegisterNum(i); + unsigned Reg1 = regs[RegNum]; + MVT::ValueType VT = Layout.getType(i); + assert(VT == Arg.getValueType()); + assert(VT == MVT::i32 || VT == MVT::f32 || VT == MVT::f64); // Add argument register to the end of the list so that it is known live // into the call. - Ops.push_back(DAG.getRegister(Reg, Arg.getValueType())); + Ops.push_back(DAG.getRegister(Reg1, MVT::i32)); + if (VT == MVT::f64) { + unsigned Reg2 = regs[RegNum + 1]; + SDOperand SDReg1 = DAG.getRegister(Reg1, MVT::i32); + SDOperand SDReg2 = DAG.getRegister(Reg2, MVT::i32); + + Ops.push_back(DAG.getRegister(Reg2, MVT::i32)); + SDVTList VTs = DAG.getVTList(MVT::Other, MVT::Flag); + SDOperand Ops[] = {Chain, SDReg1, SDReg2, Arg}; //missing flag + Chain = DAG.getNode(ARMISD::FMRRD, VTs, Ops, 4); + } else { + if (VT == MVT::f32) + Arg = DAG.getNode(ISD::BIT_CONVERT, MVT::i32, Arg); + Chain = DAG.getCopyToReg(Chain, Reg1, Arg, InFlag); + } + InFlag = Chain.getValue(1); } std::vector NodeTys; diff --git a/test/Regression/CodeGen/ARM/fp.ll b/test/Regression/CodeGen/ARM/fp.ll index 313e83f2566..22382ea185e 100644 --- a/test/Regression/CodeGen/ARM/fp.ll +++ b/test/Regression/CodeGen/ARM/fp.ll @@ -3,8 +3,8 @@ ; RUN: llvm-as < %s | llc -march=arm | grep fsitos && ; RUN: llvm-as < %s | llc -march=arm | grep fmrs && ; RUN: llvm-as < %s | llc -march=arm | grep fsitod && -; RUN: llvm-as < %s | llc -march=arm | grep fmrrd | wc -l | grep 2 && -; RUN: llvm-as < %s | llc -march=arm | grep fmdrr | wc -l | grep 1 && +; RUN: llvm-as < %s | llc -march=arm | grep fmrrd | wc -l | grep 3 && +; RUN: llvm-as < %s | llc -march=arm | grep fmdrr | wc -l | grep 2 && ; RUN: llvm-as < %s | llc -march=arm | grep flds && ; RUN: llvm-as < %s | llc -march=arm | grep ".word.*1065353216" @@ -28,3 +28,9 @@ entry: double %f2(double %a) { ret double %a } + +void %f3(double %a) { + call void %f4( double %a) + ret void +} +declare void %f4(double)