diff options
author | Stuart Hastings <stuart@apple.com> | 2011-03-19 02:33:56 +0000 |
---|---|---|
committer | Stuart Hastings <stuart@apple.com> | 2011-03-19 02:33:56 +0000 |
commit | 08b4daa1910772394693aa9d18357ddf95958f19 (patch) | |
tree | 77e24e1262d515d4f7d228eae0933f8a55e935cb /llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp | |
parent | 759423796455bafc87ca0f30f235ceac43c0a8d9 (diff) | |
download | llvm-08b4daa1910772394693aa9d18357ddf95958f19.zip llvm-08b4daa1910772394693aa9d18357ddf95958f19.tar.gz llvm-08b4daa1910772394693aa9d18357ddf95958f19.tar.bz2 |
Revert 127939. <rdar://problem/9012638>
llvm-svn: 127943
Diffstat (limited to 'llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp')
-rw-r--r-- | llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp index f332d12..fa311dc 100644 --- a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp +++ b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp @@ -641,11 +641,10 @@ getExplicitSectionGlobal(const GlobalValue *GV, SectionKind Kind, Mangler *Mang, const TargetMachine &TM) const { // Parse the section specifier and create it if valid. StringRef Segment, Section; - unsigned TAA = 0, StubSize = 0; - bool TAAParsed; + unsigned TAA = (unsigned)MCSectionMachO::SECTION_ATTRIBUTES, StubSize = 0; std::string ErrorCode = MCSectionMachO::ParseSectionSpecifier(GV->getSection(), Segment, Section, - TAA, TAAParsed, StubSize); + TAA, StubSize); if (!ErrorCode.empty()) { // If invalid, report the error with report_fatal_error. report_fatal_error("Global variable '" + GV->getNameStr() + @@ -655,13 +654,17 @@ getExplicitSectionGlobal(const GlobalValue *GV, SectionKind Kind, return DataSection; } + bool TAAWasSet = (TAA != MCSectionMachO::SECTION_ATTRIBUTES); + if (!TAAWasSet) + TAA = 0; // Sensible default if this is a new section. + // Get the section. const MCSectionMachO *S = getContext().getMachOSection(Segment, Section, TAA, StubSize, Kind); // If TAA wasn't set by ParseSectionSpecifier() above, // use the value returned by getMachOSection() as a default. - if (!TAAParsed) + if (!TAAWasSet) TAA = S->getTypeAndAttributes(); // Okay, now that we got the section, verify that the TAA & StubSize agree. |