Simplify CreateLoadLR and CreateStoreLR in MipsISelLowering.cpp.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@158413 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Akira Hatanaka 2012-06-13 19:06:08 +00:00
parent 777a120285
commit 2bd7e532b4

View File

@ -2070,17 +2070,15 @@ SDValue MipsTargetLowering::LowerShiftRightParts(SDValue Op, SelectionDAG& DAG,
static SDValue CreateLoadLR(unsigned Opc, SelectionDAG &DAG, LoadSDNode *LD, static SDValue CreateLoadLR(unsigned Opc, SelectionDAG &DAG, LoadSDNode *LD,
SDValue Chain, SDValue Src, unsigned Offset) { SDValue Chain, SDValue Src, unsigned Offset) {
SDValue BasePtr = LD->getBasePtr(), Ptr; SDValue Ptr = LD->getBasePtr();
EVT VT = LD->getValueType(0), MemVT = LD->getMemoryVT(); EVT VT = LD->getValueType(0), MemVT = LD->getMemoryVT();
EVT BasePtrVT = BasePtr.getValueType(); EVT BasePtrVT = Ptr.getValueType();
DebugLoc DL = LD->getDebugLoc(); DebugLoc DL = LD->getDebugLoc();
SDVTList VTList = DAG.getVTList(VT, MVT::Other); SDVTList VTList = DAG.getVTList(VT, MVT::Other);
if (Offset) if (Offset)
Ptr = DAG.getNode(ISD::ADD, DL, BasePtrVT, BasePtr, Ptr = DAG.getNode(ISD::ADD, DL, BasePtrVT, Ptr,
DAG.getConstant(Offset, BasePtrVT)); DAG.getConstant(Offset, BasePtrVT));
else
Ptr = BasePtr;
SDValue Ops[] = { Chain, Ptr, Src }; SDValue Ops[] = { Chain, Ptr, Src };
return DAG.getMemIntrinsicNode(Opc, DL, VTList, Ops, 3, MemVT, return DAG.getMemIntrinsicNode(Opc, DL, VTList, Ops, 3, MemVT,
@ -2151,17 +2149,14 @@ SDValue MipsTargetLowering::LowerLOAD(SDValue Op, SelectionDAG &DAG) const {
static SDValue CreateStoreLR(unsigned Opc, SelectionDAG &DAG, StoreSDNode *SD, static SDValue CreateStoreLR(unsigned Opc, SelectionDAG &DAG, StoreSDNode *SD,
SDValue Chain, unsigned Offset) { SDValue Chain, unsigned Offset) {
SDValue BasePtr = SD->getBasePtr(), Ptr, Value = SD->getValue(); SDValue Ptr = SD->getBasePtr(), Value = SD->getValue();
EVT MemVT = SD->getMemoryVT(); EVT MemVT = SD->getMemoryVT(), BasePtrVT = Ptr.getValueType();
EVT BasePtrVT = BasePtr.getValueType();
DebugLoc DL = SD->getDebugLoc(); DebugLoc DL = SD->getDebugLoc();
SDVTList VTList = DAG.getVTList(MVT::Other); SDVTList VTList = DAG.getVTList(MVT::Other);
if (Offset) if (Offset)
Ptr = DAG.getNode(ISD::ADD, DL, BasePtrVT, BasePtr, Ptr = DAG.getNode(ISD::ADD, DL, BasePtrVT, Ptr,
DAG.getConstant(Offset, BasePtrVT)); DAG.getConstant(Offset, BasePtrVT));
else
Ptr = BasePtr;
SDValue Ops[] = { Chain, Value, Ptr }; SDValue Ops[] = { Chain, Value, Ptr };
return DAG.getMemIntrinsicNode(Opc, DL, VTList, Ops, 3, MemVT, return DAG.getMemIntrinsicNode(Opc, DL, VTList, Ops, 3, MemVT,