Reformat PseudoSourceValue.cpp and PseudoSourceValue.h. NFC.

This commit reformats the files lib/CodeGen/PseudoSourceValue.cpp and
include/llvm/CodeGen/PseudoSourceValue.h using clang-format. This change is
done in preparation for the changes to the pseudo source value object
management and to the PseudoSourceValue's class hierarchy.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@244685 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Alex Lorenz 2015-08-11 22:17:22 +00:00
parent 67278b1774
commit 60ae8c800a
2 changed files with 92 additions and 94 deletions

View File

@ -17,94 +17,95 @@
#include "llvm/IR/Value.h" #include "llvm/IR/Value.h"
namespace llvm { namespace llvm {
class MachineFrameInfo; class MachineFrameInfo;
class MachineMemOperand; class MachineMemOperand;
class raw_ostream; class raw_ostream;
raw_ostream &operator<<(raw_ostream &OS, const MachineMemOperand &MMO); raw_ostream &operator<<(raw_ostream &OS, const MachineMemOperand &MMO);
/// PseudoSourceValue - Special value supplied for machine level alias /// PseudoSourceValue - Special value supplied for machine level alias
/// analysis. It indicates that a memory access references the functions /// analysis. It indicates that a memory access references the functions
/// stack frame (e.g., a spill slot), below the stack frame (e.g., argument /// stack frame (e.g., a spill slot), below the stack frame (e.g., argument
/// space), or constant pool. /// space), or constant pool.
class PseudoSourceValue { class PseudoSourceValue {
private: private:
friend class MachineMemOperand; // For printCustom(). friend class MachineMemOperand; // For printCustom().
/// printCustom - Implement printing for PseudoSourceValue. This is called /// printCustom - Implement printing for PseudoSourceValue. This is called
/// from Value::print or Value's operator<<. /// from Value::print or Value's operator<<.
/// ///
virtual void printCustom(raw_ostream &O) const; virtual void printCustom(raw_ostream &O) const;
public: public:
/// isFixed - Whether this is a FixedStackPseudoSourceValue. /// isFixed - Whether this is a FixedStackPseudoSourceValue.
bool isFixed; bool isFixed;
explicit PseudoSourceValue(bool isFixed = false); explicit PseudoSourceValue(bool isFixed = false);
virtual ~PseudoSourceValue(); virtual ~PseudoSourceValue();
/// isConstant - Test whether the memory pointed to by this /// isConstant - Test whether the memory pointed to by this
/// PseudoSourceValue has a constant value. /// PseudoSourceValue has a constant value.
/// ///
virtual bool isConstant(const MachineFrameInfo *) const; virtual bool isConstant(const MachineFrameInfo *) const;
/// isAliased - Test whether the memory pointed to by this /// isAliased - Test whether the memory pointed to by this
/// PseudoSourceValue may also be pointed to by an LLVM IR Value. /// PseudoSourceValue may also be pointed to by an LLVM IR Value.
virtual bool isAliased(const MachineFrameInfo *) const; virtual bool isAliased(const MachineFrameInfo *) const;
/// mayAlias - Return true if the memory pointed to by this /// mayAlias - Return true if the memory pointed to by this
/// PseudoSourceValue can ever alias an LLVM IR Value. /// PseudoSourceValue can ever alias an LLVM IR Value.
virtual bool mayAlias(const MachineFrameInfo *) const; virtual bool mayAlias(const MachineFrameInfo *) const;
/// A pseudo source value referencing a fixed stack frame entry, /// A pseudo source value referencing a fixed stack frame entry,
/// e.g., a spill slot. /// e.g., a spill slot.
static const PseudoSourceValue *getFixedStack(int FI); static const PseudoSourceValue *getFixedStack(int FI);
/// A pseudo source value referencing the area below the stack frame of /// A pseudo source value referencing the area below the stack frame of
/// a function, e.g., the argument space. /// a function, e.g., the argument space.
static const PseudoSourceValue *getStack(); static const PseudoSourceValue *getStack();
/// A pseudo source value referencing the global offset table /// A pseudo source value referencing the global offset table
/// (or something the like). /// (or something the like).
static const PseudoSourceValue *getGOT(); static const PseudoSourceValue *getGOT();
/// A pseudo source value referencing the constant pool. Since constant /// A pseudo source value referencing the constant pool. Since constant
/// pools are constant, this doesn't need to identify a specific constant /// pools are constant, this doesn't need to identify a specific constant
/// pool entry. /// pool entry.
static const PseudoSourceValue *getConstantPool(); static const PseudoSourceValue *getConstantPool();
/// A pseudo source value referencing a jump table. Since jump tables are /// A pseudo source value referencing a jump table. Since jump tables are
/// constant, this doesn't need to identify a specific jump table. /// constant, this doesn't need to identify a specific jump table.
static const PseudoSourceValue *getJumpTable(); static const PseudoSourceValue *getJumpTable();
}; };
/// FixedStackPseudoSourceValue - A specialized PseudoSourceValue /// FixedStackPseudoSourceValue - A specialized PseudoSourceValue
/// for holding FixedStack values, which must include a frame /// for holding FixedStack values, which must include a frame
/// index. /// index.
class FixedStackPseudoSourceValue : public PseudoSourceValue { class FixedStackPseudoSourceValue : public PseudoSourceValue {
const int FI; const int FI;
public:
explicit FixedStackPseudoSourceValue(int fi) :
PseudoSourceValue(true), FI(fi) {}
/// classof - Methods for support type inquiry through isa, cast, and public:
/// dyn_cast: explicit FixedStackPseudoSourceValue(int fi)
/// : PseudoSourceValue(true), FI(fi) {}
static inline bool classof(const PseudoSourceValue *V) {
return V->isFixed == true;
}
bool isConstant(const MachineFrameInfo *MFI) const override; /// classof - Methods for support type inquiry through isa, cast, and
/// dyn_cast:
///
static inline bool classof(const PseudoSourceValue *V) {
return V->isFixed == true;
}
bool isAliased(const MachineFrameInfo *MFI) const override; bool isConstant(const MachineFrameInfo *MFI) const override;
bool mayAlias(const MachineFrameInfo *) const override; bool isAliased(const MachineFrameInfo *MFI) const override;
void printCustom(raw_ostream &OS) const override; bool mayAlias(const MachineFrameInfo *) const override;
int getFrameIndex() const { return FI; } void printCustom(raw_ostream &OS) const override;
};
int getFrameIndex() const { return FI; }
};
} // End llvm namespace } // End llvm namespace
#endif #endif

View File

@ -26,13 +26,15 @@ namespace {
struct PSVGlobalsTy { struct PSVGlobalsTy {
// PseudoSourceValues are immutable so don't need locking. // PseudoSourceValues are immutable so don't need locking.
const PseudoSourceValue PSVs[4]; const PseudoSourceValue PSVs[4];
sys::Mutex Lock; // Guards FSValues, but not the values inside it. sys::Mutex Lock; // Guards FSValues, but not the values inside it.
std::map<int, const PseudoSourceValue *> FSValues; std::map<int, const PseudoSourceValue *> FSValues;
PSVGlobalsTy() : PSVs() {} PSVGlobalsTy() : PSVs() {}
~PSVGlobalsTy() { ~PSVGlobalsTy() {
for (std::map<int, const PseudoSourceValue *>::iterator for (std::map<int, const PseudoSourceValue *>::iterator
I = FSValues.begin(), E = FSValues.end(); I != E; ++I) { I = FSValues.begin(),
E = FSValues.end();
I != E; ++I) {
delete I->second; delete I->second;
} }
} }
@ -40,23 +42,23 @@ struct PSVGlobalsTy {
static ManagedStatic<PSVGlobalsTy> PSVGlobals; static ManagedStatic<PSVGlobalsTy> PSVGlobals;
} // anonymous namespace } // anonymous namespace
const PseudoSourceValue *PseudoSourceValue::getStack() const PseudoSourceValue *PseudoSourceValue::getStack() {
{ return &PSVGlobals->PSVs[0]; } return &PSVGlobals->PSVs[0];
const PseudoSourceValue *PseudoSourceValue::getGOT() }
{ return &PSVGlobals->PSVs[1]; } const PseudoSourceValue *PseudoSourceValue::getGOT() {
const PseudoSourceValue *PseudoSourceValue::getJumpTable() return &PSVGlobals->PSVs[1];
{ return &PSVGlobals->PSVs[2]; } }
const PseudoSourceValue *PseudoSourceValue::getConstantPool() const PseudoSourceValue *PseudoSourceValue::getJumpTable() {
{ return &PSVGlobals->PSVs[3]; } return &PSVGlobals->PSVs[2];
}
const PseudoSourceValue *PseudoSourceValue::getConstantPool() {
return &PSVGlobals->PSVs[3];
}
static const char *const PSVNames[] = { static const char *const PSVNames[] = {"Stack", "GOT", "JumpTable",
"Stack", "ConstantPool"};
"GOT",
"JumpTable",
"ConstantPool"
};
PseudoSourceValue::PseudoSourceValue(bool isFixed) : isFixed(isFixed) {} PseudoSourceValue::PseudoSourceValue(bool isFixed) : isFixed(isFixed) {}
@ -78,31 +80,26 @@ const PseudoSourceValue *PseudoSourceValue::getFixedStack(int FI) {
bool PseudoSourceValue::isConstant(const MachineFrameInfo *) const { bool PseudoSourceValue::isConstant(const MachineFrameInfo *) const {
if (this == getStack()) if (this == getStack())
return false; return false;
if (this == getGOT() || if (this == getGOT() || this == getConstantPool() || this == getJumpTable())
this == getConstantPool() ||
this == getJumpTable())
return true; return true;
llvm_unreachable("Unknown PseudoSourceValue!"); llvm_unreachable("Unknown PseudoSourceValue!");
} }
bool PseudoSourceValue::isAliased(const MachineFrameInfo *MFI) const { bool PseudoSourceValue::isAliased(const MachineFrameInfo *MFI) const {
if (this == getStack() || if (this == getStack() || this == getGOT() || this == getConstantPool() ||
this == getGOT() ||
this == getConstantPool() ||
this == getJumpTable()) this == getJumpTable())
return false; return false;
llvm_unreachable("Unknown PseudoSourceValue!"); llvm_unreachable("Unknown PseudoSourceValue!");
} }
bool PseudoSourceValue::mayAlias(const MachineFrameInfo *MFI) const { bool PseudoSourceValue::mayAlias(const MachineFrameInfo *MFI) const {
if (this == getGOT() || if (this == getGOT() || this == getConstantPool() || this == getJumpTable())
this == getConstantPool() ||
this == getJumpTable())
return false; return false;
return true; return true;
} }
bool FixedStackPseudoSourceValue::isConstant(const MachineFrameInfo *MFI) const{ bool FixedStackPseudoSourceValue::isConstant(
const MachineFrameInfo *MFI) const {
return MFI && MFI->isImmutableObjectIndex(FI); return MFI && MFI->isImmutableObjectIndex(FI);
} }