summaryrefslogtreecommitdiff
path: root/Userland/Utilities
diff options
context:
space:
mode:
authorGunnar Beutner <gbeutner@serenityos.org>2021-07-22 00:47:30 +0200
committerAndreas Kling <kling@serenityos.org>2021-07-22 08:57:01 +0200
commitdb1c5c483045e9c5e7afedb6b11f2fbbef79a9dc (patch)
tree05bc7816fedf372598149d58445a522b864caedd /Userland/Utilities
parent36c3927169c407d06811e416a7eb0672a0c4f04b (diff)
downloadserenity-db1c5c483045e9c5e7afedb6b11f2fbbef79a9dc.zip
LibELF+Utilities: Avoid truncating 64-bit values
This fixes displaying 64-bit addresses in readelf and also fixes showing backtraces from core dumps on x86_64.
Diffstat (limited to 'Userland/Utilities')
-rw-r--r--Userland/Utilities/readelf.cpp23
1 files changed, 12 insertions, 11 deletions
diff --git a/Userland/Utilities/readelf.cpp b/Userland/Utilities/readelf.cpp
index 2034046419..cb64e4ea87 100644
--- a/Userland/Utilities/readelf.cpp
+++ b/Userland/Utilities/readelf.cpp
@@ -563,18 +563,19 @@ int main(int argc, char** argv)
outln("There are no program headers in this file.");
} else {
outln("Program Headers:");
- outln(" Type Offset VirtAddr{} PhysAddr{} FileSiz MemSiz Flg Align", addr_padding, addr_padding);
+ outln(" Type Offset{} VirtAddr{} PhysAddr{} FileSiz{} MemSiz{} Flg Align",
+ addr_padding, addr_padding, addr_padding, addr_padding, addr_padding);
elf_image.for_each_program_header([](const ELF::Image::ProgramHeader& program_header) {
out(" ");
out("{:14} ", object_program_header_type_to_string(program_header.type()));
- out("{:#08x} ", program_header.offset());
+ out("{:p} ", program_header.offset());
out("{:p} ", program_header.vaddr().as_ptr());
out("{:p} ", program_header.vaddr().as_ptr()); // FIXME: assumes PhysAddr = VirtAddr
- out("{:#08x} ", program_header.size_in_image());
- out("{:#08x} ", program_header.size_in_memory());
+ out("{:p} ", program_header.size_in_image());
+ out("{:p} ", program_header.size_in_memory());
out("{:04x} ", program_header.flags());
- out("{:#08x}", program_header.alignment());
+ out("{:p}", program_header.alignment());
outln();
if (program_header.type() == PT_INTERP)
@@ -642,11 +643,11 @@ int main(int argc, char** argv)
outln("Relocation section '{}' at offset {:#08x} contains zero entries:", object->relocation_section().name(), object->relocation_section().offset());
} else {
outln("Relocation section '{}' at offset {:#08x} contains {} entries:", object->relocation_section().name(), object->relocation_section().offset(), object->relocation_section().entry_count());
- outln(" Offset Type Sym Value Sym Name");
+ outln(" Offset{} Type Sym Value{} Sym Name", addr_padding, addr_padding);
object->relocation_section().for_each_relocation([](const ELF::DynamicObject::Relocation& reloc) {
- out(" {:#08x} ", reloc.offset());
+ out(" {:p} ", reloc.offset());
out(" {:17} ", object_relocation_type_to_string(reloc.type()));
- out(" {:#08x} ", reloc.symbol().value());
+ out(" {:p} ", reloc.symbol().value());
out(" {}", reloc.symbol().name());
outln();
});
@@ -657,11 +658,11 @@ int main(int argc, char** argv)
outln("Relocation section '{}' at offset {:#08x} contains zero entries:", object->plt_relocation_section().name(), object->plt_relocation_section().offset());
} else {
outln("Relocation section '{}' at offset {:#08x} contains {} entries:", object->plt_relocation_section().name(), object->plt_relocation_section().offset(), object->plt_relocation_section().entry_count());
- outln(" Offset Type Sym Value Sym Name");
+ outln(" Offset{} Type Sym Value{} Sym Name", addr_padding, addr_padding);
object->plt_relocation_section().for_each_relocation([](const ELF::DynamicObject::Relocation& reloc) {
- out(" {:#08x} ", reloc.offset());
+ out(" {:p} ", reloc.offset());
out(" {:17} ", object_relocation_type_to_string(reloc.type()));
- out(" {:#08x} ", reloc.symbol().value());
+ out(" {:p} ", reloc.symbol().value());
out(" {}", reloc.symbol().name());
outln();
});