mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-20 03:23:01 +02:00
d4258dce35
We forgot to consider the target of ifuncs when considering if a function was alive or dead. N.B. Also update a few auxiliary tools like bugpoint and verify-uselistorder. This fixes PR27593. llvm-svn: 268468
85 lines
2.7 KiB
C++
85 lines
2.7 KiB
C++
//===- llvm/GlobalIndirectSymbol.h - GlobalIndirectSymbol class -*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file contains the declaration of the GlobalIndirectSymbol class, which
|
|
// is a base class for GlobalAlias and GlobalIFunc. It contains all common code
|
|
// for aliases and ifuncs.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_IR_GLOBALINDIRECTSYMBOL_H
|
|
#define LLVM_IR_GLOBALINDIRECTSYMBOL_H
|
|
|
|
#include "llvm/IR/GlobalValue.h"
|
|
#include "llvm/IR/OperandTraits.h"
|
|
|
|
namespace llvm {
|
|
|
|
class GlobalIndirectSymbol : public GlobalValue {
|
|
void operator=(const GlobalIndirectSymbol &) = delete;
|
|
GlobalIndirectSymbol(const GlobalIndirectSymbol &) = delete;
|
|
|
|
protected:
|
|
GlobalIndirectSymbol(Type *Ty, ValueTy VTy, unsigned AddressSpace,
|
|
LinkageTypes Linkage, const Twine &Name, Constant *Symbol);
|
|
|
|
public:
|
|
// allocate space for exactly one operand
|
|
void *operator new(size_t s) {
|
|
return User::operator new(s, 1);
|
|
}
|
|
|
|
/// Provide fast operand accessors
|
|
DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Constant);
|
|
|
|
/// These methods set and retrieve indirect symbol.
|
|
void setIndirectSymbol(Constant *Symbol) {
|
|
setOperand(0, Symbol);
|
|
}
|
|
const Constant *getIndirectSymbol() const {
|
|
return const_cast<GlobalIndirectSymbol *>(this)->getIndirectSymbol();
|
|
}
|
|
Constant *getIndirectSymbol() {
|
|
return getOperand(0);
|
|
}
|
|
|
|
const GlobalObject *getBaseObject() const {
|
|
return const_cast<GlobalIndirectSymbol *>(this)->getBaseObject();
|
|
}
|
|
GlobalObject *getBaseObject() {
|
|
return dyn_cast<GlobalObject>(getIndirectSymbol()->stripInBoundsOffsets());
|
|
}
|
|
|
|
const GlobalObject *getBaseObject(const DataLayout &DL, APInt &Offset) const {
|
|
return const_cast<GlobalIndirectSymbol *>(this)->getBaseObject(DL, Offset);
|
|
}
|
|
GlobalObject *getBaseObject(const DataLayout &DL, APInt &Offset) {
|
|
return dyn_cast<GlobalObject>(
|
|
getIndirectSymbol()->stripAndAccumulateInBoundsConstantOffsets(DL,
|
|
Offset));
|
|
}
|
|
|
|
// Methods for support type inquiry through isa, cast, and dyn_cast:
|
|
static inline bool classof(const Value *V) {
|
|
return V->getValueID() == Value::GlobalAliasVal ||
|
|
V->getValueID() == Value::GlobalIFuncVal;
|
|
}
|
|
};
|
|
|
|
template <>
|
|
struct OperandTraits<GlobalIndirectSymbol> :
|
|
public FixedNumOperandTraits<GlobalIndirectSymbol, 1> {
|
|
};
|
|
|
|
DEFINE_TRANSPARENT_OPERAND_ACCESSORS(GlobalIndirectSymbol, Constant)
|
|
|
|
} // End llvm namespace
|
|
|
|
#endif
|