mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-09 05:31:37 +00:00
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:
parent
67278b1774
commit
60ae8c800a
@ -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
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user