forked from OSchip/llvm-project
[mips] Correct section alignments and EntrySizes for .bss, .text, .data, .reginfo, .MIPS.options, and .MIPS.abiflags
Summary: .bss, .text, and .data are at least 16-byte aligned. .reginfo is 4-byte aligned and has a 24-byte EntrySize. .MIPS.abiflags has an 24-byte EntrySize. .MIPS.options is 8-byte aligned and has 1-byte EntrySize. Using a 1-byte EntrySize for .MIPS.options seems strange because the records are neither 1-byte long nor fixed-length but this matches the value that GAS emits. Differential Revision: http://reviews.llvm.org/D4487 llvm-svn: 212939
This commit is contained in:
parent
7ddb0ab85f
commit
8e254166e1
|
@ -323,13 +323,30 @@ void MipsTargetELFStreamer::finish() {
|
|||
MCAssembler &MCA = getStreamer().getAssembler();
|
||||
MCContext &Context = MCA.getContext();
|
||||
MCStreamer &OS = getStreamer();
|
||||
const MCObjectFileInfo &OFI = *Context.getObjectFileInfo();
|
||||
Triple T(STI.getTargetTriple());
|
||||
uint64_t Features = STI.getFeatureBits();
|
||||
|
||||
// .bss, .text and .data are always at least 16-byte aligned.
|
||||
MCSectionData &TextSectionData =
|
||||
MCA.getOrCreateSectionData(*OFI.getTextSection());
|
||||
MCSectionData &DataSectionData =
|
||||
MCA.getOrCreateSectionData(*OFI.getDataSection());
|
||||
MCSectionData &BSSSectionData =
|
||||
MCA.getOrCreateSectionData(*OFI.getBSSSection());
|
||||
|
||||
TextSectionData.setAlignment(std::max(16u, TextSectionData.getAlignment()));
|
||||
DataSectionData.setAlignment(std::max(16u, DataSectionData.getAlignment()));
|
||||
BSSSectionData.setAlignment(std::max(16u, BSSSectionData.getAlignment()));
|
||||
|
||||
if (T.isArch64Bit() && (Features & Mips::FeatureN64)) {
|
||||
const MCSectionELF *Sec = Context.getELFSection(
|
||||
".MIPS.options", ELF::SHT_MIPS_OPTIONS,
|
||||
ELF::SHF_ALLOC | ELF::SHF_MIPS_NOSTRIP, SectionKind::getMetadata());
|
||||
// The EntrySize value of 1 seems strange since the records are neither
|
||||
// 1-byte long nor fixed length but it matches the value GAS emits.
|
||||
const MCSectionELF *Sec =
|
||||
Context.getELFSection(".MIPS.options", ELF::SHT_MIPS_OPTIONS,
|
||||
ELF::SHF_ALLOC | ELF::SHF_MIPS_NOSTRIP,
|
||||
SectionKind::getMetadata(), 1, "");
|
||||
MCA.getOrCreateSectionData(*Sec).setAlignment(8);
|
||||
OS.SwitchSection(Sec);
|
||||
|
||||
OS.EmitIntValue(1, 1); // kind
|
||||
|
@ -346,7 +363,8 @@ void MipsTargetELFStreamer::finish() {
|
|||
} else {
|
||||
const MCSectionELF *Sec =
|
||||
Context.getELFSection(".reginfo", ELF::SHT_MIPS_REGINFO, ELF::SHF_ALLOC,
|
||||
SectionKind::getMetadata());
|
||||
SectionKind::getMetadata(), 24, "");
|
||||
MCA.getOrCreateSectionData(*Sec).setAlignment(4);
|
||||
OS.SwitchSection(Sec);
|
||||
|
||||
OS.EmitIntValue(0, 4); // ri_gprmask
|
||||
|
@ -638,7 +656,7 @@ void MipsTargetELFStreamer::emitMipsAbiFlags() {
|
|||
MCStreamer &OS = getStreamer();
|
||||
const MCSectionELF *Sec =
|
||||
Context.getELFSection(".MIPS.abiflags", ELF::SHT_MIPS_ABIFLAGS,
|
||||
ELF::SHF_ALLOC, SectionKind::getMetadata());
|
||||
ELF::SHF_ALLOC, SectionKind::getMetadata(), 24, "");
|
||||
MCSectionData &ABIShndxSD = MCA.getOrCreateSectionData(*Sec);
|
||||
ABIShndxSD.setAlignment(8);
|
||||
OS.SwitchSection(Sec);
|
||||
|
|
|
@ -14,13 +14,19 @@
|
|||
# check for .MIPS.options
|
||||
# CHECK_64: Sections [
|
||||
# CHECK_64: Section {
|
||||
# CHECK_64: Name: .MIPS.options
|
||||
# CHECK_64-LABEL: Name: .MIPS.options
|
||||
# CHECK_64-NEXT: Type: SHT_MIPS_OPTIONS
|
||||
# CHECK_64-NEXT: Flags [ (0x8000002)
|
||||
# CHECK_64: AddressAlignment: 8
|
||||
# CHECK_64: EntrySize: 1
|
||||
# CHECK_64-LABEL: }
|
||||
|
||||
# check for .reginfo
|
||||
# CHECK_32: Sections [
|
||||
# CHECK_32: Section {
|
||||
# CHECK_32: Name: .reginfo
|
||||
# CHECK_32-LABEL: Name: .reginfo
|
||||
# CHECK_32-NEXT: Type: SHT_MIPS_REGINFO
|
||||
# CHECK_32-NEXT: Flags [ (0x2)
|
||||
# CHECK_32: AddressAlignment: 4
|
||||
# CHECK_32: EntrySize: 24
|
||||
# CHECK_32-LABEL: }
|
||||
|
|
|
@ -10,25 +10,24 @@
|
|||
# Checking if the Mips.abiflags were correctly emitted.
|
||||
# CHECK-OBJ: Section {
|
||||
# CHECK-OBJ: Index: 5
|
||||
# CHECK-OBJ: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ-LABEL: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
|
||||
# CHECK-OBJ: Flags [ (0x2)
|
||||
# CHECK-OBJ: SHF_ALLOC (0x2)
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: Address: 0x0
|
||||
# CHECK-OBJ: Offset: 0x50
|
||||
# CHECK-OBJ: Size: 24
|
||||
# CHECK-OBJ: Link: 0
|
||||
# CHECK-OBJ: Info: 0
|
||||
# CHECK-OBJ: AddressAlignment: 8
|
||||
# CHECK-OBJ: EntrySize: 0
|
||||
# CHECK-OBJ: EntrySize: 24
|
||||
# CHECK-OBJ: Relocations [
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: SectionData (
|
||||
# CHECK-OBJ: 0000: 00002001 01010001 00000000 00000000 |.. .............|
|
||||
# CHECK-OBJ: 0010: 00000001 00000000 |........|
|
||||
# CHECK-OBJ: )
|
||||
# CHECK-OBJ: }
|
||||
# CHECK-OBJ-LABEL: }
|
||||
|
||||
.module fp=32
|
||||
|
||||
|
|
|
@ -11,25 +11,24 @@
|
|||
# Checking if the Mips.abiflags were correctly emitted.
|
||||
# CHECK-OBJ: Section {
|
||||
# CHECK-OBJ: Index: 5
|
||||
# CHECK-OBJ: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ-LABEL: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
|
||||
# CHECK-OBJ: Flags [ (0x2)
|
||||
# CHECK-OBJ: SHF_ALLOC (0x2)
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: Address: 0x0
|
||||
# CHECK-OBJ: Offset: 0x50
|
||||
# CHECK-OBJ: Size: 24
|
||||
# CHECK-OBJ: Link: 0
|
||||
# CHECK-OBJ: Info: 0
|
||||
# CHECK-OBJ: AddressAlignment: 8
|
||||
# CHECK-OBJ: EntrySize: 0
|
||||
# CHECK-OBJ: EntrySize: 24
|
||||
# CHECK-OBJ: Relocations [
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: SectionData (
|
||||
# CHECK-OBJ: 0000: 00002002 01010001 00000000 00000000 |.. .............|
|
||||
# CHECK-OBJ: 0010: 00000001 00000000 |........|
|
||||
# CHECK-OBJ: )
|
||||
# CHECK-OBJ: }
|
||||
# CHECK-OBJ-LABEL: }
|
||||
|
||||
.module fp=32
|
||||
.set fp=64
|
||||
|
|
|
@ -10,25 +10,24 @@
|
|||
# Checking if the Mips.abiflags were correctly emitted.
|
||||
# CHECK-OBJ: Section {
|
||||
# CHECK-OBJ: Index: 5
|
||||
# CHECK-OBJ: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ-LABEL: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
|
||||
# CHECK-OBJ: Flags [ (0x2)
|
||||
# CHECK-OBJ: SHF_ALLOC (0x2)
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: Address: 0x0
|
||||
# CHECK-OBJ: Offset: 0x50
|
||||
# CHECK-OBJ: Size: 24
|
||||
# CHECK-OBJ: Link: 0
|
||||
# CHECK-OBJ: Info: 0
|
||||
# CHECK-OBJ: AddressAlignment: 8
|
||||
# CHECK-OBJ: EntrySize: 0
|
||||
# CHECK-OBJ: EntrySize: 24
|
||||
# CHECK-OBJ: Relocations [
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: SectionData (
|
||||
# CHECK-OBJ: 0000: 00004001 02020001 00000000 00000000 |..@.............|
|
||||
# CHECK-OBJ: 0010: 00000001 00000000 |........|
|
||||
# CHECK-OBJ: )
|
||||
# CHECK-OBJ: }
|
||||
# CHECK-OBJ-LABEL: }
|
||||
|
||||
.module fp=64
|
||||
|
||||
|
|
|
@ -10,25 +10,24 @@
|
|||
# Checking if the Mips.abiflags were correctly emitted.
|
||||
# CHECK-OBJ: Section {
|
||||
# CHECK-OBJ: Index: 5
|
||||
# CHECK-OBJ: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ-LABEL: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
|
||||
# CHECK-OBJ: Flags [ (0x2)
|
||||
# CHECK-OBJ: SHF_ALLOC (0x2)
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: Address: 0x0
|
||||
# CHECK-OBJ: Offset: 0x50
|
||||
# CHECK-OBJ: Size: 24
|
||||
# CHECK-OBJ: Link: 0
|
||||
# CHECK-OBJ: Info: 0
|
||||
# CHECK-OBJ: AddressAlignment: 8
|
||||
# CHECK-OBJ: EntrySize: 0
|
||||
# CHECK-OBJ: EntrySize: 24
|
||||
# CHECK-OBJ: Relocations [
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: SectionData (
|
||||
# CHECK-OBJ: 0000: 00004002 02020001 00000000 00000000 |..@.............|
|
||||
# CHECK-OBJ: 0010: 00000001 00000000 |........|
|
||||
# CHECK-OBJ: )
|
||||
# CHECK-OBJ: }
|
||||
# CHECK-OBJ-LABEL: }
|
||||
|
||||
.module fp=64
|
||||
|
||||
|
|
|
@ -10,25 +10,24 @@
|
|||
# Checking if the Mips.abiflags were correctly emitted.
|
||||
# CHECK-OBJ: Section {
|
||||
# CHECK-OBJ: Index: 5
|
||||
# CHECK-OBJ: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ-LABEL: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
|
||||
# CHECK-OBJ: Flags [ (0x2)
|
||||
# CHECK-OBJ: SHF_ALLOC (0x2)
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: Address: 0x0
|
||||
# CHECK-OBJ: Offset: 0x50
|
||||
# CHECK-OBJ: Size: 24
|
||||
# CHECK-OBJ: Link: 0
|
||||
# CHECK-OBJ: Info: 0
|
||||
# CHECK-OBJ: AddressAlignment: 8
|
||||
# CHECK-OBJ: EntrySize: 0
|
||||
# CHECK-OBJ: EntrySize: 24
|
||||
# CHECK-OBJ: Relocations [
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: SectionData (
|
||||
# CHECK-OBJ: 0000: 00002001 01010005 00000000 00000000 |.. .............|
|
||||
# CHECK-OBJ: 0010: 00000001 00000000 |........|
|
||||
# CHECK-OBJ: )
|
||||
# CHECK-OBJ: }
|
||||
# CHECK-OBJ-LABEL: }
|
||||
|
||||
.module fp=xx
|
||||
|
||||
|
|
|
@ -11,25 +11,24 @@
|
|||
# Checking if the Mips.abiflags were correctly emitted.
|
||||
# CHECK-OBJ: Section {
|
||||
# CHECK-OBJ: Index: 5
|
||||
# CHECK-OBJ: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ-LABEL: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
|
||||
# CHECK-OBJ: Flags [ (0x2)
|
||||
# CHECK-OBJ: SHF_ALLOC (0x2)
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: Address: 0x0
|
||||
# CHECK-OBJ: Offset: 0x50
|
||||
# CHECK-OBJ: Size: 24
|
||||
# CHECK-OBJ: Link: 0
|
||||
# CHECK-OBJ: Info: 0
|
||||
# CHECK-OBJ: AddressAlignment: 8
|
||||
# CHECK-OBJ: EntrySize: 0
|
||||
# CHECK-OBJ: EntrySize: 24
|
||||
# CHECK-OBJ: Relocations [
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: SectionData (
|
||||
# CHECK-OBJ: 0000: 00002001 01010005 00000000 00000000 |.. .............|
|
||||
# CHECK-OBJ: 0010: 00000001 00000000 |........|
|
||||
# CHECK-OBJ: )
|
||||
# CHECK-OBJ: }
|
||||
# CHECK-OBJ-LABEL: }
|
||||
|
||||
.module fp=xx
|
||||
.set fp=64
|
||||
|
|
|
@ -11,25 +11,24 @@
|
|||
# Checking if the Mips.abiflags were correctly emitted.
|
||||
# CHECK-OBJ: Section {
|
||||
# CHECK-OBJ: Index: 5
|
||||
# CHECK-OBJ: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ-LABEL: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
|
||||
# CHECK-OBJ: Flags [ (0x2)
|
||||
# CHECK-OBJ: SHF_ALLOC (0x2)
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: Address: 0x0
|
||||
# CHECK-OBJ: Offset: 0x50
|
||||
# CHECK-OBJ: Size: 24
|
||||
# CHECK-OBJ: Link: 0
|
||||
# CHECK-OBJ: Info: 0
|
||||
# CHECK-OBJ: AddressAlignment: 8
|
||||
# CHECK-OBJ: EntrySize: 0
|
||||
# CHECK-OBJ: EntrySize: 24
|
||||
# CHECK-OBJ: Relocations [
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: SectionData (
|
||||
# CHECK-OBJ: 0000: 00002002 01030001 00000000 00000200 |.. .............|
|
||||
# CHECK-OBJ: 0010: 00000001 00000000 |........|
|
||||
# CHECK-OBJ: )
|
||||
# CHECK-OBJ: }
|
||||
# CHECK-OBJ-LABEL: }
|
||||
|
||||
.module fp=32
|
||||
.set fp=64
|
||||
|
|
|
@ -16,25 +16,24 @@
|
|||
# Checking if the Mips.abiflags were correctly emitted.
|
||||
# CHECK-OBJ: Section {
|
||||
# CHECK-OBJ: Index: 5
|
||||
# CHECK-OBJ: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ-LABEL: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
|
||||
# CHECK-OBJ: Flags [ (0x2)
|
||||
# CHECK-OBJ: SHF_ALLOC (0x2)
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: Address: 0x0
|
||||
# CHECK-OBJ: Offset: 0x50
|
||||
# CHECK-OBJ: Size: 24
|
||||
# CHECK-OBJ: Link: 0
|
||||
# CHECK-OBJ: Info: 0
|
||||
# CHECK-OBJ: AddressAlignment: 8
|
||||
# CHECK-OBJ: EntrySize: 0
|
||||
# CHECK-OBJ: EntrySize: 24
|
||||
# CHECK-OBJ: Relocations [
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: SectionData (
|
||||
# CHECK-OBJ: 0000: 00002001 01020007 00000000 00000000 |.. .............|
|
||||
# CHECK-OBJ: 0010: 00000000 00000000 |........|
|
||||
# CHECK-OBJ: )
|
||||
# CHECK-OBJ: }
|
||||
# CHECK-OBJ-LABEL: }
|
||||
|
||||
# INVALID: ERROR: -mno-odd-spreg requires the O32 ABI
|
||||
|
||||
|
|
|
@ -16,25 +16,24 @@
|
|||
# Checking if the Mips.abiflags were correctly emitted.
|
||||
# CHECK-OBJ: Section {
|
||||
# CHECK-OBJ: Index: 5
|
||||
# CHECK-OBJ: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ-LABEL: Name: .MIPS.abiflags (12)
|
||||
# CHECK-OBJ: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
|
||||
# CHECK-OBJ: Flags [ (0x2)
|
||||
# CHECK-OBJ: SHF_ALLOC (0x2)
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: Address: 0x0
|
||||
# CHECK-OBJ: Offset: 0x50
|
||||
# CHECK-OBJ: Size: 24
|
||||
# CHECK-OBJ: Link: 0
|
||||
# CHECK-OBJ: Info: 0
|
||||
# CHECK-OBJ: AddressAlignment: 8
|
||||
# CHECK-OBJ: EntrySize: 0
|
||||
# CHECK-OBJ: EntrySize: 24
|
||||
# CHECK-OBJ: Relocations [
|
||||
# CHECK-OBJ: ]
|
||||
# CHECK-OBJ: SectionData (
|
||||
# CHECK-OBJ: 0000: 00002001 01020007 00000000 00000000 |.. .............|
|
||||
# CHECK-OBJ: 0010: 00000000 00000000 |........|
|
||||
# CHECK-OBJ: )
|
||||
# CHECK-OBJ: }
|
||||
# CHECK-OBJ-LABEL: }
|
||||
|
||||
# INVALID: '.module nooddspreg' requires the O32 ABI
|
||||
|
||||
|
|
|
@ -38,18 +38,17 @@
|
|||
# Checking if the Mips.abiflags were correctly emitted.
|
||||
# CHECK-OBJ-ALL: Section {
|
||||
# CHECK-OBJ-ALL: Index: 5
|
||||
# CHECK-OBJ-ALL: Name: .MIPS.abiflags ({{[0-9]+}})
|
||||
# CHECK-OBJ-ALL-LABEL: Name: .MIPS.abiflags ({{[0-9]+}})
|
||||
# CHECK-OBJ-ALL: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
|
||||
# CHECK-OBJ-ALL: Flags [ (0x2)
|
||||
# CHECK-OBJ-ALL: SHF_ALLOC (0x2)
|
||||
# CHECK-OBJ-ALL: ]
|
||||
# CHECK-OBJ-ALL: Address: 0x0
|
||||
# CHECK-OBJ-ALL: Offset: 0x{{[0-9A-F]+}}
|
||||
# CHECK-OBJ-ALL: Size: 24
|
||||
# CHECK-OBJ-ALL: Link: 0
|
||||
# CHECK-OBJ-ALL: Info: 0
|
||||
# CHECK-OBJ-ALL: AddressAlignment: 8
|
||||
# CHECK-OBJ-ALL: EntrySize: 0
|
||||
# CHECK-OBJ-ALL: EntrySize: 24
|
||||
# CHECK-OBJ-ALL: Relocations [
|
||||
# CHECK-OBJ-ALL: ]
|
||||
# CHECK-OBJ-ALL: SectionData (
|
||||
|
@ -60,7 +59,7 @@
|
|||
# CHECK-OBJ-N64: 0000: 00004001 02020001 00000000 00000000 |..@.............|
|
||||
# CHECK-OBJ-N64: 0010: 00000001 00000000 |........|
|
||||
# CHECK-OBJ-ALL: )
|
||||
# CHECK-OBJ-ALL: }
|
||||
# CHECK-OBJ-ALL-LABEL: }
|
||||
|
||||
.module oddspreg
|
||||
add.s $f3, $f1, $f5
|
||||
|
|
Loading…
Reference in New Issue