Index: lld/test/ELF/invalid/verneed-shared.test =================================================================== --- lld/test/ELF/invalid/verneed-shared.test +++ lld/test/ELF/invalid/verneed-shared.test @@ -14,10 +14,9 @@ Type: ET_DYN Machine: EM_X86_64 Sections: - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Flags: [ SHF_ALLOC ] - Info: 1 + - Name: .gnu.version_r + Type: SHT_GNU_verneed + Flags: [ SHF_ALLOC ] ShOffset: 0xFFFFFFFF ## A Verneed entry is misaligned (not a multiple of 4). This may happen @@ -37,8 +36,6 @@ - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] - Info: 1 - Link: .dynstr Dependencies: - Version: 1 File: foo @@ -65,7 +62,6 @@ Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] Info: 1 - Link: .dynstr Content: "[[VERNEED]]" DynamicSymbols: - Name: foo Index: llvm/include/llvm/ObjectYAML/ELFYAML.h =================================================================== --- llvm/include/llvm/ObjectYAML/ELFYAML.h +++ llvm/include/llvm/ObjectYAML/ELFYAML.h @@ -427,7 +427,7 @@ struct VerneedSection : Section { Optional> VerneedV; - llvm::yaml::Hex64 Info; + Optional Info; VerneedSection() : Section(ChunkKind::Verneed) {} @@ -531,8 +531,7 @@ struct VerdefSection : Section { Optional> Entries; - - llvm::yaml::Hex64 Info; + Optional Info; VerdefSection() : Section(ChunkKind::Verdef) {} Index: llvm/lib/ObjectYAML/ELFEmitter.cpp =================================================================== --- llvm/lib/ObjectYAML/ELFEmitter.cpp +++ llvm/lib/ObjectYAML/ELFEmitter.cpp @@ -1288,6 +1288,11 @@ void ELFState::writeSectionContent(Elf_Shdr &SHeader, const ELFYAML::SymverSection &Section, ContiguousBlobAccumulator &CBA) { + unsigned Link = 0; + if (!Section.Link && !ExcludedSectionHeaders.count(".dynsym") && + SN2I.lookup(".dynsym", Link)) + SHeader.sh_link = Link; + if (!Section.Entries) return; @@ -1446,7 +1451,16 @@ void ELFState::writeSectionContent(Elf_Shdr &SHeader, const ELFYAML::VerdefSection &Section, ContiguousBlobAccumulator &CBA) { - SHeader.sh_info = Section.Info; + + if (Section.Info) + SHeader.sh_info = *Section.Info; + else if (Section.Entries) + SHeader.sh_info = Section.Entries->size(); + + unsigned Link = 0; + if (!Section.Link && !ExcludedSectionHeaders.count(".dynstr") && + SN2I.lookup(".dynstr", Link)) + SHeader.sh_link = Link; if (!Section.Entries) return; @@ -1488,7 +1502,15 @@ void ELFState::writeSectionContent(Elf_Shdr &SHeader, const ELFYAML::VerneedSection &Section, ContiguousBlobAccumulator &CBA) { - SHeader.sh_info = Section.Info; + if (Section.Info) + SHeader.sh_info = *Section.Info; + else if (Section.VerneedV) + SHeader.sh_info = Section.VerneedV->size(); + + unsigned Link = 0; + if (!Section.Link && !ExcludedSectionHeaders.count(".dynstr") && + SN2I.lookup(".dynstr", Link)) + SHeader.sh_link = Link; if (!Section.VerneedV) return; Index: llvm/lib/ObjectYAML/ELFYAML.cpp =================================================================== --- llvm/lib/ObjectYAML/ELFYAML.cpp +++ llvm/lib/ObjectYAML/ELFYAML.cpp @@ -1203,7 +1203,7 @@ static void sectionMapping(IO &IO, ELFYAML::VerdefSection &Section) { commonSectionMapping(IO, Section); - IO.mapRequired("Info", Section.Info); + IO.mapOptional("Info", Section.Info); IO.mapOptional("Entries", Section.Entries); } @@ -1214,7 +1214,7 @@ static void sectionMapping(IO &IO, ELFYAML::VerneedSection &Section) { commonSectionMapping(IO, Section); - IO.mapRequired("Info", Section.Info); + IO.mapOptional("Info", Section.Info); IO.mapOptional("Dependencies", Section.VerneedV); } Index: llvm/test/Object/invalid.test =================================================================== --- llvm/test/Object/invalid.test +++ llvm/test/Object/invalid.test @@ -644,7 +644,6 @@ Type: SHT_GNU_versym EntSize: 0x0000000000000003 Entries: [ ] - Link: .dynsym ## Needed to trigger creation of .dynsym. DynamicSymbols: - Name: foo Index: llvm/test/tools/llvm-objdump/ELF/verdef.test =================================================================== --- llvm/test/tools/llvm-objdump/ELF/verdef.test +++ llvm/test/tools/llvm-objdump/ELF/verdef.test @@ -18,9 +18,7 @@ Type: SHT_GNU_verdef Flags: [ SHF_ALLOC ] Address: 0x0000000000000230 - Link: .dynstr AddressAlign: 0x0000000000000004 - Info: 0x0000000000000003 Entries: - Version: 1 Flags: 1 Index: llvm/test/tools/llvm-objdump/ELF/verneed.test =================================================================== --- llvm/test/tools/llvm-objdump/ELF/verneed.test +++ llvm/test/tools/llvm-objdump/ELF/verneed.test @@ -22,7 +22,6 @@ Address: 0x0000000000200250 Link: .dynstr AddressAlign: 0x0000000000000004 - Info: 0x0000000000000002 Dependencies: - Version: 1 File: dso.so.0 Index: llvm/test/tools/llvm-readobj/ELF/all.test =================================================================== --- llvm/test/tools/llvm-readobj/ELF/all.test +++ llvm/test/tools/llvm-readobj/ELF/all.test @@ -53,14 +53,11 @@ - Name: .gnu.version Type: SHT_GNU_versym Entries: [ 0 ] - Link: .dynsym - Name: .gnu.version_d Type: SHT_GNU_verdef - Info: 0x0 Entries: [] - Name: .gnu.version_r Type: SHT_GNU_verneed - Info: 0x0 Dependencies: - Version: 1 File: verneed1.so.0 Index: llvm/test/tools/llvm-readobj/ELF/dyn-symbols.test =================================================================== --- llvm/test/tools/llvm-readobj/ELF/dyn-symbols.test +++ llvm/test/tools/llvm-readobj/ELF/dyn-symbols.test @@ -304,9 +304,7 @@ - Name: .gnu.version_d Type: SHT_GNU_verdef Flags: [ SHF_ALLOC ] - Link: .dynstr AddressAlign: 0x4 - Info: 0x2 Entries: - VersionNdx: 2 Names: Index: llvm/test/tools/llvm-readobj/ELF/hidden-versym.test =================================================================== --- llvm/test/tools/llvm-readobj/ELF/hidden-versym.test +++ llvm/test/tools/llvm-readobj/ELF/hidden-versym.test @@ -15,13 +15,10 @@ Type: SHT_GNU_versym Flags: [ SHF_ALLOC ] Address: 0x0000000000200210 - Link: .dynsym Entries: [ 0, 0x8003 ] - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] - Link: .dynstr - Info: 0x0000000000000001 Dependencies: - Version: 1 File: somefile Index: llvm/test/tools/llvm-readobj/ELF/merged.test =================================================================== --- llvm/test/tools/llvm-readobj/ELF/merged.test +++ llvm/test/tools/llvm-readobj/ELF/merged.test @@ -44,7 +44,6 @@ - Name: .gnu.version Type: SHT_GNU_versym Flags: [ SHF_ALLOC ] - Link: .dynsym Entries: [ 0, 1 ] DynamicSymbols: - Name: foo Index: llvm/test/tools/llvm-readobj/ELF/reloc-symbol-with-versioning.test =================================================================== --- llvm/test/tools/llvm-readobj/ELF/reloc-symbol-with-versioning.test +++ llvm/test/tools/llvm-readobj/ELF/reloc-symbol-with-versioning.test @@ -36,9 +36,7 @@ - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] - Link: .dynstr AddressAlign: 0x0000000000000004 - Info: 0x0000000000000002 Dependencies: - Version: 1 File: verneed1.so.0 Index: llvm/test/tools/llvm-readobj/ELF/section-types.test =================================================================== --- llvm/test/tools/llvm-readobj/ELF/section-types.test +++ llvm/test/tools/llvm-readobj/ELF/section-types.test @@ -212,11 +212,9 @@ Content: "" - Name: gnu_verdef Type: SHT_GNU_verdef - Info: 0 Entries: - Name: gnu_verneed Type: SHT_GNU_verneed - Info: 0 Dependencies: - Name: unknown Type: 0x1000 Index: llvm/test/tools/llvm-readobj/ELF/verdef-invalid.test =================================================================== --- llvm/test/tools/llvm-readobj/ELF/verdef-invalid.test +++ llvm/test/tools/llvm-readobj/ELF/verdef-invalid.test @@ -21,7 +21,6 @@ - Name: .gnu.version_d Type: SHT_GNU_verdef Link: [[LINK]] - Info: 0x0 Entries: [] ## Check that we report a warning when the sh_link field of a SHT_GNU_verdef section references a non-string table section. @@ -48,8 +47,6 @@ Sections: - Name: .gnu.version_d Type: SHT_GNU_verdef - Link: .dynstr - Info: 0x0 Entries: [] ShOffset: [[SHOFFSET=]] ShName: [[SHNAME=]] @@ -102,10 +99,8 @@ Data: ELFDATA2LSB Type: ET_DYN Sections: - - Name: .gnu.version_d - Type: SHT_GNU_verdef - Link: .dynstr - Info: 0x1 + - Name: .gnu.version_d + Type: SHT_GNU_verdef Entries: - Names: - FOO @@ -128,10 +123,8 @@ Data: ELFDATA2LSB Type: ET_DYN Sections: - - Name: .gnu.version_d - Type: SHT_GNU_verdef - Link: .dynstr - Info: 0x1 + - Name: .gnu.version_d + Type: SHT_GNU_verdef Entries: - Names: - FOO @@ -168,10 +161,9 @@ Data: ELFDATA2LSB Type: ET_DYN Sections: - - Name: .gnu.version_d - Type: SHT_GNU_verdef - Link: .strtab - Info: 0x1 + - Name: .gnu.version_d + Type: SHT_GNU_verdef + Link: .strtab Entries: - Names: - FOO @@ -286,14 +278,12 @@ - Name: .gnu.version Type: SHT_GNU_versym Flags: [ SHF_ALLOC ] - Link: .dynsym AddressAlign: 0x0000000000000002 EntSize: 0x0000000000000002 Entries: [ 0, 2 ] - Name: .gnu.version_d Type: SHT_GNU_verdef Flags: [ SHF_ALLOC ] - Link: .dynstr AddressAlign: 0x4 Info: 0x1 Entries: [] Index: llvm/test/tools/llvm-readobj/ELF/verneed-flags.yaml =================================================================== --- llvm/test/tools/llvm-readobj/ELF/verneed-flags.yaml +++ llvm/test/tools/llvm-readobj/ELF/verneed-flags.yaml @@ -83,10 +83,8 @@ Type: ET_EXEC Entry: 0x0000000000201000 Sections: - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Link: .dynstr - Info: 0x0000000000000001 + - Name: .gnu.version_r + Type: SHT_GNU_verneed Dependencies: - Version: 1 File: dso.so.0 Index: llvm/test/tools/llvm-readobj/ELF/verneed-invalid.test =================================================================== --- llvm/test/tools/llvm-readobj/ELF/verneed-invalid.test +++ llvm/test/tools/llvm-readobj/ELF/verneed-invalid.test @@ -55,13 +55,10 @@ Type: SHT_GNU_versym Flags: [ SHF_ALLOC ] Address: 0x200210 - Link: .dynsym Entries: [ 0, 2 ] - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] - Link: .dynstr - Info: 1 AddressAlign: 4 Dependencies: - Version: 1 @@ -130,13 +127,11 @@ - Name: .gnu.version Type: SHT_GNU_versym Flags: [ SHF_ALLOC ] - Link: .dynsym Entries: [ 0, 2 ] - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] Link: 0 - Info: 1 AddressAlign: 4 Dependencies: - Version: 1 @@ -178,13 +173,11 @@ - Name: .gnu.version Type: SHT_GNU_versym Flags: [ SHF_ALLOC ] - Link: .dynsym Entries: [ 2 ] - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] Info: 1 - Link: .dynstr AddressAlign: 4 ## The byte offset to the auxiliary entry is 0x11, i.e. it is not correctly aligned in memory. Content: "0100010001000000110000000000000000000000" @@ -244,7 +237,6 @@ - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] - Info: 1 Link: .mystrtab AddressAlign: 4 Dependencies: @@ -299,7 +291,6 @@ - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] - Info: 1 Link: .mystrtab AddressAlign: 4 Dependencies: @@ -352,7 +343,6 @@ - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] - Info: 1 Link: [[LINK=.dynstr]] ShName: [[SHNAME=]] Dependencies: @@ -429,11 +419,9 @@ Data: ELFDATA2LSB Type: ET_EXEC Sections: - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Flags: [ SHF_ALLOC ] - Info: 1 - Link: .dynstr + - Name: .gnu.version_r + Type: SHT_GNU_verneed + Flags: [ SHF_ALLOC ] ShOffset: 0xFFFFFFFF ## Triggers creation of the .dynstr. DynamicSymbols: @@ -454,11 +442,9 @@ Data: ELFDATA2LSB Type: ET_EXEC Sections: - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Flags: [ SHF_ALLOC ] - Info: 1 - Link: .dynstr + - Name: .gnu.version_r + Type: SHT_GNU_verneed + Flags: [ SHF_ALLOC ] ShSize: 0x1 Dependencies: - Version: 1 @@ -490,7 +476,6 @@ - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] - Info: 1 Link: .dynstr Dependencies: - Version: 1 @@ -518,11 +503,9 @@ Data: ELFDATA2LSB Type: ET_EXEC Sections: - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Flags: [ SHF_ALLOC ] - Info: 1 - Link: .dynstr + - Name: .gnu.version_r + Type: SHT_GNU_verneed + Flags: [ SHF_ALLOC ] ShSize: 21 Dependencies: - Version: 1 @@ -553,7 +536,6 @@ Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] Info: 1 - Link: .dynstr ## The byte offset to the auxiliary entry is 0x11, i.e. it is not correctly aligned in memory. Content: "0100010001000000110000000000000000000000" DynamicSymbols: @@ -576,8 +558,6 @@ - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] - Info: 1 - Link: .dynstr Dependencies: - Version: 0xfefe File: foo @@ -625,13 +605,11 @@ - Name: .gnu.version Type: SHT_GNU_versym Flags: [ SHF_ALLOC ] - Link: .dynsym Entries: [ 0, 2 ] - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Flags: [ SHF_ALLOC ] - Link: .custom.dynstr - Info: 1 + - Name: .gnu.version_r + Type: SHT_GNU_verneed + Flags: [ SHF_ALLOC ] + Link: .custom.dynstr AddressAlign: 4 Dependencies: - Version: 1 Index: llvm/test/tools/llvm-readobj/ELF/versioninfo.test =================================================================== --- llvm/test/tools/llvm-readobj/ELF/versioninfo.test +++ llvm/test/tools/llvm-readobj/ELF/versioninfo.test @@ -16,16 +16,12 @@ - Name: .gnu.version Type: SHT_GNU_versym Flags: [ SHF_ALLOC ] - Link: .dynsym AddressAlign: 0x0000000000000002 - EntSize: 0x0000000000000002 Entries: [ 0, 2, 3, 4, 5, 6] - Name: .gnu.version_d Type: SHT_GNU_verdef Flags: [ SHF_ALLOC ] - Link: .dynstr AddressAlign: 0x0000000000000004 - Info: 0x0000000000000006 Entries: - Names: - VERSION1 @@ -53,9 +49,7 @@ - Name: .gnu.version_r Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] - Link: .dynstr AddressAlign: 0x0000000000000004 - Info: 0x0000000000000002 Dependencies: - Version: 1 File: verneed1.so.0 Index: llvm/test/tools/llvm-readobj/ELF/versym-invalid.test =================================================================== --- llvm/test/tools/llvm-readobj/ELF/versym-invalid.test +++ llvm/test/tools/llvm-readobj/ELF/versym-invalid.test @@ -66,7 +66,6 @@ Sections: - Name: .gnu.version Type: SHT_GNU_versym - Link: .dynsym Entries: [ 0 ] - Name: .dynstr Type: SHT_NULL @@ -95,7 +94,6 @@ - Name: .gnu.version Type: SHT_GNU_versym Entries: [ 0 ] - Link: .dynsym ShOffset: [[SHOFFSET=]] ShName: [[SHNAME=]] - Name: .dynsym @@ -149,7 +147,7 @@ # INVALID-ENT-SIZE-GNU-NEXT: 0: 0000000000000000 0 NOTYPE LOCAL DEFAULT UND @ # INVALID-ENT-SIZE-GNU-NEXT: 1: 0000000000000000 0 NOTYPE LOCAL DEFAULT UND foo@ # INVALID-ENT-SIZE-GNU: Version symbols section '.gnu.version' contains 1 entries: -# INVALID-ENT-SIZE-GNU-NEXT: Addr: 0000000000000000 Offset: 0x000040 Link: 0 () +# INVALID-ENT-SIZE-GNU-NEXT: Addr: 0000000000000000 Offset: 0x000040 Link: 2 (.dynsym) # INVALID-ENT-SIZE-GNU-NEXT: warning: '[[FILE]]': cannot read content of SHT_GNU_versym section with index 1: section [index 1] has invalid sh_entsize: expected 2, but got 3 # INVALID-ENT-SIZE-LLVM: DynamicSymbols [ @@ -214,7 +212,6 @@ - Name: .gnu.version Type: SHT_GNU_versym Entries: [ 0, 1 ] - Link: .dynsym DynamicSymbols: - Name: foo - Name: bar Index: llvm/test/tools/obj2yaml/ELF/verdef-section.yaml =================================================================== --- llvm/test/tools/obj2yaml/ELF/verdef-section.yaml +++ llvm/test/tools/obj2yaml/ELF/verdef-section.yaml @@ -1,4 +1,6 @@ ## Check how we dump SHT_GNU_verdef sections. +## Check we don't dump the `Info` field when its value is equal +## to the number of version definitions. # RUN: yaml2obj %s -o %t # RUN: obj2yaml %t | FileCheck %s @@ -9,7 +11,7 @@ # CHECK-NEXT: Address: 0x230 # CHECK-NEXT: Link: .dynstr # CHECK-NEXT: AddressAlign: 0x4 -# CHECK-NEXT: Info: 0x4 +# INFO-NEXT: Info: 0x4 # CHECK-NEXT: Entries: # CHECK-NEXT: - Names: # CHECK-NEXT: - VERSION_0 @@ -37,9 +39,8 @@ Type: SHT_GNU_verdef Flags: [ SHF_ALLOC ] Address: 0x230 - Link: .dynstr AddressAlign: 0x4 - Info: 0x4 + Info: [[INFO=]] Entries: ## An entry that has all fields explicitly set to their default values. ## Used to check that we don't dump them. @@ -66,6 +67,12 @@ ## Needed to emit the .dynstr section. DynamicSymbols: [] +## Check we dump the `Info` field when its value is not equal +## to the number of version definitions. + +# RUN: yaml2obj %s -DINFO=0x4 -o %t.info +# RUN: obj2yaml %t.info | FileCheck %s --check-prefixes=CHECK,INFO + ## Document that we are not able to dump a version definition which ## has a version revision (vd_version) that is not equal to 1. Index: llvm/test/tools/obj2yaml/ELF/verneed-section.yaml =================================================================== --- llvm/test/tools/obj2yaml/ELF/verneed-section.yaml +++ llvm/test/tools/obj2yaml/ELF/verneed-section.yaml @@ -1,15 +1,17 @@ +## Check that we are able to yamalize the SHT_GNU_verneed section. +## Check we don't dump the `Info` field when its value +## is equal to the number of version dependencies. + # RUN: yaml2obj %s -o %t # RUN: obj2yaml %t | FileCheck %s -## Check we are able to yamalize SHT_GNU_verneed section. - # CHECK: - Name: .gnu.version_r # CHECK-NEXT: Type: SHT_GNU_verneed # CHECK-NEXT: Flags: [ SHF_ALLOC ] # CHECK-NEXT: Address: 0x200250 # CHECK-NEXT: Link: .dynstr # CHECK-NEXT: AddressAlign: 0x4 -# CHECK-NEXT: Info: 0x2 +# INFO-NEXT: Info: 0x3 # CHECK-NEXT: Dependencies: # CHECK-NEXT: - Version: 1 # CHECK-NEXT: File: dso.so.0 @@ -37,13 +39,12 @@ Type: ET_EXEC Entry: 0x0000000000201000 Sections: - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Flags: [ SHF_ALLOC ] - Address: 0x200250 - Link: .dynstr - AddressAlign: 4 - Info: 2 + - Name: .gnu.version_r + Type: SHT_GNU_verneed + Flags: [ SHF_ALLOC ] + Address: 0x200250 + AddressAlign: 4 + Info: [[INFO=]] Dependencies: - Version: 1 File: dso.so.0 @@ -66,3 +67,9 @@ DynamicSymbols: - Name: f1 Binding: STB_GLOBAL + +## Check we dump the `Info` field when its value +## is not equal to the number of version dependencies. + +# RUN: yaml2obj %s -DINFO=0x3 -o %t.info +# RUN: obj2yaml %t.info | FileCheck %s --check-prefixes=CHECK,INFO Index: llvm/test/tools/yaml2obj/ELF/override-shname.yaml =================================================================== --- llvm/test/tools/yaml2obj/ELF/override-shname.yaml +++ llvm/test/tools/yaml2obj/ELF/override-shname.yaml @@ -68,14 +68,12 @@ Type: SHT_GNU_versym Entries: [ ] ShName: 0x000000007 - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Info: 0x0000000000000001 + - Name: .gnu.version_r + Type: SHT_GNU_verneed ShName: 0x000000008 Dependencies: - Name: .gnu.version_d Type: SHT_GNU_verdef - Info: 0x0000000000000001 ShName: 0x000000009 Entries: - Name: .regular Index: llvm/test/tools/yaml2obj/ELF/override-shoffset.yaml =================================================================== --- llvm/test/tools/yaml2obj/ELF/override-shoffset.yaml +++ llvm/test/tools/yaml2obj/ELF/override-shoffset.yaml @@ -48,14 +48,12 @@ Type: SHT_GNU_versym Entries: [ ] ShOffset: 0x000000007 - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Info: 0x0000000000000001 + - Name: .gnu.version_r + Type: SHT_GNU_verneed ShOffset: 0x000000008 Dependencies: - Name: .gnu.version_d Type: SHT_GNU_verdef - Info: 0x0000000000000001 ShOffset: 0x000000009 Entries: - Name: .regular Index: llvm/test/tools/yaml2obj/ELF/override-shsize.yaml =================================================================== --- llvm/test/tools/yaml2obj/ELF/override-shsize.yaml +++ llvm/test/tools/yaml2obj/ELF/override-shsize.yaml @@ -48,14 +48,12 @@ Type: SHT_GNU_versym Entries: [ ] ShSize: 0x000000007 - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Info: 0x0000000000000001 + - Name: .gnu.version_r + Type: SHT_GNU_verneed ShSize: 0x000000008 Dependencies: - Name: .gnu.version_d Type: SHT_GNU_verdef - Info: 0x0000000000000001 ShSize: 0x000000009 Entries: - Name: .regular Index: llvm/test/tools/yaml2obj/ELF/override-shtype.yaml =================================================================== --- llvm/test/tools/yaml2obj/ELF/override-shtype.yaml +++ llvm/test/tools/yaml2obj/ELF/override-shtype.yaml @@ -31,7 +31,6 @@ Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] ShType: [[TYPE=SHT_GNU_verneed]] - Info: 0 Dependencies: - Version: 1 File: dso.so.0 Index: llvm/test/tools/yaml2obj/ELF/verdef-section.yaml =================================================================== --- llvm/test/tools/yaml2obj/ELF/verdef-section.yaml +++ llvm/test/tools/yaml2obj/ELF/verdef-section.yaml @@ -1,7 +1,18 @@ ## Test how we create SHT_GNU_verdef sections. +## Check that we link the SHT_GNU_verdef section to +## the `.dynstr` section by default. +## Check that we set the value of `sh_info` field to the +## number of version definitions by default. + # RUN: yaml2obj --docnum=1 %s -o %t1 # RUN: llvm-readobj -V %t1 | FileCheck %s +# RUN: llvm-readelf --sections %t1 | \ +# RUN: FileCheck %s -DLINK=3 -DINFO=4 --check-prefix=FIELDS + +# FIELDS: [Nr] Name Type {{.*}} Flg Lk Inf +# FIELDS: [ 1] .gnu.version_d VERDEF {{.*}} A [[LINK]] [[INFO]] +# FIELDS: [ 3] .dynstr # CHECK: VersionDefinitions [ # CHECK-NEXT: Definition { @@ -56,8 +67,8 @@ - Name: .gnu.version_d Type: SHT_GNU_verdef Flags: [ SHF_ALLOC ] - Link: .dynstr - Info: 0x4 + Info: [[INFO=]] + Link: [[LINK=]] Entries: ## Case 1: an entry that has no Version, Flags, VersionNdx or Hash fields set. ## Used to check values that are written by default. Also shows @@ -92,6 +103,12 @@ - Name: foo Binding: STB_GLOBAL +## Check that we are able to set sh_info and sh_link fields to arbitrary values. + +# RUN: yaml2obj --docnum=1 -DINFO=123 -DLINK=234 %s -o %t1.fields +# RUN: llvm-readelf --sections %t1.fields | \ +# RUN: FileCheck %s -DINFO=123 -DLINK=234 --check-prefix=FIELDS + ## Check we are able to emit a version definition which has a version revision ## (vd_version) field value that is not equal to 1. @@ -114,7 +131,7 @@ # CONTENT-NEXT: Offset: 0x40 # CONTENT-NEXT: Size: 3 # CONTENT-NEXT: Link: 0 -# CONTENT-NEXT: Info: 1 +# CONTENT-NEXT: Info: 0 # CONTENT-NEXT: AddressAlignment: # CONTENT-NEXT: EntrySize: # CONTENT-NEXT: SectionData ( @@ -130,7 +147,6 @@ - Name: .gnu.version_d Type: SHT_GNU_verdef Flags: [ SHF_ALLOC ] - Info: 0x0000000000000001 Content: "112233" ## Check we can omit "Content" and "Entries" fields to produce an empty SHT_GNU_verdef section. @@ -139,7 +155,7 @@ # RUN: llvm-readelf --sections %t3 | FileCheck %s --check-prefix=NO-PROPS # NO-PROPS: [Nr] Name Type Address Off Size ES Flg Lk Inf Al -# NO-PROPS: [ 1] .gnu.version_d VERDEF 0000000000000000 000040 000000 00 A 0 1 0 +# NO-PROPS: [ 1] .gnu.version_d VERDEF 0000000000000000 000040 000000 00 A 0 0 0 --- !ELF FileHeader: @@ -150,7 +166,6 @@ - Name: .gnu.version_d Type: SHT_GNU_verdef Flags: [ SHF_ALLOC ] - Info: 0x0000000000000001 ## Check we can use the "Content" key with the "Size" key when the size is greater ## than or equal to the content size. @@ -168,7 +183,6 @@ Sections: - Name: .gnu.version_d Type: SHT_GNU_verdef - Info: 0x1 Size: [[SIZE=]] Content: [[CONTENT=]] Entries: [[ENTRIES=]] Index: llvm/test/tools/yaml2obj/ELF/verneed-section.yaml =================================================================== --- llvm/test/tools/yaml2obj/ELF/verneed-section.yaml +++ llvm/test/tools/yaml2obj/ELF/verneed-section.yaml @@ -1,7 +1,17 @@ -## Check we are able to handle SHT_GNU_verneed sections. +## Check we are able to dump SHT_GNU_verneed sections properly. +## Check that we link the SHT_GNU_verneed section to +## the `.dynstr` section by default. +## Check that we set the value of `sh_info` field to the number +## of version dependencies by default. # RUN: yaml2obj --docnum=1 %s -o %t1 # RUN: llvm-readobj -V %t1 | FileCheck %s +# RUN: llvm-readelf --sections %t1 | \ +# RUN: FileCheck %s -DLINK=3 -DINFO=2 --check-prefix=FIELDS + +# FIELDS: [Nr] Name Type {{.*}} Flg Lk Inf Al +# FIELDS: [ 1] .gnu.version_r VERNEED {{.*}} A [[LINK]] [[INFO]] 4 +# FIELDS: [ 3] .dynstr # CHECK: VersionRequirements [ # CHECK-NEXT: Dependency { @@ -52,13 +62,13 @@ Type: ET_EXEC Entry: 0x0000000000201000 Sections: - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Flags: [ SHF_ALLOC ] - Address: 0x0000000000200250 - Link: .dynstr - AddressAlign: 0x0000000000000004 - Info: 0x0000000000000002 + - Name: .gnu.version_r + Type: SHT_GNU_verneed + Flags: [ SHF_ALLOC ] + Address: 0x0000000000200250 + AddressAlign: 0x0000000000000004 + Info: [[INFO=]] + Link: [[LINK=]] Dependencies: - Version: 1 File: dso.so.0 @@ -82,6 +92,12 @@ - Name: f1 Binding: STB_GLOBAL +## Check that we are able to set sh_info and sh_link fields to arbitrary values. + +# RUN: yaml2obj --docnum=1 -DINFO=123 -DLINK=234 %s -o %t1.fields +# RUN: llvm-readelf --sections %t1.fields | \ +# RUN: FileCheck %s -DINFO=123 -DLINK=234 --check-prefix=FIELDS + ## Check we can omit "Content", "Size" and "Dependencies" fields to ## produce an empty SHT_GNU_verneed section. @@ -97,10 +113,9 @@ Data: ELFDATA2LSB Type: ET_EXEC Sections: - - Name: .gnu.version_r - Type: SHT_GNU_verneed - Flags: [ SHF_ALLOC ] - Info: 0x0 + - Name: .gnu.version_r + Type: SHT_GNU_verneed + Flags: [ SHF_ALLOC ] Size: [[SIZE=]] Content: [[CONTENT=]] Dependencies: [[DEPS=]] Index: llvm/test/tools/yaml2obj/ELF/versym-section.yaml =================================================================== --- llvm/test/tools/yaml2obj/ELF/versym-section.yaml +++ llvm/test/tools/yaml2obj/ELF/versym-section.yaml @@ -55,7 +55,6 @@ Type: SHT_GNU_versym Flags: [ SHF_ALLOC ] Address: 0x0000000000200210 - Link: .dynsym AddressAlign: 0x0000000000000002 EntSize: 0x0000000000000002 Entries: [ 0, 3, 4 ] @@ -63,9 +62,7 @@ Type: SHT_GNU_verneed Flags: [ SHF_ALLOC ] Address: 0x0000000000200250 - Link: .dynstr AddressAlign: 0x0000000000000004 - Info: 0x0000000000000001 Dependencies: - Version: 1 File: dso.so.0 @@ -86,13 +83,15 @@ ... ## Check we are able to set custom sh_entsize field for SHT_GNU_versym section. +## Check we link it to the .dynsym section by default. # RUN: yaml2obj --docnum=2 %s -o %t2 -# RUN: llvm-readelf -S %t2 | FileCheck %s --check-prefix=ENTSIZE +# RUN: llvm-readelf -S %t2 | FileCheck %s -DLINK=2 --check-prefix=FIELDS -# ENTSIZE: Section Headers: -# ENTSIZE: [Nr] Name Type Address Off Size ES -# ENTSIZE: [ 1] .gnu.version VERSYM 0000000000000000 000040 000000 03 +# FIELDS: Section Headers: +# FIELDS: [Nr] Name Type Address Off Size ES Flg Lk +# FIELDS: [ 1] .gnu.version VERSYM 0000000000000000 000040 000000 03 [[LINK]] +# FIELDS: [ 2] .dynsym DYNSYM 0000000000000000 000040 000018 18 A 3 --- !ELF FileHeader: @@ -105,6 +104,14 @@ Type: SHT_GNU_versym EntSize: 0x0000000000000003 Entries: [ ] + Link: [[LINK=]] +## Needed to emit the .dynsym section. +DynamicSymbols: [] + +## Check we are able to set the sh_link field to an arbitrary value. + +# RUN: yaml2obj --docnum=2 -DLINK=0xff %s -o %t2.link +# RUN: llvm-readelf -S %t2.link | FileCheck %s -DLINK=255 --check-prefix=FIELDS ## Check we can use the "Content" key with the "Size" key when the size is greater ## than or equal to the content size. Index: llvm/tools/obj2yaml/elf2yaml.cpp =================================================================== --- llvm/tools/obj2yaml/elf2yaml.cpp +++ llvm/tools/obj2yaml/elf2yaml.cpp @@ -1294,8 +1294,6 @@ if (Error E = dumpCommonSection(Shdr, *S)) return std::move(E); - S->Info = Shdr->sh_info; - auto StringTableShdrOrErr = Obj.getSection(Shdr->sh_link); if (!StringTableShdrOrErr) return StringTableShdrOrErr.takeError(); @@ -1342,6 +1340,9 @@ Buf = Verdef->vd_next ? Buf + Verdef->vd_next : nullptr; } + if (Shdr->sh_info != S->Entries->size()) + S->Info = (llvm::yaml::Hex64)Shdr->sh_info; + return S.release(); } @@ -1370,8 +1371,6 @@ if (Error E = dumpCommonSection(Shdr, *S)) return std::move(E); - S->Info = Shdr->sh_info; - auto Contents = Obj.getSectionContents(*Shdr); if (!Contents) return Contents.takeError(); @@ -1416,6 +1415,9 @@ Buf = Verneed->vn_next ? Buf + Verneed->vn_next : nullptr; } + if (Shdr->sh_info != S->VerneedV->size()) + S->Info = (llvm::yaml::Hex64)Shdr->sh_info; + return S.release(); }