Linker
Linker (angl. výslovnost [ˈliŋkə(r)]; česky sestavovací program) je v informatice počítačový program, který jeden nebo více objektových souborů vygenerovaných překladačem spojí do jediného spustitelného souboru (tzv. linkování). Výsledný soubor může být přímo spustitelný jádrem operačního systému nebo knihovnou, která je později využívána jiným programem. Statická knihovna je připojována k jinému programu, dynamická knihovna je s programem spojována při jeho zavádění do paměti (zavaděč vyvolá dynamický linker).
Funkce linkeru
[editovat | editovat zdroj]Objektové soubory jsou moduly programu obsahující strojový kód a informace pro linker. Mohou obsahovat tři různé definice symbolů:
- definované symboly – mohou být volány z externích modulů
- nedefinované symboly – volají funkce v externích modulech, uvnitř kterých jsou definovány
- lokální symboly – interně definované symboly používané například při relokaci
Ve zkratce, účelem linkeru je řešení referencí nedefinovaných symbolů vyhledáváním symbolů v ostatních objektových souborech, které je definují. Nedefinovaný symbol je nahrazen adresou symbolu, který jej definuje.
Linker často pracuje s objekty, které jsou uspořádány ve větších celcích, tzv. knihovnách. Některé linkery neobsahují na výstupu celou knihovnu, ale obsahují pouze její symboly, na které je odkazováno z objektových souborů případně jiných knihoven. Existuje celá řada knihoven majících různý účel. Jedna nebo více systémových knihoven bývají obvykle připojovány v linkovacím procesu standardně.
Linker se také stará o umisťování objektů v adresním prostoru programu. Používá k tomu relokační kód, který dokáže přesunout spodní mez adresního prostoru (referenční adresa) na jiný základ. Jelikož překladač obvykle neví, kam bude objekt v paměti umístěn, je objektu obvykle přidělena nejnižší možná spodní adresa a to nula. Relokační strojový kód může obsahovat příkaz pro přesměrování absolutních skoků, načtení a uložení.
Výstup spustitelný linkerem může před tím, než je program zaveden do paměti (těsně před spuštěním) vyžadovat ještě jeden průchod relokačním cyklem. U hardwaru umožňujícím využití virtuální paměti je tento cyklus vypuštěn, neboť každému programu je přidělen vlastní adresní prostor tak, že nemůže dojít ke konfliktu, ačkoliv všechny programy budou načteny se stejnou referenční adresou.
Sdílené knihovny
[editovat | editovat zdroj]Moderní prostředí operačních systémů umožňuje tzv. dynamické sestavování, řešící některé nespecifikované symboly až po spuštění programu, z čehož vyplývá, že spustitelný soubor stále obsahuje nespecifikované symboly a seznam objektů a knihoven obsahujících jejich definice. Tyto objekty a knihovny se načtou až při spuštění programu, kdy se provede konečné sestavení.
Tento přístup má dvě výhody:
- často používané knihovny (např. standardní knihovna jazyka C) nemusí být obsaženy v každém adresním prostoru každého programu zvlášť, ale pouze jednou ve sdílené části paměti
- pokud je chybně fungující knihovna nahrazena, všechny programy, které k ní dynamicky přistupují mohou po svém restartu z této změny těžit, avšak programy, které se na funkci obsaženou v knihovně odkazují staticky musí být nejprve přelinkovány
Relaxace
[editovat | editovat zdroj]Protože překladač nemá žádné informace o rozložení objektů v konečném výstupu, nemůže využít zkrácené nebo účinnější instrukce, které vyžadují adresy jiných objektů. Například skoková instrukce může být vyjádřena absolutní adresou nebo offsetem vztahujícím se k momentální pozici, přičemž hodnota offsetu může mít v závislosti na vzdálenosti od cíle různou délku. Generováním nejkonzervativnějších instrukcí (obvykle jsou to ty největší relativní či absolutní varianty, to závisí na platformě) a přidáním oddychových nápověd, je možné během konečného sestavování tyto nahradit kratšími a efektivnějšími instrukcemi. Tento krok je možné provést až poté, co byl celý kód přečten a byly stanoveny dočasné adresy. Proces relaxace pak provede přeadresování, což umožní celkové odlehčení programu. Nahrazené posloupnosti instrukcí jsou kratší, což tomuto procesu umožňuje vždy počítat s optimálním řešením pevného uspořádání objektů. Pokud tomu tak není, dojde ke konfliktu, a linker musí zvážit její výhody či další možnosti.