freebsd-dev/lib/CodeGen/PseudoSourceValue.cpp

135 lines
4.0 KiB
C++
Raw Normal View History

2009-06-02 17:52:33 +00:00
//===-- llvm/CodeGen/PseudoSourceValue.cpp ----------------------*- C++ -*-===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
// This file implements the PseudoSourceValue class.
//
//===----------------------------------------------------------------------===//
#include "llvm/CodeGen/MachineFrameInfo.h"
#include "llvm/CodeGen/PseudoSourceValue.h"
#include "llvm/DerivedTypes.h"
2009-11-04 14:58:56 +00:00
#include "llvm/LLVMContext.h"
2009-10-14 17:57:32 +00:00
#include "llvm/Support/ErrorHandling.h"
2009-06-02 17:52:33 +00:00
#include "llvm/Support/ManagedStatic.h"
#include "llvm/Support/raw_ostream.h"
2010-03-06 09:22:29 +00:00
#include "llvm/System/Mutex.h"
2009-06-02 17:52:33 +00:00
#include <map>
using namespace llvm;
2010-03-06 09:22:29 +00:00
namespace {
struct PSVGlobalsTy {
// PseudoSourceValues are immutable so don't need locking.
const PseudoSourceValue PSVs[4];
sys::Mutex Lock; // Guards FSValues, but not the values inside it.
std::map<int, const PseudoSourceValue *> FSValues;
PSVGlobalsTy() : PSVs() {}
~PSVGlobalsTy() {
for (std::map<int, const PseudoSourceValue *>::iterator
I = FSValues.begin(), E = FSValues.end(); I != E; ++I) {
delete I->second;
}
}
};
static ManagedStatic<PSVGlobalsTy> PSVGlobals;
} // anonymous namespace
2009-06-02 17:52:33 +00:00
const PseudoSourceValue *PseudoSourceValue::getStack()
2010-03-06 09:22:29 +00:00
{ return &PSVGlobals->PSVs[0]; }
2009-06-02 17:52:33 +00:00
const PseudoSourceValue *PseudoSourceValue::getGOT()
2010-03-06 09:22:29 +00:00
{ return &PSVGlobals->PSVs[1]; }
2009-06-02 17:52:33 +00:00
const PseudoSourceValue *PseudoSourceValue::getJumpTable()
2010-03-06 09:22:29 +00:00
{ return &PSVGlobals->PSVs[2]; }
2009-06-02 17:52:33 +00:00
const PseudoSourceValue *PseudoSourceValue::getConstantPool()
2010-03-06 09:22:29 +00:00
{ return &PSVGlobals->PSVs[3]; }
2009-06-02 17:52:33 +00:00
static const char *const PSVNames[] = {
"Stack",
"GOT",
"JumpTable",
"ConstantPool"
};
2009-10-14 17:57:32 +00:00
// FIXME: THIS IS A HACK!!!!
// Eventually these should be uniqued on LLVMContext rather than in a managed
// static. For now, we can safely use the global context for the time being to
// squeak by.
2009-11-18 14:58:34 +00:00
PseudoSourceValue::PseudoSourceValue(enum ValueTy Subclass) :
2009-10-14 17:57:32 +00:00
Value(Type::getInt8PtrTy(getGlobalContext()),
2009-11-18 14:58:34 +00:00
Subclass) {}
2009-06-02 17:52:33 +00:00
2009-10-14 17:57:32 +00:00
void PseudoSourceValue::printCustom(raw_ostream &O) const {
2010-03-06 09:22:29 +00:00
O << PSVNames[this - PSVGlobals->PSVs];
2009-06-02 17:52:33 +00:00
}
const PseudoSourceValue *PseudoSourceValue::getFixedStack(int FI) {
2010-03-06 09:22:29 +00:00
PSVGlobalsTy &PG = *PSVGlobals;
sys::ScopedLock locked(PG.Lock);
const PseudoSourceValue *&V = PG.FSValues[FI];
2009-06-02 17:52:33 +00:00
if (!V)
V = new FixedStackPseudoSourceValue(FI);
return V;
}
bool PseudoSourceValue::isConstant(const MachineFrameInfo *) const {
if (this == getStack())
return false;
if (this == getGOT() ||
this == getConstantPool() ||
this == getJumpTable())
return true;
2009-10-14 17:57:32 +00:00
llvm_unreachable("Unknown PseudoSourceValue!");
2009-06-02 17:52:33 +00:00
return false;
}
2009-10-23 14:19:52 +00:00
bool PseudoSourceValue::isAliased(const MachineFrameInfo *MFI) const {
if (this == getStack() ||
this == getGOT() ||
this == getConstantPool() ||
this == getJumpTable())
return false;
llvm_unreachable("Unknown PseudoSourceValue!");
return true;
}
2009-11-04 14:58:56 +00:00
bool PseudoSourceValue::mayAlias(const MachineFrameInfo *MFI) const {
if (this == getGOT() ||
this == getConstantPool() ||
this == getJumpTable())
return false;
return true;
}
2009-06-02 17:52:33 +00:00
bool FixedStackPseudoSourceValue::isConstant(const MachineFrameInfo *MFI) const{
return MFI && MFI->isImmutableObjectIndex(FI);
}
2009-10-23 14:19:52 +00:00
bool FixedStackPseudoSourceValue::isAliased(const MachineFrameInfo *MFI) const {
// Negative frame indices are used for special things that don't
// appear in LLVM IR. Non-negative indices may be used for things
// like static allocas.
if (!MFI)
return FI >= 0;
// Spill slots should not alias others.
return !MFI->isFixedObjectIndex(FI) && !MFI->isSpillSlotObjectIndex(FI);
}
2009-11-04 14:58:56 +00:00
bool FixedStackPseudoSourceValue::mayAlias(const MachineFrameInfo *MFI) const {
if (!MFI)
return true;
// Spill slots will not alias any LLVM IR value.
return !MFI->isSpillSlotObjectIndex(FI);
}
2009-11-18 14:58:34 +00:00
void FixedStackPseudoSourceValue::printCustom(raw_ostream &OS) const {
OS << "FixedStack" << FI;
}