From 1a490607b56c4817b03237e380a988c61e8f160d Mon Sep 17 00:00:00 2001 From: Geoff Berry Date: Thu, 14 Apr 2016 21:31:07 +0000 Subject: [PATCH] [ScheduleDAGInstrs] Re-factor for based on review feedback. NFC. Summary: Re-factor some code to improve clarity and style based on review comments from http://reviews.llvm.org/D18093. Reviewers: MatzeB, mcrosier Subscribers: MatzeB, mcrosier, llvm-commits Differential Revision: http://reviews.llvm.org/D19128 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@266372 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/CodeGen/ScheduleDAGInstrs.h | 9 ++- lib/CodeGen/ScheduleDAGInstrs.cpp | 97 +++++++++++------------- 2 files changed, 52 insertions(+), 54 deletions(-) diff --git a/include/llvm/CodeGen/ScheduleDAGInstrs.h b/include/llvm/CodeGen/ScheduleDAGInstrs.h index a83a5158689..12124ecc4b3 100644 --- a/include/llvm/CodeGen/ScheduleDAGInstrs.h +++ b/include/llvm/CodeGen/ScheduleDAGInstrs.h @@ -87,8 +87,13 @@ namespace llvm { VReg2SUnitOperIdxMultiMap; typedef PointerUnion ValueType; - typedef SmallVector, 4> - UnderlyingObjectsVector; + struct UnderlyingObject : PointerIntPair { + UnderlyingObject(ValueType V, bool MayAlias) + : PointerIntPair(V, MayAlias) {} + ValueType getValue() const { return getPointer(); } + bool mayAlias() const { return getInt(); } + }; + typedef SmallVector UnderlyingObjectsVector; /// ScheduleDAGInstrs - A ScheduleDAG subclass for scheduling lists of /// MachineInstrs. diff --git a/lib/CodeGen/ScheduleDAGInstrs.cpp b/lib/CodeGen/ScheduleDAGInstrs.cpp index c9c9a47a795..d8905ec588d 100644 --- a/lib/CodeGen/ScheduleDAGInstrs.cpp +++ b/lib/CodeGen/ScheduleDAGInstrs.cpp @@ -159,49 +159,46 @@ static void getUnderlyingObjectsForInstr(const MachineInstr *MI, const MachineFrameInfo *MFI, UnderlyingObjectsVector &Objects, const DataLayout &DL) { - for (auto *MMO : MI->memoperands()) { - if (MMO->isVolatile()) { - Objects.clear(); - return; - } + auto allMMOsOkay = [&]() { + for (const MachineMemOperand *MMO : MI->memoperands()) { + if (MMO->isVolatile()) + return false; - if (const PseudoSourceValue *PSV = MMO->getPseudoValue()) { - // Function that contain tail calls don't have unique PseudoSourceValue - // objects. Two PseudoSourceValues might refer to the same or overlapping - // locations. The client code calling this function assumes this is not the - // case. So return a conservative answer of no known object. - if (MFI->hasTailCall()) { - Objects.clear(); - return; - } + if (const PseudoSourceValue *PSV = MMO->getPseudoValue()) { + // Function that contain tail calls don't have unique PseudoSourceValue + // objects. Two PseudoSourceValues might refer to the same or + // overlapping locations. The client code calling this function assumes + // this is not the case. So return a conservative answer of no known + // object. + if (MFI->hasTailCall()) + return false; - // For now, ignore PseudoSourceValues which may alias LLVM IR values - // because the code that uses this function has no way to cope with - // such aliases. - if (PSV->isAliased(MFI)) { - Objects.clear(); - return; - } + // For now, ignore PseudoSourceValues which may alias LLVM IR values + // because the code that uses this function has no way to cope with + // such aliases. + if (PSV->isAliased(MFI)) + return false; - bool MayAlias = PSV->mayAlias(MFI); - Objects.push_back(UnderlyingObjectsVector::value_type(PSV, MayAlias)); - } else if (const Value *V = MMO->getValue()) { - SmallVector Objs; - getUnderlyingObjects(V, Objs, DL); + bool MayAlias = PSV->mayAlias(MFI); + Objects.push_back(UnderlyingObjectsVector::value_type(PSV, MayAlias)); + } else if (const Value *V = MMO->getValue()) { + SmallVector Objs; + getUnderlyingObjects(V, Objs, DL); - for (Value *V : Objs) { - if (!isIdentifiedObject(V)) { - Objects.clear(); - return; + for (Value *V : Objs) { + if (!isIdentifiedObject(V)) + return false; + + Objects.push_back(UnderlyingObjectsVector::value_type(V, true)); } - - Objects.push_back(UnderlyingObjectsVector::value_type(V, true)); - } - } else { - Objects.clear(); - return; + } else + return false; } - } + return true; + }; + + if (!allMMOsOkay()) + Objects.clear(); } void ScheduleDAGInstrs::startBlock(MachineBasicBlock *bb) { @@ -1031,26 +1028,22 @@ void ScheduleDAGInstrs::buildSchedGraph(AliasAnalysis *AA, } else { // Add precise dependencies against all previously seen memory // accesses mapped to the same Value(s). - for (auto &underlObj : Objs) { - ValueType V = underlObj.getPointer(); - bool ThisMayAlias = underlObj.getInt(); - - Value2SUsMap &stores_ = (ThisMayAlias ? Stores : NonAliasStores); + for (const UnderlyingObject &UnderlObj : Objs) { + ValueType V = UnderlObj.getValue(); + bool ThisMayAlias = UnderlObj.mayAlias(); // Add dependencies to previous stores and loads mapped to V. - addChainDependencies(SU, stores_, V); + addChainDependencies(SU, (ThisMayAlias ? Stores : NonAliasStores), V); addChainDependencies(SU, (ThisMayAlias ? Loads : NonAliasLoads), V); } // Update the store map after all chains have been added to avoid adding // self-loop edge if multiple underlying objects are present. - for (auto &underlObj : Objs) { - ValueType V = underlObj.getPointer(); - bool ThisMayAlias = underlObj.getInt(); - - Value2SUsMap &stores_ = (ThisMayAlias ? Stores : NonAliasStores); + for (const UnderlyingObject &UnderlObj : Objs) { + ValueType V = UnderlObj.getValue(); + bool ThisMayAlias = UnderlObj.mayAlias(); // Map this store to V. - stores_.insert(SU, V); + (ThisMayAlias ? Stores : NonAliasStores).insert(SU, V); } // The store may have dependencies to unanalyzable loads and // stores. @@ -1065,9 +1058,9 @@ void ScheduleDAGInstrs::buildSchedGraph(AliasAnalysis *AA, Loads.insert(SU, UnknownValue); } else { - for (auto &underlObj : Objs) { - ValueType V = underlObj.getPointer(); - bool ThisMayAlias = underlObj.getInt(); + for (const UnderlyingObject &UnderlObj : Objs) { + ValueType V = UnderlObj.getValue(); + bool ThisMayAlias = UnderlObj.mayAlias(); // Add precise dependencies against all previously seen stores // mapping to the same Value(s).