2020-10-30 15:40:48 +08:00
|
|
|
What: vDSO
|
|
|
|
Date: July 2011
|
|
|
|
KernelVersion: 3.0
|
|
|
|
Contact: Andy Lutomirski <luto@kernel.org>
|
|
|
|
Description:
|
|
|
|
|
2011-07-13 21:24:16 +08:00
|
|
|
On some architectures, when the kernel loads any userspace program it
|
|
|
|
maps an ELF DSO into that program's address space. This DSO is called
|
|
|
|
the vDSO and it often contains useful and highly-optimized alternatives
|
|
|
|
to real syscalls.
|
|
|
|
|
|
|
|
These functions are called just like ordinary C function according to
|
|
|
|
your platform's ABI. Call them from a sensible context. (For example,
|
|
|
|
if you set CS on x86 to something strange, the vDSO functions are
|
|
|
|
within their rights to crash.) In addition, if you pass a bad
|
|
|
|
pointer to a vDSO function, you might get SIGSEGV instead of -EFAULT.
|
|
|
|
|
|
|
|
To find the DSO, parse the auxiliary vector passed to the program's
|
|
|
|
entry point. The AT_SYSINFO_EHDR entry will point to the vDSO.
|
|
|
|
|
|
|
|
The vDSO uses symbol versioning; whenever you request a symbol from the
|
|
|
|
vDSO, specify the version you are expecting.
|
|
|
|
|
|
|
|
Programs that dynamically link to glibc will use the vDSO automatically.
|
2017-03-09 03:50:31 +08:00
|
|
|
Otherwise, you can use the reference parser in
|
|
|
|
tools/testing/selftests/vDSO/parse_vdso.c.
|
2011-07-13 21:24:16 +08:00
|
|
|
|
|
|
|
Unless otherwise noted, the set of symbols with any given version and the
|
|
|
|
ABI of those symbols is considered stable. It may vary across architectures,
|
|
|
|
though.
|
|
|
|
|
2020-10-30 15:40:38 +08:00
|
|
|
Note:
|
|
|
|
As of this writing, this ABI documentation as been confirmed for x86_64.
|
2011-07-13 21:24:16 +08:00
|
|
|
The maintainers of the other vDSO-using architectures should confirm
|
2020-10-30 15:40:38 +08:00
|
|
|
that it is correct for their architecture.
|