mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 11:13:28 +01:00
Add support for putting globals in a particular section
llvm-svn: 24309
This commit is contained in:
parent
483048fe7f
commit
bcf40488a9
@ -38,12 +38,13 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
GlobalValue(const Type *Ty, ValueTy vty, Use *Ops, unsigned NumOps,
|
GlobalValue(const Type *Ty, ValueTy vty, Use *Ops, unsigned NumOps,
|
||||||
LinkageTypes linkage, const std::string &name = "")
|
LinkageTypes linkage, const std::string &name = "")
|
||||||
: Constant(Ty, vty, Ops, NumOps, name), Linkage(linkage),
|
: Constant(Ty, vty, Ops, NumOps, name),
|
||||||
Parent(0), Alignment(0) { }
|
Parent(0), Linkage(linkage), Alignment(0) { }
|
||||||
|
|
||||||
LinkageTypes Linkage; // The linkage of this global
|
|
||||||
Module *Parent;
|
Module *Parent;
|
||||||
unsigned Alignment;
|
LinkageTypes Linkage; // The linkage of this global
|
||||||
|
unsigned Alignment; // Alignment of this symbol, must be power of two
|
||||||
|
std::string Section; // Section to emit this into, empty mean default
|
||||||
public:
|
public:
|
||||||
~GlobalValue() {
|
~GlobalValue() {
|
||||||
removeDeadConstantUsers(); // remove any dead constants using this.
|
removeDeadConstantUsers(); // remove any dead constants using this.
|
||||||
@ -55,6 +56,10 @@ public:
|
|||||||
Alignment = Align;
|
Alignment = Align;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool hasSection() const { return !Section.empty(); }
|
||||||
|
const std::string &getSection() const { return Section; }
|
||||||
|
void setSection(const std::string &S) { Section = S; }
|
||||||
|
|
||||||
/// If the usage is empty (except transitively dead constants), then this
|
/// If the usage is empty (except transitively dead constants), then this
|
||||||
/// global value can can be safely deleted since the destructor will
|
/// global value can can be safely deleted since the destructor will
|
||||||
/// delete the dead constants as well.
|
/// delete the dead constants as well.
|
||||||
|
Loading…
Reference in New Issue
Block a user