Re-commit: [mips] Correct section alignments and EntrySizes for .bss, .text, .data, .reginfo, .MIPS.options, and .MIPS.abiflags

The lld tests will temporarily fail again but Simon Atanasyan will commit a fix for those shortly.



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@212946 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Daniel Sanders 2014-07-14 15:05:51 +00:00
parent b70b4892a4
commit 52a51e197f
12 changed files with 235 additions and 221 deletions

View File

@ -323,13 +323,30 @@ void MipsTargetELFStreamer::finish() {
MCAssembler &MCA = getStreamer().getAssembler(); MCAssembler &MCA = getStreamer().getAssembler();
MCContext &Context = MCA.getContext(); MCContext &Context = MCA.getContext();
MCStreamer &OS = getStreamer(); MCStreamer &OS = getStreamer();
const MCObjectFileInfo &OFI = *Context.getObjectFileInfo();
Triple T(STI.getTargetTriple()); Triple T(STI.getTargetTriple());
uint64_t Features = STI.getFeatureBits(); 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)) { if (T.isArch64Bit() && (Features & Mips::FeatureN64)) {
const MCSectionELF *Sec = Context.getELFSection( // The EntrySize value of 1 seems strange since the records are neither
".MIPS.options", ELF::SHT_MIPS_OPTIONS, // 1-byte long nor fixed length but it matches the value GAS emits.
ELF::SHF_ALLOC | ELF::SHF_MIPS_NOSTRIP, SectionKind::getMetadata()); 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.SwitchSection(Sec);
OS.EmitIntValue(1, 1); // kind OS.EmitIntValue(1, 1); // kind
@ -346,7 +363,8 @@ void MipsTargetELFStreamer::finish() {
} else { } else {
const MCSectionELF *Sec = const MCSectionELF *Sec =
Context.getELFSection(".reginfo", ELF::SHT_MIPS_REGINFO, ELF::SHF_ALLOC, Context.getELFSection(".reginfo", ELF::SHT_MIPS_REGINFO, ELF::SHF_ALLOC,
SectionKind::getMetadata()); SectionKind::getMetadata(), 24, "");
MCA.getOrCreateSectionData(*Sec).setAlignment(4);
OS.SwitchSection(Sec); OS.SwitchSection(Sec);
OS.EmitIntValue(0, 4); // ri_gprmask OS.EmitIntValue(0, 4); // ri_gprmask
@ -638,7 +656,7 @@ void MipsTargetELFStreamer::emitMipsAbiFlags() {
MCStreamer &OS = getStreamer(); MCStreamer &OS = getStreamer();
const MCSectionELF *Sec = const MCSectionELF *Sec =
Context.getELFSection(".MIPS.abiflags", ELF::SHT_MIPS_ABIFLAGS, Context.getELFSection(".MIPS.abiflags", ELF::SHT_MIPS_ABIFLAGS,
ELF::SHF_ALLOC, SectionKind::getMetadata()); ELF::SHF_ALLOC, SectionKind::getMetadata(), 24, "");
MCSectionData &ABIShndxSD = MCA.getOrCreateSectionData(*Sec); MCSectionData &ABIShndxSD = MCA.getOrCreateSectionData(*Sec);
ABIShndxSD.setAlignment(8); ABIShndxSD.setAlignment(8);
OS.SwitchSection(Sec); OS.SwitchSection(Sec);

View File

@ -14,13 +14,19 @@
# check for .MIPS.options # check for .MIPS.options
# CHECK_64: Sections [ # CHECK_64: Sections [
# CHECK_64: Section { # CHECK_64: Section {
# CHECK_64: Name: .MIPS.options # CHECK_64-LABEL: Name: .MIPS.options
# CHECK_64-NEXT: Type: SHT_MIPS_OPTIONS # CHECK_64-NEXT: Type: SHT_MIPS_OPTIONS
# CHECK_64-NEXT: Flags [ (0x8000002) # CHECK_64-NEXT: Flags [ (0x8000002)
# CHECK_64: AddressAlignment: 8
# CHECK_64: EntrySize: 1
# CHECK_64-LABEL: }
# check for .reginfo # check for .reginfo
# CHECK_32: Sections [ # CHECK_32: Sections [
# CHECK_32: Section { # CHECK_32: Section {
# CHECK_32: Name: .reginfo # CHECK_32-LABEL: Name: .reginfo
# CHECK_32-NEXT: Type: SHT_MIPS_REGINFO # CHECK_32-NEXT: Type: SHT_MIPS_REGINFO
# CHECK_32-NEXT: Flags [ (0x2) # CHECK_32-NEXT: Flags [ (0x2)
# CHECK_32: AddressAlignment: 4
# CHECK_32: EntrySize: 24
# CHECK_32-LABEL: }

View File

@ -8,27 +8,26 @@
# CHECK-ASM: .module fp=32 # CHECK-ASM: .module fp=32
# Checking if the Mips.abiflags were correctly emitted. # Checking if the Mips.abiflags were correctly emitted.
# CHECK-OBJ: Section { # CHECK-OBJ: Section {
# CHECK-OBJ: Index: 5 # 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: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
# CHECK-OBJ: Flags [ (0x2) # CHECK-OBJ: Flags [ (0x2)
# CHECK-OBJ: SHF_ALLOC (0x2) # CHECK-OBJ: SHF_ALLOC (0x2)
# CHECK-OBJ: ] # CHECK-OBJ: ]
# CHECK-OBJ: Address: 0x0 # CHECK-OBJ: Address: 0x0
# CHECK-OBJ: Offset: 0x50 # CHECK-OBJ: Size: 24
# CHECK-OBJ: Size: 24 # CHECK-OBJ: Link: 0
# CHECK-OBJ: Link: 0 # CHECK-OBJ: Info: 0
# CHECK-OBJ: Info: 0 # CHECK-OBJ: AddressAlignment: 8
# CHECK-OBJ: AddressAlignment: 8 # CHECK-OBJ: EntrySize: 24
# CHECK-OBJ: EntrySize: 0 # CHECK-OBJ: Relocations [
# CHECK-OBJ: Relocations [ # CHECK-OBJ: ]
# CHECK-OBJ: ] # CHECK-OBJ: SectionData (
# CHECK-OBJ: SectionData ( # CHECK-OBJ: 0000: 00002001 01010001 00000000 00000000 |.. .............|
# CHECK-OBJ: 0000: 00002001 01010001 00000000 00000000 |.. .............| # CHECK-OBJ: 0010: 00000001 00000000 |........|
# CHECK-OBJ: 0010: 00000001 00000000 |........| # CHECK-OBJ: )
# CHECK-OBJ: ) # CHECK-OBJ-LABEL: }
# CHECK-OBJ: }
.module fp=32 .module fp=32

View File

@ -9,27 +9,26 @@
# CHECK-ASM: .set fp=64 # CHECK-ASM: .set fp=64
# Checking if the Mips.abiflags were correctly emitted. # Checking if the Mips.abiflags were correctly emitted.
# CHECK-OBJ: Section { # CHECK-OBJ: Section {
# CHECK-OBJ: Index: 5 # 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: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
# CHECK-OBJ: Flags [ (0x2) # CHECK-OBJ: Flags [ (0x2)
# CHECK-OBJ: SHF_ALLOC (0x2) # CHECK-OBJ: SHF_ALLOC (0x2)
# CHECK-OBJ: ] # CHECK-OBJ: ]
# CHECK-OBJ: Address: 0x0 # CHECK-OBJ: Address: 0x0
# CHECK-OBJ: Offset: 0x50 # CHECK-OBJ: Size: 24
# CHECK-OBJ: Size: 24 # CHECK-OBJ: Link: 0
# CHECK-OBJ: Link: 0 # CHECK-OBJ: Info: 0
# CHECK-OBJ: Info: 0 # CHECK-OBJ: AddressAlignment: 8
# CHECK-OBJ: AddressAlignment: 8 # CHECK-OBJ: EntrySize: 24
# CHECK-OBJ: EntrySize: 0 # CHECK-OBJ: Relocations [
# CHECK-OBJ: Relocations [ # CHECK-OBJ: ]
# CHECK-OBJ: ] # CHECK-OBJ: SectionData (
# CHECK-OBJ: SectionData ( # CHECK-OBJ: 0000: 00002002 01010001 00000000 00000000 |.. .............|
# CHECK-OBJ: 0000: 00002002 01010001 00000000 00000000 |.. .............| # CHECK-OBJ: 0010: 00000001 00000000 |........|
# CHECK-OBJ: 0010: 00000001 00000000 |........| # CHECK-OBJ: )
# CHECK-OBJ: ) # CHECK-OBJ-LABEL: }
# CHECK-OBJ: }
.module fp=32 .module fp=32
.set fp=64 .set fp=64

View File

@ -8,27 +8,26 @@
# CHECK-ASM: .module fp=64 # CHECK-ASM: .module fp=64
# Checking if the Mips.abiflags were correctly emitted. # Checking if the Mips.abiflags were correctly emitted.
# CHECK-OBJ: Section { # CHECK-OBJ: Section {
# CHECK-OBJ: Index: 5 # 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: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
# CHECK-OBJ: Flags [ (0x2) # CHECK-OBJ: Flags [ (0x2)
# CHECK-OBJ: SHF_ALLOC (0x2) # CHECK-OBJ: SHF_ALLOC (0x2)
# CHECK-OBJ: ] # CHECK-OBJ: ]
# CHECK-OBJ: Address: 0x0 # CHECK-OBJ: Address: 0x0
# CHECK-OBJ: Offset: 0x50 # CHECK-OBJ: Size: 24
# CHECK-OBJ: Size: 24 # CHECK-OBJ: Link: 0
# CHECK-OBJ: Link: 0 # CHECK-OBJ: Info: 0
# CHECK-OBJ: Info: 0 # CHECK-OBJ: AddressAlignment: 8
# CHECK-OBJ: AddressAlignment: 8 # CHECK-OBJ: EntrySize: 24
# CHECK-OBJ: EntrySize: 0 # CHECK-OBJ: Relocations [
# CHECK-OBJ: Relocations [ # CHECK-OBJ: ]
# CHECK-OBJ: ] # CHECK-OBJ: SectionData (
# CHECK-OBJ: SectionData ( # CHECK-OBJ: 0000: 00004001 02020001 00000000 00000000 |..@.............|
# CHECK-OBJ: 0000: 00004001 02020001 00000000 00000000 |..@.............| # CHECK-OBJ: 0010: 00000001 00000000 |........|
# CHECK-OBJ: 0010: 00000001 00000000 |........| # CHECK-OBJ: )
# CHECK-OBJ: ) # CHECK-OBJ-LABEL: }
# CHECK-OBJ: }
.module fp=64 .module fp=64

View File

@ -8,27 +8,26 @@
# CHECK-ASM: .module fp=64 # CHECK-ASM: .module fp=64
# Checking if the Mips.abiflags were correctly emitted. # Checking if the Mips.abiflags were correctly emitted.
# CHECK-OBJ: Section { # CHECK-OBJ: Section {
# CHECK-OBJ: Index: 5 # 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: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
# CHECK-OBJ: Flags [ (0x2) # CHECK-OBJ: Flags [ (0x2)
# CHECK-OBJ: SHF_ALLOC (0x2) # CHECK-OBJ: SHF_ALLOC (0x2)
# CHECK-OBJ: ] # CHECK-OBJ: ]
# CHECK-OBJ: Address: 0x0 # CHECK-OBJ: Address: 0x0
# CHECK-OBJ: Offset: 0x50 # CHECK-OBJ: Size: 24
# CHECK-OBJ: Size: 24 # CHECK-OBJ: Link: 0
# CHECK-OBJ: Link: 0 # CHECK-OBJ: Info: 0
# CHECK-OBJ: Info: 0 # CHECK-OBJ: AddressAlignment: 8
# CHECK-OBJ: AddressAlignment: 8 # CHECK-OBJ: EntrySize: 24
# CHECK-OBJ: EntrySize: 0 # CHECK-OBJ: Relocations [
# CHECK-OBJ: Relocations [ # CHECK-OBJ: ]
# CHECK-OBJ: ] # CHECK-OBJ: SectionData (
# CHECK-OBJ: SectionData ( # CHECK-OBJ: 0000: 00004002 02020001 00000000 00000000 |..@.............|
# CHECK-OBJ: 0000: 00004002 02020001 00000000 00000000 |..@.............| # CHECK-OBJ: 0010: 00000001 00000000 |........|
# CHECK-OBJ: 0010: 00000001 00000000 |........| # CHECK-OBJ: )
# CHECK-OBJ: ) # CHECK-OBJ-LABEL: }
# CHECK-OBJ: }
.module fp=64 .module fp=64

View File

@ -8,27 +8,26 @@
# CHECK-ASM: .module fp=xx # CHECK-ASM: .module fp=xx
# Checking if the Mips.abiflags were correctly emitted. # Checking if the Mips.abiflags were correctly emitted.
# CHECK-OBJ: Section { # CHECK-OBJ: Section {
# CHECK-OBJ: Index: 5 # 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: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
# CHECK-OBJ: Flags [ (0x2) # CHECK-OBJ: Flags [ (0x2)
# CHECK-OBJ: SHF_ALLOC (0x2) # CHECK-OBJ: SHF_ALLOC (0x2)
# CHECK-OBJ: ] # CHECK-OBJ: ]
# CHECK-OBJ: Address: 0x0 # CHECK-OBJ: Address: 0x0
# CHECK-OBJ: Offset: 0x50 # CHECK-OBJ: Size: 24
# CHECK-OBJ: Size: 24 # CHECK-OBJ: Link: 0
# CHECK-OBJ: Link: 0 # CHECK-OBJ: Info: 0
# CHECK-OBJ: Info: 0 # CHECK-OBJ: AddressAlignment: 8
# CHECK-OBJ: AddressAlignment: 8 # CHECK-OBJ: EntrySize: 24
# CHECK-OBJ: EntrySize: 0 # CHECK-OBJ: Relocations [
# CHECK-OBJ: Relocations [ # CHECK-OBJ: ]
# CHECK-OBJ: ] # CHECK-OBJ: SectionData (
# CHECK-OBJ: SectionData ( # CHECK-OBJ: 0000: 00002001 01010005 00000000 00000000 |.. .............|
# CHECK-OBJ: 0000: 00002001 01010005 00000000 00000000 |.. .............| # CHECK-OBJ: 0010: 00000001 00000000 |........|
# CHECK-OBJ: 0010: 00000001 00000000 |........| # CHECK-OBJ: )
# CHECK-OBJ: ) # CHECK-OBJ-LABEL: }
# CHECK-OBJ: }
.module fp=xx .module fp=xx

View File

@ -9,27 +9,26 @@
# CHECK-ASM: .set fp=64 # CHECK-ASM: .set fp=64
# Checking if the Mips.abiflags were correctly emitted. # Checking if the Mips.abiflags were correctly emitted.
# CHECK-OBJ: Section { # CHECK-OBJ: Section {
# CHECK-OBJ: Index: 5 # 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: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
# CHECK-OBJ: Flags [ (0x2) # CHECK-OBJ: Flags [ (0x2)
# CHECK-OBJ: SHF_ALLOC (0x2) # CHECK-OBJ: SHF_ALLOC (0x2)
# CHECK-OBJ: ] # CHECK-OBJ: ]
# CHECK-OBJ: Address: 0x0 # CHECK-OBJ: Address: 0x0
# CHECK-OBJ: Offset: 0x50 # CHECK-OBJ: Size: 24
# CHECK-OBJ: Size: 24 # CHECK-OBJ: Link: 0
# CHECK-OBJ: Link: 0 # CHECK-OBJ: Info: 0
# CHECK-OBJ: Info: 0 # CHECK-OBJ: AddressAlignment: 8
# CHECK-OBJ: AddressAlignment: 8 # CHECK-OBJ: EntrySize: 24
# CHECK-OBJ: EntrySize: 0 # CHECK-OBJ: Relocations [
# CHECK-OBJ: Relocations [ # CHECK-OBJ: ]
# CHECK-OBJ: ] # CHECK-OBJ: SectionData (
# CHECK-OBJ: SectionData ( # CHECK-OBJ: 0000: 00002001 01010005 00000000 00000000 |.. .............|
# CHECK-OBJ: 0000: 00002001 01010005 00000000 00000000 |.. .............| # CHECK-OBJ: 0010: 00000001 00000000 |........|
# CHECK-OBJ: 0010: 00000001 00000000 |........| # CHECK-OBJ: )
# CHECK-OBJ: ) # CHECK-OBJ-LABEL: }
# CHECK-OBJ: }
.module fp=xx .module fp=xx
.set fp=64 .set fp=64

View File

@ -9,27 +9,26 @@
# CHECK-ASM: .set fp=64 # CHECK-ASM: .set fp=64
# Checking if the Mips.abiflags were correctly emitted. # Checking if the Mips.abiflags were correctly emitted.
# CHECK-OBJ: Section { # CHECK-OBJ: Section {
# CHECK-OBJ: Index: 5 # 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: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
# CHECK-OBJ: Flags [ (0x2) # CHECK-OBJ: Flags [ (0x2)
# CHECK-OBJ: SHF_ALLOC (0x2) # CHECK-OBJ: SHF_ALLOC (0x2)
# CHECK-OBJ: ] # CHECK-OBJ: ]
# CHECK-OBJ: Address: 0x0 # CHECK-OBJ: Address: 0x0
# CHECK-OBJ: Offset: 0x50 # CHECK-OBJ: Size: 24
# CHECK-OBJ: Size: 24 # CHECK-OBJ: Link: 0
# CHECK-OBJ: Link: 0 # CHECK-OBJ: Info: 0
# CHECK-OBJ: Info: 0 # CHECK-OBJ: AddressAlignment: 8
# CHECK-OBJ: AddressAlignment: 8 # CHECK-OBJ: EntrySize: 24
# CHECK-OBJ: EntrySize: 0 # CHECK-OBJ: Relocations [
# CHECK-OBJ: Relocations [ # CHECK-OBJ: ]
# CHECK-OBJ: ] # CHECK-OBJ: SectionData (
# CHECK-OBJ: SectionData ( # CHECK-OBJ: 0000: 00002002 01030001 00000000 00000200 |.. .............|
# CHECK-OBJ: 0000: 00002002 01030001 00000000 00000200 |.. .............| # CHECK-OBJ: 0010: 00000001 00000000 |........|
# CHECK-OBJ: 0010: 00000001 00000000 |........| # CHECK-OBJ: )
# CHECK-OBJ: ) # CHECK-OBJ-LABEL: }
# CHECK-OBJ: }
.module fp=32 .module fp=32
.set fp=64 .set fp=64

View File

@ -14,27 +14,26 @@
# CHECK-ASM-NOT: .module nooddspreg # CHECK-ASM-NOT: .module nooddspreg
# Checking if the Mips.abiflags were correctly emitted. # Checking if the Mips.abiflags were correctly emitted.
# CHECK-OBJ: Section { # CHECK-OBJ: Section {
# CHECK-OBJ: Index: 5 # 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: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
# CHECK-OBJ: Flags [ (0x2) # CHECK-OBJ: Flags [ (0x2)
# CHECK-OBJ: SHF_ALLOC (0x2) # CHECK-OBJ: SHF_ALLOC (0x2)
# CHECK-OBJ: ] # CHECK-OBJ: ]
# CHECK-OBJ: Address: 0x0 # CHECK-OBJ: Address: 0x0
# CHECK-OBJ: Offset: 0x50 # CHECK-OBJ: Size: 24
# CHECK-OBJ: Size: 24 # CHECK-OBJ: Link: 0
# CHECK-OBJ: Link: 0 # CHECK-OBJ: Info: 0
# CHECK-OBJ: Info: 0 # CHECK-OBJ: AddressAlignment: 8
# CHECK-OBJ: AddressAlignment: 8 # CHECK-OBJ: EntrySize: 24
# CHECK-OBJ: EntrySize: 0 # CHECK-OBJ: Relocations [
# CHECK-OBJ: Relocations [ # CHECK-OBJ: ]
# CHECK-OBJ: ] # CHECK-OBJ: SectionData (
# CHECK-OBJ: SectionData ( # CHECK-OBJ: 0000: 00002001 01020007 00000000 00000000 |.. .............|
# CHECK-OBJ: 0000: 00002001 01020007 00000000 00000000 |.. .............| # CHECK-OBJ: 0010: 00000000 00000000 |........|
# CHECK-OBJ: 0010: 00000000 00000000 |........| # CHECK-OBJ: )
# CHECK-OBJ: ) # CHECK-OBJ-LABEL: }
# CHECK-OBJ: }
# INVALID: ERROR: -mno-odd-spreg requires the O32 ABI # INVALID: ERROR: -mno-odd-spreg requires the O32 ABI

View File

@ -14,27 +14,26 @@
# CHECK-ASM: .module nooddspreg # CHECK-ASM: .module nooddspreg
# Checking if the Mips.abiflags were correctly emitted. # Checking if the Mips.abiflags were correctly emitted.
# CHECK-OBJ: Section { # CHECK-OBJ: Section {
# CHECK-OBJ: Index: 5 # 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: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
# CHECK-OBJ: Flags [ (0x2) # CHECK-OBJ: Flags [ (0x2)
# CHECK-OBJ: SHF_ALLOC (0x2) # CHECK-OBJ: SHF_ALLOC (0x2)
# CHECK-OBJ: ] # CHECK-OBJ: ]
# CHECK-OBJ: Address: 0x0 # CHECK-OBJ: Address: 0x0
# CHECK-OBJ: Offset: 0x50 # CHECK-OBJ: Size: 24
# CHECK-OBJ: Size: 24 # CHECK-OBJ: Link: 0
# CHECK-OBJ: Link: 0 # CHECK-OBJ: Info: 0
# CHECK-OBJ: Info: 0 # CHECK-OBJ: AddressAlignment: 8
# CHECK-OBJ: AddressAlignment: 8 # CHECK-OBJ: EntrySize: 24
# CHECK-OBJ: EntrySize: 0 # CHECK-OBJ: Relocations [
# CHECK-OBJ: Relocations [ # CHECK-OBJ: ]
# CHECK-OBJ: ] # CHECK-OBJ: SectionData (
# CHECK-OBJ: SectionData ( # CHECK-OBJ: 0000: 00002001 01020007 00000000 00000000 |.. .............|
# CHECK-OBJ: 0000: 00002001 01020007 00000000 00000000 |.. .............| # CHECK-OBJ: 0010: 00000000 00000000 |........|
# CHECK-OBJ: 0010: 00000000 00000000 |........| # CHECK-OBJ: )
# CHECK-OBJ: ) # CHECK-OBJ-LABEL: }
# CHECK-OBJ: }
# INVALID: '.module nooddspreg' requires the O32 ABI # INVALID: '.module nooddspreg' requires the O32 ABI

View File

@ -36,31 +36,30 @@
# CHECK-ASM: .module oddspreg # CHECK-ASM: .module oddspreg
# Checking if the Mips.abiflags were correctly emitted. # Checking if the Mips.abiflags were correctly emitted.
# CHECK-OBJ-ALL: Section { # CHECK-OBJ-ALL: Section {
# CHECK-OBJ-ALL: Index: 5 # 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: Type: SHT_MIPS_ABIFLAGS (0x7000002A)
# CHECK-OBJ-ALL: Flags [ (0x2) # CHECK-OBJ-ALL: Flags [ (0x2)
# CHECK-OBJ-ALL: SHF_ALLOC (0x2) # CHECK-OBJ-ALL: SHF_ALLOC (0x2)
# CHECK-OBJ-ALL: ] # CHECK-OBJ-ALL: ]
# CHECK-OBJ-ALL: Address: 0x0 # CHECK-OBJ-ALL: Address: 0x0
# CHECK-OBJ-ALL: Offset: 0x{{[0-9A-F]+}} # CHECK-OBJ-ALL: Size: 24
# CHECK-OBJ-ALL: Size: 24 # CHECK-OBJ-ALL: Link: 0
# CHECK-OBJ-ALL: Link: 0 # CHECK-OBJ-ALL: Info: 0
# CHECK-OBJ-ALL: Info: 0 # CHECK-OBJ-ALL: AddressAlignment: 8
# CHECK-OBJ-ALL: AddressAlignment: 8 # CHECK-OBJ-ALL: EntrySize: 24
# CHECK-OBJ-ALL: EntrySize: 0 # CHECK-OBJ-ALL: Relocations [
# CHECK-OBJ-ALL: Relocations [ # CHECK-OBJ-ALL: ]
# CHECK-OBJ-ALL: ] # CHECK-OBJ-ALL: SectionData (
# CHECK-OBJ-ALL: SectionData ( # CHECK-OBJ-O32: 0000: 00002001 01020006 00000000 00000000 |.. .............|
# CHECK-OBJ-O32: 0000: 00002001 01020006 00000000 00000000 |.. .............| # CHECK-OBJ-O32: 0010: 00000001 00000000 |........|
# CHECK-OBJ-O32: 0010: 00000001 00000000 |........| # CHECK-OBJ-N32: 0000: 00004001 02020001 00000000 00000000 |..@.............|
# CHECK-OBJ-N32: 0000: 00004001 02020001 00000000 00000000 |..@.............| # CHECK-OBJ-N32: 0010: 00000001 00000000 |........|
# CHECK-OBJ-N32: 0010: 00000001 00000000 |........| # CHECK-OBJ-N64: 0000: 00004001 02020001 00000000 00000000 |..@.............|
# CHECK-OBJ-N64: 0000: 00004001 02020001 00000000 00000000 |..@.............| # CHECK-OBJ-N64: 0010: 00000001 00000000 |........|
# CHECK-OBJ-N64: 0010: 00000001 00000000 |........| # CHECK-OBJ-ALL: )
# CHECK-OBJ-ALL: ) # CHECK-OBJ-ALL-LABEL: }
# CHECK-OBJ-ALL: }
.module oddspreg .module oddspreg
add.s $f3, $f1, $f5 add.s $f3, $f1, $f5