Index: llvm/include/llvm/ObjectYAML/ELFYAML.h =================================================================== --- llvm/include/llvm/ObjectYAML/ELFYAML.h +++ llvm/include/llvm/ObjectYAML/ELFYAML.h @@ -106,8 +106,8 @@ Optional Section; Optional Index; ELF_STB Binding; - llvm::yaml::Hex64 Value; - llvm::yaml::Hex64 Size; + Optional Value; + Optional Size; Optional Other; Optional StName; Index: llvm/lib/ObjectYAML/ELFEmitter.cpp =================================================================== --- llvm/lib/ObjectYAML/ELFEmitter.cpp +++ llvm/lib/ObjectYAML/ELFEmitter.cpp @@ -837,9 +837,9 @@ else if (Sym.Index) Symbol.st_shndx = *Sym.Index; - Symbol.st_value = Sym.Value; + Symbol.st_value = Sym.Value.getValueOr(yaml::Hex64(0)); Symbol.st_other = Sym.Other ? *Sym.Other : 0; - Symbol.st_size = Sym.Size; + Symbol.st_size = Sym.Size.getValueOr(yaml::Hex64(0)); } return Ret; Index: llvm/lib/ObjectYAML/ELFYAML.cpp =================================================================== --- llvm/lib/ObjectYAML/ELFYAML.cpp +++ llvm/lib/ObjectYAML/ELFYAML.cpp @@ -1089,8 +1089,8 @@ IO.mapOptional("Section", Symbol.Section); IO.mapOptional("Index", Symbol.Index); IO.mapOptional("Binding", Symbol.Binding, ELFYAML::ELF_STB(0)); - IO.mapOptional("Value", Symbol.Value, Hex64(0)); - IO.mapOptional("Size", Symbol.Size, Hex64(0)); + IO.mapOptional("Value", Symbol.Value); + IO.mapOptional("Size", Symbol.Size); // Symbol's Other field is a bit special. It is usually a field that // represents st_other and holds the symbol visibility. However, on some Index: llvm/test/tools/obj2yaml/ELF/symbol.yaml =================================================================== --- /dev/null +++ llvm/test/tools/obj2yaml/ELF/symbol.yaml @@ -0,0 +1,27 @@ +## This is a test case to check how tool dumps symbols. + +## Check that we only dump Size and Value keys when +## their values are not 0. + +# RUN: yaml2obj %s -o %t1 +# RUN: obj2yaml %t1 | FileCheck %s --check-prefix=FIELDS-DEF + +# FIELDS-DEF: Symbols: +# FIELDS-DEF-NEXT: - Name: foo +# FIELDS-DEF-NEXT: - Name: bar +# FIELDS-DEF-NEXT: Value: 0x1 +# FIELDS-DEF-NEXT: Size: 0x1 +# FIELDS-DEF-NEXT: ... + +!ELF +FileHeader: + Class: ELFCLASS64 + Data: ELFDATA2LSB + Type: ET_REL +Symbols: + - Name: foo + Size: 0x0 + Value: 0x0 + - Name: bar + Size: 0x1 + Value: 0x1 Index: llvm/test/tools/yaml2obj/ELF/symbol-value-size.yaml =================================================================== --- /dev/null +++ llvm/test/tools/yaml2obj/ELF/symbol-value-size.yaml @@ -0,0 +1,40 @@ +## Check we can set different values and sizes for symbols. + +# RUN: yaml2obj %s -o %t +# RUN: llvm-readelf --symbols %t | FileCheck %s + +# CHECK: Symbol table '.symtab' contains 6 entries: +# CHECK-NEXT: Num: Value Size Type Bind Vis Ndx Name +# CHECK-NEXT: 0: 0000000000000000 0 NOTYPE LOCAL DEFAULT UND + +!ELF +FileHeader: + Class: ELFCLASS64 + Data: ELFDATA2LSB + Type: ET_REL +Symbols: +## No "Size" or "Value" keys were set. Check it is the +## same as if we would set them to 0. + - Name: aaa +# CHECK-NEXT: 1: 0000000000000000 0 NOTYPE LOCAL DEFAULT UND aaa +## Both "Size" and "Value" are explicitly set to 0x0. + - Name: bbb + Value: 0x0 + Size: 0x0 +## Check we can use the "=" syntax. +# CHECK-NEXT: 2: 0000000000000000 0 NOTYPE LOCAL DEFAULT UND bbb + - Name: ccc + Value: [[EVAL=]] + Size: [[ESIZE=]] +# CHECK-NEXT: 3: 0000000000000000 0 NOTYPE LOCAL DEFAULT UND ccc +## Both "Size" and "Value" are explicitly set to an arbitraty value. +## Here we use UINT64_MAX to check this boundary case. + - Name: ddd + Value: 0xffffffffffffffff + Size: 0xffffffffffffffff +# CHECK-NEXT: 4: ffffffffffffffff -1 NOTYPE LOCAL DEFAULT UND ddd +## The same as previous, but decimal values were used. + - Name: eee + Value: 18446744073709551615 + Size: 18446744073709551615 +# CHECK-NEXT: 5: ffffffffffffffff -1 NOTYPE LOCAL DEFAULT UND eee Index: llvm/tools/obj2yaml/elf2yaml.cpp =================================================================== --- llvm/tools/obj2yaml/elf2yaml.cpp +++ llvm/tools/obj2yaml/elf2yaml.cpp @@ -661,8 +661,10 @@ Error ELFDumper::dumpSymbol(const Elf_Sym *Sym, const Elf_Shdr *SymTab, StringRef StrTable, ELFYAML::Symbol &S) { S.Type = Sym->getType(); - S.Value = Sym->st_value; - S.Size = Sym->st_size; + if (Sym->st_value) + S.Value = (yaml::Hex64)Sym->st_value; + if (Sym->st_size) + S.Size = (yaml::Hex64)Sym->st_size; S.Other = Sym->st_other; S.Binding = Sym->getBinding();