diff options
| author | Rafael Espindola <rafael.espindola@gmail.com> | 2011-01-08 16:42:36 +0000 | 
|---|---|---|
| committer | Rafael Espindola <rafael.espindola@gmail.com> | 2011-01-08 16:42:36 +0000 | 
| commit | bea4626f93c830e31f82cc947df28fdae583cd09 (patch) | |
| tree | 516eb5bca793907f8e19649df18f6ace84898f5e /lib/Bitcode | |
| parent | 8368ac3688ccbb9f61b35a369ddc43ff90f8cdbd (diff) | |
| download | external_llvm-bea4626f93c830e31f82cc947df28fdae583cd09.zip external_llvm-bea4626f93c830e31f82cc947df28fdae583cd09.tar.gz external_llvm-bea4626f93c830e31f82cc947df28fdae583cd09.tar.bz2 | |
First step in fixing PR8927:
Add a unnamed_addr bit to global variables and functions. This will be used
to indicate that the address is not significant and therefore the constant
or function can be merged with others.
If an optimization pass can show that an address is not used, it can set this.
Examples of things that can have this set by the FE are globals created to
hold string literals and C++ constructors.
Adding unnamed_addr to a non-const global should have no effect unless
an optimization can transform that global into a constant.
Aliases are not allowed to have unnamed_addr since I couldn't figure
out any use for it.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@123063 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bitcode')
| -rw-r--r-- | lib/Bitcode/Reader/BitcodeReader.cpp | 14 | ||||
| -rw-r--r-- | lib/Bitcode/Writer/BitcodeWriter.cpp | 10 | 
2 files changed, 19 insertions, 5 deletions
| diff --git a/lib/Bitcode/Reader/BitcodeReader.cpp b/lib/Bitcode/Reader/BitcodeReader.cpp index e8b998e..7a71b26 100644 --- a/lib/Bitcode/Reader/BitcodeReader.cpp +++ b/lib/Bitcode/Reader/BitcodeReader.cpp @@ -1422,7 +1422,8 @@ bool BitcodeReader::ParseModule() {        break;      }      // GLOBALVAR: [pointer type, isconst, initid, -    //             linkage, alignment, section, visibility, threadlocal] +    //             linkage, alignment, section, visibility, threadlocal, +    //             unnamed_addr]      case bitc::MODULE_CODE_GLOBALVAR: {        if (Record.size() < 6)          return Error("Invalid MODULE_CODE_GLOBALVAR record"); @@ -1449,6 +1450,10 @@ bool BitcodeReader::ParseModule() {        if (Record.size() > 7)          isThreadLocal = Record[7]; +      bool UnnamedAddr = false; +      if (Record.size() > 8) +        UnnamedAddr = Record[8]; +        GlobalVariable *NewGV =          new GlobalVariable(*TheModule, Ty, isConstant, Linkage, 0, "", 0,                             isThreadLocal, AddressSpace); @@ -1457,6 +1462,7 @@ bool BitcodeReader::ParseModule() {          NewGV->setSection(Section);        NewGV->setVisibility(Visibility);        NewGV->setThreadLocal(isThreadLocal); +      NewGV->setUnnamedAddr(UnnamedAddr);        ValueList.push_back(NewGV); @@ -1466,7 +1472,7 @@ bool BitcodeReader::ParseModule() {        break;      }      // FUNCTION:  [type, callingconv, isproto, linkage, paramattr, -    //             alignment, section, visibility, gc] +    //             alignment, section, visibility, gc, unnamed_addr]      case bitc::MODULE_CODE_FUNCTION: {        if (Record.size() < 8)          return Error("Invalid MODULE_CODE_FUNCTION record"); @@ -1499,6 +1505,10 @@ bool BitcodeReader::ParseModule() {            return Error("Invalid GC ID");          Func->setGC(GCTable[Record[8]-1].c_str());        } +      bool UnnamedAddr = false; +      if (Record.size() > 9) +        UnnamedAddr = Record[9]; +      Func->setUnnamedAddr(UnnamedAddr);        ValueList.push_back(Func);        // If this is a function with a body, remember the prototype we are diff --git a/lib/Bitcode/Writer/BitcodeWriter.cpp b/lib/Bitcode/Writer/BitcodeWriter.cpp index 7b6b843..702a611 100644 --- a/lib/Bitcode/Writer/BitcodeWriter.cpp +++ b/lib/Bitcode/Writer/BitcodeWriter.cpp @@ -404,7 +404,8 @@ static void WriteModuleInfo(const Module *M, const ValueEnumerator &VE,      unsigned AbbrevToUse = 0;      // GLOBALVAR: [type, isconst, initid, -    //             linkage, alignment, section, visibility, threadlocal] +    //             linkage, alignment, section, visibility, threadlocal, +    //             unnamed_addr]      Vals.push_back(VE.getTypeID(GV->getType()));      Vals.push_back(GV->isConstant());      Vals.push_back(GV->isDeclaration() ? 0 : @@ -413,9 +414,11 @@ static void WriteModuleInfo(const Module *M, const ValueEnumerator &VE,      Vals.push_back(Log2_32(GV->getAlignment())+1);      Vals.push_back(GV->hasSection() ? SectionMap[GV->getSection()] : 0);      if (GV->isThreadLocal() || -        GV->getVisibility() != GlobalValue::DefaultVisibility) { +        GV->getVisibility() != GlobalValue::DefaultVisibility || +        GV->hasUnnamedAddr()) {        Vals.push_back(getEncodedVisibility(GV));        Vals.push_back(GV->isThreadLocal()); +      Vals.push_back(GV->hasUnnamedAddr());      } else {        AbbrevToUse = SimpleGVarAbbrev;      } @@ -427,7 +430,7 @@ static void WriteModuleInfo(const Module *M, const ValueEnumerator &VE,    // Emit the function proto information.    for (Module::const_iterator F = M->begin(), E = M->end(); F != E; ++F) {      // FUNCTION:  [type, callingconv, isproto, paramattr, -    //             linkage, alignment, section, visibility, gc] +    //             linkage, alignment, section, visibility, gc, unnamed_addr]      Vals.push_back(VE.getTypeID(F->getType()));      Vals.push_back(F->getCallingConv());      Vals.push_back(F->isDeclaration()); @@ -437,6 +440,7 @@ static void WriteModuleInfo(const Module *M, const ValueEnumerator &VE,      Vals.push_back(F->hasSection() ? SectionMap[F->getSection()] : 0);      Vals.push_back(getEncodedVisibility(F));      Vals.push_back(F->hasGC() ? GCMap[F->getGC()] : 0); +    Vals.push_back(F->hasUnnamedAddr());      unsigned AbbrevToUse = 0;      Stream.EmitRecord(bitc::MODULE_CODE_FUNCTION, Vals, AbbrevToUse); | 
