Re: [PATCH v6 00/19] Unify vDSOs across more architectures

From: Arnd Bergmann
Date: Tue Jun 04 2019 - 08:16:27 EST


On Tue, Jun 4, 2019 at 2:05 PM Vincenzo Frascino
<vincenzo.frascino@xxxxxxx> wrote:
> On 31/05/2019 09:46, Arnd Bergmann wrote:
> > On Thu, May 30, 2019 at 4:15 PM Vincenzo Frascino
> > <vincenzo.frascino@xxxxxxx> wrote:
> > One open question I touched in my review is whether we want to
> > have a vdso version of clock_getres() in all architectures or not.
> > I'd prefer to leave it out because there is very little advantage to
> > it over the system call (the results don't change at runtime and
> > can easily be cached by libc if performance ever matters), and
> > it takes up a small amount of memory for the implementation.
> >
>
> I thought about it and I ended up with what proposed in this patchset mainly for
> symmetry across all the architectures since in the end they use the same common
> code.
>
> It seems also that there is some performance impact (i.e.):
>
> clock-getres-monotonic: libc(system call): 296 nsec/call
> clock-getres-monotonic: libc(vdso): 5 nsec/call
>
>
> I agree with you though when you say that caching it in the libc is a
> possibility to overcome the performance impact.

It's clear that the vdso version is much faster, my point was that
I could not think of any use case that cared about it being fast.

If there is a good reason for it, I also don't mind adding a
clock_getres_time64() vdso version everywhere.

> > We shouldn't just need it for consistency because all callers
> > would require implementing a fallback to the system call
> > anyway, to deal with old kernels.
> >
>
> A way to address this issue would be to use versioning, which seems supported in
> the vdso library (i.e. arch/x86/entry/vdso/vdso32/vdso32.lds.S).
>
> For example for x86 (vdso32) we would have something like:
>
> VERSION
> {
> LINUX_5.3 (being optimistic here :) ) {
> global:
> __vdso_clock_getres;
> __vdso_clock_gettime64;
> };
> LINUX_2.6 {
> global:
> __vdso_clock_gettime;
> __vdso_gettimeofday;
> __vdso_time;
> };
>
> LINUX_2.5 {
> global:
> __kernel_vsyscall;
> __kernel_sigreturn;
> __kernel_rt_sigreturn;
> local: *;
> };
> }
>
> What do you think? Would this be a viable solution?

I actually never understood the point of symbol versioning
in the vdso. What does that gain us? Note that there are
no conflicting symbol names between the versions, and
that nothing enforces the kernel headers to match the
symbol version used when linking.

Arnd