Global Offset Table
The Global Offset Table, or GOT, is a section of a computer program's (executables and shared libraries) memory used to enable computer program code compiled as an ELF file to run correctly, independent of the memory address where the program's code or data is loaded at runtime.[1]
It maps symbols in programming code to their corresponding absolute memory addresses to facilitate Position Independent Code (PIC) and Position Independent Executables (PIE)[2] which are loaded[3] to a different memory address each time the program is started. The runtime memory address, also known as absolute memory address of variables and functions is unknown before the program is started when PIC or PIE code is run[4] so cannot be hardcoded during compilation by a compiler.
The Global Offset Table is represented as the .got and .got.plt sections in an ELF file[5] which are loaded into the program's memory at startup.[5][6] The operating system's dynamic linker updates the global offset table relocations (symbol to absolute memory addresses) at program startup or as symbols are accessed.[7] It is the mechanism that allows shared libraries (.so) to be relocated to a different memory address at startup and avoid memory address conflicts with the main program or other shared libraries, and to harden computer program code from exploitation.[8]
References
- ^ "Dynamic Linking". refspecs.linuxfoundation.org.
- ^ "Code Gen Options (Using the GNU Compiler Collection)". gcc.gnu.org.
- ^ "How programs get run: ELF binaries [LWN.net]". lwn.net.
- ^ "Global Offset Tables". bottomupcs.sourceforge.net.
- ^ a b "Executable and Linkable Format (ELF)". stevens.netmeister.org.
- ^ Wienand, Ian (May 10, 2011). "PLT and GOT - the key to code sharing and dynamic libraries". Technovelty. Retrieved 14 April 2020.
- ^ Aichinger, Christian. "The ELF format - how programs look from the inside". Christian Aichinger's thoughts.
- ^ Sidhpurwala, Huzaifa (28 January 2018). "Hardening ELF binaries using Relocation Read-Only (RELRO)". Red Hat.