Page 1 of 1

Dynamic linking (DLL/SO); how is it done?

Posted: Wed Sep 10, 2014 7:28 pm
by drunkenfox
I know that the memory manager on most OS's map each process on it's own separate physical addresses, and then gives them the "same" virtual address. But how does this work with dynamic libraries? Does it map the libraries into one physical address, and then remap parts of processes that utilize the library with the same address?

Re: Dynamic linking (DLL/SO); how is it done?

Posted: Thu Sep 11, 2014 3:03 am
by mallard
Dynamic libraries are loaded into the same address space as the program that uses them. The "dynamic linker" then modifies the references in the program code so that they point to the library.

Libraries are (usually) "position independent", meaning they can be loaded at any address, with the linker performing any adjustments needed (relocations). They often also have a "preferred" address which they will be loaded at if possible (i.e. that address doesn't conflict with the program itself or any other libraries). When loaded at the preferred address, the relocations aren't necessary.

Additionally, if two (or more) programs load the same library at the same address, the library's code (and some data; usually the 'text' and 'rodata' sections of the binary) can be shared between the programs as long as there is either a guarantee that the library doesn't modify what's ahared (usually by having the memory marked 'read only'), or appropriate measures to ensure that any modifications don't affect other programs (e.g. a "copy-on-write" strategy).

Re: Dynamic linking (DLL/SO); how is it done?

Posted: Thu Sep 11, 2014 3:05 am
by alexfru
The parts that aren't going to change (e.g. code and constant data) can exist as a single instance/copy in the physical memory and be available through page translation at the same or different virtual addresses in different processes/virtual address spaces.

The parts that are going to change (data, heap) can either exists as multiple copies in physical memory from the beginning or start out as a single copy in the physical memory and then become separate private copies upon modification (ever heard of copy-on-write?). The virtual addresses, again, can be either the same or different.

Whether or not a library appears at the same virtual address in different processes/virtual address spaces is affected by several things:
- whether the library is compiled as position-independent code or as relocatable
- whether the region of the virtual address space is available, whether or not it's occupied by the main program module or other libraries