notebook/notes/linkers/elf.md

19 KiB

title TARGET DECK FILE TAGS tags
ELF Obsidian::STEM linker::elf x86-64
elf
linker
x86-64

Overview

ELF (Executable and Linkable Format) is the modern linkers/index#Object Files form used by x86-64/index Linux systems.

%%ANKI Basic What object file format do modern x86-64 Linux machines typically use? Back: ELF. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic What is the ELF object file format an acronym for? Back: Executable and Linkable Format. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic What is ELF an example of? Back: An object file format. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

Sections

A typical ELF object file contains the following sections:

.text

The machine code of the compiled program.

%%ANKI Basic What does the .text section contain? Back: The machine code of the compiled program. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic Which ELF section typically contains the machine code of the compiled program? Back: .text Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Cloze The {.text} ELF section contains the {machine code} of the compiled program. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

.rodata

Read-only data such as the format strings in c17/strings/printf statements and conditions#JMP for switch statements.

%%ANKI Basic What does the .rodata section contain? Back: Read-only data. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic Which ELF section typically contains read-only data? Back: .rodata Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic Why is the .rodata section named the way it is? Back: It stands for read-only data. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic In what ELF section would a printf format string be found in? Back: .rodata Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17::printf

END%%

%%ANKI Basic In what ELF section would a jump table be found in? Back: .rodata Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

.data

Global and static C variables initialized to a non-zero value.

%%ANKI Basic What kind of global/static C variables does the .data section contain? Back: Those initialized to a non-zero value. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Which ELF section contains global C variables initialized to a non-zero value? Back: .data Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Which ELF section contains static C variables initialized to a non-zero value? Back: .data Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Which ELF section contains local C variables initialized to a non-zero value? Back: N/A. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Consider the following translation unit. Which ELF section will foo end up in?

int foo = 1;

Back: .data Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Consider the following translation unit. Which ELF section will bar end up in?

int foo() {
  int bar = 0;
}

Back: N/A. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Consider the following translation unit. Which ELF section will bar end up in?

int foo() {
  static int bar = 1;
}

Back: .data. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

.tdata

Thread-local global and static C variables initialized to a non-zero value.

%%ANKI Basic What kind of global and static C variables does the .tdata section contain? Back: Thread-local variables initialized to a non-zero value. Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Which ELF section contains global thread-local C variables initialized to a non-zero value? Back: .tdata Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Which ELF section contains static thread-local C variables initialized to a non-zero value? Back: .tdata Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Consider the following translation unit. Which ELF section will foo end up in?

_Thread_local int foo = 1;

Back: .tdata Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Consider the following translation unit. Which ELF section will bar end up in?

int foo() {
  static _Thread_local int bar = 1;
}

Back: .tdata. Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Consider the following translation unit. Which ELF section will bar end up in?

int foo() {
  _Thread_local int bar = 1;
}

Back: N/A. Compilation error - bar must have global storage. Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

.bss

Assuming -fno-common, contains global and static C variables, along with any global or static variables initialized to zero.

%%ANKI Basic Assuming -fno-common, what kind of C variables does the .bss section contain? Back: Uninitialized global and static variables or those initialized to zero. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Assuming -fno-common, which ELF section contains uninitialized global C variables? Back: .bss Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Assuming -fno-common, which ELF section contains global C variables initialized to a zero value? Back: .bss Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Assuming -fno-common, which two ELF sections contain global and static C variables? Back: .data and .bss Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Consider the following translation unit. Assuming -fno-common, which ELF section will foo end up in?

int foo = 0;

Back: .bss Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Consider the following translation unit. Assuming -fno-common, which ELF section will foo end up in?

int foo;

Back: .bss Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Assuming -fno-common, both .bss and .data hold what kind of C variables? Back: Global and static variables. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

%%ANKI Basic Which of .data and/or .bss is considered a placeholder? Back: .bss Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic What does Bryant et al. mean by saying .bss is "merely a placeholder"? Back: The .bss section occupies no actual space in the object file. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic What mneumonic does Bryant et al. suggest to remember the .bss and .data distinction? Back: .bss is a backronym for "Better Save Space!" Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic Why is the .bss section named the way it is? Back: It was originally an acronym for block started by symbol. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Cloze {Block started by symbol} is the actual acronym for Bryant et al.'s mneumonic {better save space}. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic Consider the following translation unit. Assuming -fno-common, which section will bar end up in?

int foo() {
  static int bar = 0;
}

Back: .bss. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016. Tags: c17

END%%

.tbss

Uninitialized global and static thread-local C variables, along with any global or static thread-local variables initialized to zero.

%%ANKI Basic What kind of global and static C variables does the .tbss section contain? Back: Unitialized thread-local variables or those initialized to zero. Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Which ELF section contains uninitialized thread-local global C variables? Back: .tbss Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Which ELF section contains global thread-local C variables initialized to a zero value? Back: .tbss Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Which two ELF sections contain global and static thread-local C variables? Back: .tdata and .tbss Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Consider the following translation unit. Which ELF section will foo end up in?

_Thread_local int foo = 0;

Back: .tbss Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Consider the following translation unit. Which ELF section will foo end up in?

_Thread_local int foo;

Back: .tbss Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Both .tbss and .tdata hold what kind of C variables? Back: Global or static thread-local variables. Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Which of .tdata and/or .tbss is considered a "placeholder"? Back: .tbss Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

%%ANKI Basic Consider the following translation unit. Which ELF section will bar end up in?

int foo() {
  static _Thread_local int bar = 0;
}

Back: .tbss. Reference: Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d. Tags: c17

END%%

.symtab

A symbol table with information about functions and global variables defined and referenced in the program.

%%ANKI Basic What does the .symtab section contain? Back: A symbol table for functions and global variables. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic Which ELF section contains a symbol table for functions and global variables? Back: .symtab Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic Why is the .symtab section named the way it is? Back: It's short for symbol table. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

.rel.text

A list of locations in the .text section that will need to be modified when the linker combines this object file with others.

%%ANKI Basic What does the .rel.text section contain? Back: Relocation entries for the .text section. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic Why is the .rel.text section named the way it is? Back: It's short for relocation entries for the .text section. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Cloze The {.rel.text} ELF section contains {relocation entries} for the .text section. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

.rel.data

A list of locations in the .data section that will need to be modified when the linker combines this object file with others.

%%ANKI Basic What does the .rel.data section contain? Back: Relocation entries for the .data section. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic Why is the .rel.data section named the way it is? Back: It's short for relocation entries for the .data section. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Cloze The {.rel.data} ELF section contains {relocation entries} for the .data section. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

.strtab

A string table for the symbol tables in the .symtab section as well as for section names in the section headers. It is a sequence of NUL-terminated character strings.

%%ANKI Basic What does the .strtab section contain? Back: A string table. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic Why is the .strtab section named the way it is? Back: It is short for string table. Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic The .strtab provides information for what other, non-debug ELF section? Back: .symtab Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

%%ANKI Basic Section names are contained in what ELF section? Back: .strtab Reference: Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.

END%%

Bibliography

  • Bryant, Randal E., and David O'Hallaron. Computer Systems: A Programmer's Perspective. Third edition, Global edition. Always Learning. Pearson, 2016.
  • Ulrich Drepper, “ELF Handling For Thread-Local Storage,” n.d.