Dynamisk länkning och shared objects i FreeBSD: Difference between revisions

From Peters wiki
Jump to navigation Jump to search
Line 32: Line 32:
gcc -shared -Wl,-soname,libfoo.so.1 -o libfoo.so.1.0 foo.o
gcc -shared -Wl,-soname,libfoo.so.1 -o libfoo.so.1.0 foo.o
</pre>}}
</pre>}}
Optionen <tt>-shared</tt> används för att skapa ett shared object (so-fil). Optionen <tt>-Wl,-soname,libfoo.so.1</tt> är en länkar option <tt>-soname libfoo.so.1</tt>. Denna option sätter en ELF variabel (DT_SONAME). När ett program laddas och detta är länkat mot ett shared object som har DT_SONAME satt, då kommer den dynamiska laddaren gå på DT_SONAME istället för filnamnet. Mer om detta senare. Vi har nu skapat en fil som heter libfoo.so.1.0
Optionen <tt>-shared</tt> används för att skapa ett shared object (so-fil). Optionen <tt>-Wl,-soname,libfoo.so.1</tt> är en länkaroption <tt>-soname libfoo.so.1</tt>. Denna option sätter en ELF variabel (DT_SONAME). När ett program laddas och detta är länkat mot ett shared object som har DT_SONAME satt, då kommer den dynamiska laddaren gå på DT_SONAME istället för filnamnet. Mer om detta senare. Vi har nu skapat en fil som heter libfoo.so.1.0


=== Bygga och länka myapp ===
=== Bygga och länka myapp ===

Revision as of 16:17, 1 January 2012

Detta ämne är under utveckling.

Problem med dynamisk länkning är ofta det som strular när man ska kompilera länka ihop något större program. Särskilt om man inte är root på systemet och måste installera sina program på andra ställen än systemets standardställen.


Bygga och länka mot en so-fil

Vi börjar med ett exempel på ett litet program som består av en exekverbar fil + en so-fil. Detta exempel kommer sedan användas för att åskådliggöra problemen runt so-filer och dynamisk länkning. Vår filstruktur i exemplet är:

.
├── Makefile
├── lib
│   ├── Makefile
│   ├── foo.c
│   ├── foo.h
│   ├── libfoo.so -> libfoo.so.1.0
│   └── libfoo.so.1 -> libfoo.so.1.0
└── main.c

Bygga och länka libfoo.so

Källkoden till libfoo.so ligger i foo.c och dess interface i foo.h. När vi kompilerar koden måste vi använda -fPIC flaggan. Vi använder det fullständiga kommandot: Template:Box Kommando För att sedan länka ihop libfoo.so.1 så använder vi följande kommando: Template:Box Kommando Optionen -shared används för att skapa ett shared object (so-fil). Optionen -Wl,-soname,libfoo.so.1 är en länkaroption -soname libfoo.so.1. Denna option sätter en ELF variabel (DT_SONAME). När ett program laddas och detta är länkat mot ett shared object som har DT_SONAME satt, då kommer den dynamiska laddaren gå på DT_SONAME istället för filnamnet. Mer om detta senare. Vi har nu skapat en fil som heter libfoo.so.1.0

Bygga och länka myapp

Vår exekverbar fil består av källkoden main.c men behöver en funktion i libfoo.so för att kunna köras. Vi kompilerar källkoden med kommandot:

Template:Box Kommando

Och för att länka ihop programmet myapp: Template:Box Kommando