mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 04:02:41 +01:00
Revert r250342.
Investigate why coal-sections-powerpc.s is failing on some buildbots. llvm-svn: 250346
This commit is contained in:
parent
07a3f21d1f
commit
16b2844360
@ -114,37 +114,22 @@ void MCObjectFileInfo::initMachOMCObjectFileInfo(Triple T) {
|
|||||||
= Ctx->getMachOSection("__TEXT", "__const", 0,
|
= Ctx->getMachOSection("__TEXT", "__const", 0,
|
||||||
SectionKind::getReadOnly());
|
SectionKind::getReadOnly());
|
||||||
|
|
||||||
// If the target is not powerpc, map the coal sections to the non-coal
|
TextCoalSection
|
||||||
// sections.
|
= Ctx->getMachOSection("__TEXT", "__textcoal_nt",
|
||||||
//
|
MachO::S_COALESCED |
|
||||||
// "__TEXT/__textcoal_nt" => section "__TEXT/__text"
|
MachO::S_ATTR_PURE_INSTRUCTIONS,
|
||||||
// "__TEXT/__const_coal" => section "__TEXT/__const"
|
SectionKind::getText());
|
||||||
// "__DATA/__datacoal_nt" => section "__DATA/__data"
|
ConstTextCoalSection
|
||||||
Triple::ArchType ArchTy = T.getArch();
|
= Ctx->getMachOSection("__TEXT", "__const_coal",
|
||||||
|
MachO::S_COALESCED,
|
||||||
if (ArchTy == Triple::ppc || ArchTy == Triple::ppc64) {
|
SectionKind::getReadOnly());
|
||||||
TextCoalSection
|
|
||||||
= Ctx->getMachOSection("__TEXT", "__textcoal_nt",
|
|
||||||
MachO::S_COALESCED |
|
|
||||||
MachO::S_ATTR_PURE_INSTRUCTIONS,
|
|
||||||
SectionKind::getText());
|
|
||||||
ConstTextCoalSection
|
|
||||||
= Ctx->getMachOSection("__TEXT", "__const_coal",
|
|
||||||
MachO::S_COALESCED,
|
|
||||||
SectionKind::getReadOnly());
|
|
||||||
DataCoalSection
|
|
||||||
= Ctx->getMachOSection("__DATA","__datacoal_nt",
|
|
||||||
MachO::S_COALESCED,
|
|
||||||
SectionKind::getDataRel());
|
|
||||||
} else {
|
|
||||||
TextCoalSection = TextSection;
|
|
||||||
ConstTextCoalSection = ReadOnlySection;
|
|
||||||
DataCoalSection = DataSection;
|
|
||||||
}
|
|
||||||
|
|
||||||
ConstDataSection // .const_data
|
ConstDataSection // .const_data
|
||||||
= Ctx->getMachOSection("__DATA", "__const", 0,
|
= Ctx->getMachOSection("__DATA", "__const", 0,
|
||||||
SectionKind::getReadOnlyWithRel());
|
SectionKind::getReadOnlyWithRel());
|
||||||
|
DataCoalSection
|
||||||
|
= Ctx->getMachOSection("__DATA","__datacoal_nt",
|
||||||
|
MachO::S_COALESCED,
|
||||||
|
SectionKind::getDataRel());
|
||||||
DataCommonSection
|
DataCommonSection
|
||||||
= Ctx->getMachOSection("__DATA","__common",
|
= Ctx->getMachOSection("__DATA","__common",
|
||||||
MachO::S_ZEROFILL,
|
MachO::S_ZEROFILL,
|
||||||
|
@ -10,10 +10,8 @@
|
|||||||
#include "llvm/MC/MCParser/MCAsmParserExtension.h"
|
#include "llvm/MC/MCParser/MCAsmParserExtension.h"
|
||||||
#include "llvm/ADT/StringRef.h"
|
#include "llvm/ADT/StringRef.h"
|
||||||
#include "llvm/ADT/StringSwitch.h"
|
#include "llvm/ADT/StringSwitch.h"
|
||||||
#include "llvm/ADT/Triple.h"
|
|
||||||
#include "llvm/ADT/Twine.h"
|
#include "llvm/ADT/Twine.h"
|
||||||
#include "llvm/MC/MCContext.h"
|
#include "llvm/MC/MCContext.h"
|
||||||
#include "llvm/MC/MCObjectFileInfo.h"
|
|
||||||
#include "llvm/MC/MCParser/MCAsmLexer.h"
|
#include "llvm/MC/MCParser/MCAsmLexer.h"
|
||||||
#include "llvm/MC/MCParser/MCAsmParser.h"
|
#include "llvm/MC/MCParser/MCAsmParser.h"
|
||||||
#include "llvm/MC/MCSectionMachO.h"
|
#include "llvm/MC/MCSectionMachO.h"
|
||||||
@ -581,29 +579,6 @@ bool DarwinAsmParser::parseDirectiveSection(StringRef, SMLoc) {
|
|||||||
if (!ErrorStr.empty())
|
if (!ErrorStr.empty())
|
||||||
return Error(Loc, ErrorStr.c_str());
|
return Error(Loc, ErrorStr.c_str());
|
||||||
|
|
||||||
// Issue a warning if the target is not powerpc and Section is a *coal* section.
|
|
||||||
Triple TT = getParser().getContext().getObjectFileInfo()->getTargetTriple();
|
|
||||||
Triple::ArchType ArchTy = TT.getArch();
|
|
||||||
|
|
||||||
if (ArchTy != Triple::ppc && ArchTy != Triple::ppc64) {
|
|
||||||
StringRef NonCoalSection = StringSwitch<StringRef>(Section)
|
|
||||||
.Case("__textcoal_nt", "__text")
|
|
||||||
.Case("__const_coal", "__const")
|
|
||||||
.Case("__datacoal_nt", "__data")
|
|
||||||
.Default(Section);
|
|
||||||
|
|
||||||
if (!Section.equals(NonCoalSection)) {
|
|
||||||
StringRef SectionVal(Loc.getPointer());
|
|
||||||
size_t B = SectionVal.find(',') + 1, E = SectionVal.find(',', B);
|
|
||||||
SMLoc BLoc = SMLoc::getFromPointer(SectionVal.data() + B);
|
|
||||||
SMLoc ELoc = SMLoc::getFromPointer(SectionVal.data() + E);
|
|
||||||
getParser().Warning(Loc, "section \"" + Section + "\" is deprecated",
|
|
||||||
SMRange(BLoc, ELoc));
|
|
||||||
getParser().Note(Loc, "change section name to \"" + NonCoalSection +
|
|
||||||
"\"", SMRange(BLoc, ELoc));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// FIXME: Arch specific.
|
// FIXME: Arch specific.
|
||||||
bool isText = Segment == "__TEXT"; // FIXME: Hack.
|
bool isText = Segment == "__TEXT"; // FIXME: Hack.
|
||||||
getStreamer().SwitchSection(getContext().getMachOSection(
|
getStreamer().SwitchSection(getContext().getMachOSection(
|
||||||
|
@ -1,24 +0,0 @@
|
|||||||
; RUN: llc < %s -mtriple powerpc-apple-darwin | FileCheck %s
|
|
||||||
|
|
||||||
; Check that *coal* sections are emitted.
|
|
||||||
|
|
||||||
; CHECK: .section __TEXT,__textcoal_nt,coalesced,pure_instructions
|
|
||||||
; CHECK: .section __TEXT,__textcoal_nt,coalesced,pure_instructions
|
|
||||||
; CHECK-NEXT: .globl _foo
|
|
||||||
|
|
||||||
; CHECK: .section __TEXT,__const_coal,coalesced
|
|
||||||
; CHECK-NEXT: .globl _a
|
|
||||||
|
|
||||||
; CHECK: .section __DATA,__datacoal_nt,coalesced
|
|
||||||
; CHECK-NEXT: .globl _b
|
|
||||||
|
|
||||||
@a = weak_odr constant [4 x i32] [i32 1, i32 2, i32 3, i32 4], align 16
|
|
||||||
@b = weak global i32 5, align 4
|
|
||||||
@g = common global i32* null, align 8
|
|
||||||
|
|
||||||
; Function Attrs: nounwind ssp uwtable
|
|
||||||
define weak i32* @foo() {
|
|
||||||
entry:
|
|
||||||
store i32* getelementptr inbounds ([4 x i32], [4 x i32]* @a, i64 0, i64 0), i32** @g, align 8
|
|
||||||
ret i32* @b
|
|
||||||
}
|
|
@ -1,23 +0,0 @@
|
|||||||
; RUN: llc < %s -mtriple x86_64-apple-darwin | FileCheck %s
|
|
||||||
|
|
||||||
; Check that *coal* sections are not emitted.
|
|
||||||
|
|
||||||
; CHECK: .section __TEXT,__text,regular,pure_instructions{{$}}
|
|
||||||
; CHECK-NEXT: .globl _foo
|
|
||||||
|
|
||||||
; CHECK: .section __TEXT,__const{{$}}
|
|
||||||
; CHECK-NEXT: .globl _a
|
|
||||||
|
|
||||||
; CHECK: .section __DATA,__data{{$}}
|
|
||||||
; CHECK-NEXT: .globl _b
|
|
||||||
|
|
||||||
@a = weak_odr constant [4 x i32] [i32 1, i32 2, i32 3, i32 4], align 16
|
|
||||||
@b = weak global i32 5, align 4
|
|
||||||
@g = common global i32* null, align 8
|
|
||||||
|
|
||||||
; Function Attrs: nounwind ssp uwtable
|
|
||||||
define weak i32* @foo() {
|
|
||||||
entry:
|
|
||||||
store i32* getelementptr inbounds ([4 x i32], [4 x i32]* @a, i64 0, i64 0), i32** @g, align 8
|
|
||||||
ret i32* @b
|
|
||||||
}
|
|
@ -117,7 +117,7 @@ bb7:
|
|||||||
|
|
||||||
; TODO: linux drops this into .rodata, we drop it into ".gnu.linkonce.r.G2"
|
; TODO: linux drops this into .rodata, we drop it into ".gnu.linkonce.r.G2"
|
||||||
|
|
||||||
; DARWIN: .section __TEXT,__const{{$}}
|
; DARWIN: .section __TEXT,__const_coal,coalesced
|
||||||
; DARWIN: _G2:
|
; DARWIN: _G2:
|
||||||
; DARWIN: .long 42
|
; DARWIN: .long 42
|
||||||
|
|
||||||
@ -176,6 +176,7 @@ bb7:
|
|||||||
; LINUX: .weak "foo bar"
|
; LINUX: .weak "foo bar"
|
||||||
; LINUX: "foo bar":
|
; LINUX: "foo bar":
|
||||||
|
|
||||||
|
; DARWIN: .section __DATA,__datacoal_nt,coalesced
|
||||||
; DARWIN: .globl "_foo bar"
|
; DARWIN: .globl "_foo bar"
|
||||||
; DARWIN: .weak_definition "_foo bar"
|
; DARWIN: .weak_definition "_foo bar"
|
||||||
; DARWIN: "_foo bar":
|
; DARWIN: "_foo bar":
|
||||||
@ -189,7 +190,7 @@ bb7:
|
|||||||
; LINUX: .byte 1
|
; LINUX: .byte 1
|
||||||
; LINUX: .size G6, 1
|
; LINUX: .size G6, 1
|
||||||
|
|
||||||
; DARWIN: .section __TEXT,__const{{$}}
|
; DARWIN: .section __TEXT,__const_coal,coalesced
|
||||||
; DARWIN: .globl _G6
|
; DARWIN: .globl _G6
|
||||||
; DARWIN: .weak_definition _G6
|
; DARWIN: .weak_definition _G6
|
||||||
; DARWIN:_G6:
|
; DARWIN:_G6:
|
||||||
@ -238,7 +239,7 @@ bb7:
|
|||||||
@G10 = weak global [100 x i32] zeroinitializer, align 32 ; <[100 x i32]*> [#uses=0]
|
@G10 = weak global [100 x i32] zeroinitializer, align 32 ; <[100 x i32]*> [#uses=0]
|
||||||
|
|
||||||
|
|
||||||
; DARWIN: .section __DATA,__data{{$}}
|
; DARWIN: .section __DATA,__datacoal_nt,coalesced
|
||||||
; DARWIN: .globl _G10
|
; DARWIN: .globl _G10
|
||||||
; DARWIN: .weak_definition _G10
|
; DARWIN: .weak_definition _G10
|
||||||
; DARWIN: .align 5
|
; DARWIN: .align 5
|
||||||
|
@ -1,46 +0,0 @@
|
|||||||
// RUN: llvm-mc -triple powerpc-apple-darwin -filetype=obj %s -o - | llvm-readobj -sections | FileCheck %s
|
|
||||||
|
|
||||||
// CHECK: Section {
|
|
||||||
// CHECK-NEXT: Index: 0
|
|
||||||
|
|
||||||
// CHECK: Section {
|
|
||||||
// CHECK-NEXT: Index: 1
|
|
||||||
// CHECK-NEXT: Name: __textcoal_nt (
|
|
||||||
|
|
||||||
// CHECK: Section {
|
|
||||||
// CHECK-NEXT: Index: 2
|
|
||||||
|
|
||||||
// CHECK: Section {
|
|
||||||
// CHECK-NEXT: Index: 3
|
|
||||||
// CHECK-NEXT: Name: __const_coal (
|
|
||||||
|
|
||||||
// CHECK: Section {
|
|
||||||
// CHECK-NEXT: Index: 4
|
|
||||||
// CHECK-NEXT: Name: __datacoal_nt (
|
|
||||||
|
|
||||||
.section __TEXT,__text,regular,pure_instructions
|
|
||||||
.machine ppc
|
|
||||||
.section __TEXT,__textcoal_nt,coalesced,pure_instructions
|
|
||||||
.section __TEXT,__symbol_stub1,symbol_stubs,pure_instructions,16
|
|
||||||
.section __TEXT,__text,regular,pure_instructions
|
|
||||||
.section __TEXT,__textcoal_nt,coalesced,pure_instructions
|
|
||||||
.globl _foo
|
|
||||||
.weak_definition _foo
|
|
||||||
.align 4
|
|
||||||
_foo:
|
|
||||||
blr
|
|
||||||
|
|
||||||
.subsections_via_symbols
|
|
||||||
.section __TEXT,__const_coal,coalesced
|
|
||||||
.globl _a ; @a
|
|
||||||
.weak_definition _a
|
|
||||||
.align 4
|
|
||||||
_a:
|
|
||||||
.long 1 ; 0x1
|
|
||||||
|
|
||||||
.section __DATA,__datacoal_nt,coalesced
|
|
||||||
.globl _b ; @b
|
|
||||||
.weak_definition _b
|
|
||||||
.align 2
|
|
||||||
_b:
|
|
||||||
.long 5 ; 0x5
|
|
@ -1,48 +0,0 @@
|
|||||||
// RUN: llvm-mc -triple x86_64-apple-darwin -filetype=obj %s -o - 2>%t.err | llvm-readobj -sections | FileCheck %s
|
|
||||||
// RUN: FileCheck --check-prefix=WARNING < %t.err %s
|
|
||||||
|
|
||||||
// CHECK: Section {
|
|
||||||
// CHECK-NEXT: Index: 0
|
|
||||||
// CHECK-NEXT: Name: __text (
|
|
||||||
|
|
||||||
// CHECK: Section {
|
|
||||||
// CHECK-NEXT: Index: 1
|
|
||||||
// CHECK-NEXT: Name: __textcoal_nt (
|
|
||||||
|
|
||||||
// CHECK: Section {
|
|
||||||
// CHECK-NEXT: Index: 2
|
|
||||||
// CHECK-NEXT: Name: __const_coal (
|
|
||||||
|
|
||||||
// CHECK: Section {
|
|
||||||
// CHECK-NEXT: Index: 3
|
|
||||||
// CHECK-NEXT: Name: __datacoal_nt (
|
|
||||||
|
|
||||||
// WARNING: warning: section "__textcoal_nt" is deprecated
|
|
||||||
// WARNING: note: change section name to "__text"
|
|
||||||
// WARNING: warning: section "__const_coal" is deprecated
|
|
||||||
// WARNING: note: change section name to "__const"
|
|
||||||
// WARNING: warning: section "__datacoal_nt" is deprecated
|
|
||||||
// WARNING: note: change section name to "__data"
|
|
||||||
|
|
||||||
.section __TEXT,__textcoal_nt,coalesced,pure_instructions
|
|
||||||
.globl _foo
|
|
||||||
.weak_definition _foo
|
|
||||||
.align 4, 0x90
|
|
||||||
_foo:
|
|
||||||
retq
|
|
||||||
|
|
||||||
.section __TEXT,__const_coal,coalesced
|
|
||||||
.globl _a ## @a
|
|
||||||
.weak_definition _a
|
|
||||||
.align 4
|
|
||||||
_a:
|
|
||||||
.long 1 ## 0x1
|
|
||||||
|
|
||||||
.section __DATA,__datacoal_nt,coalesced
|
|
||||||
.globl _b ## @b
|
|
||||||
.weak_definition _b
|
|
||||||
.align 2
|
|
||||||
_b:
|
|
||||||
.long 5 ## 0x5
|
|
||||||
|
|
||||||
.subsections_via_symbols
|
|
Loading…
Reference in New Issue
Block a user