--- title: ELF TARGET DECK: Obsidian::STEM FILE TAGS: linker::elf x86-64 tags: - elf - linker - x86-64 --- ## Overview ELF (Executable and Linkable Format) is the modern [[linkers/index#Object Files|object file]] form used by [[x86-64/index|x86-64]] 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: **E**xecutable and **L**inkable **F**ormat. 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|printf]] statements and [[conditions#JMP|jump tables]] 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 **r**ead-**o**nly **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? ```c 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? ```c 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? ```c 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? ```c _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? ```c 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? ```c 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? ```c 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? ```c 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 "**B**etter **S**ave **S**pace!" 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 **b**lock **s**tarted by **s**ymbol. 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? ```c 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? ```c _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? ```c _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? ```c 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 **sym**bol **tab**le. 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 **rel**ocation 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 **rel**ocation 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 **str**ing **tab**le. 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.