On Thu, May 30, 2019 at 4:15 PM Vincenzo Frascino vincenzo.frascino@arm.com wrote:
vDSO (virtual dynamic shared object) is a mechanism that the Linux kernel provides as an alternative to system calls to reduce where possible the costs in terms of cycles. This is possible because certain syscalls like gettimeofday() do not write any data and return one or more values that are stored in the kernel, which makes relatively safe calling them directly as a library function.
Hi Vincento,
I've very happy with how this turned out overall, and as far as I can tell you have addressed all my previous comments. I had another look through the series and only noticed a few very minor issues.
I hope Thomas can have another look soon, he probably also finds a few things, and then it should be ready for inclusion in linux-next and the coming merge window.
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.
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.
If anyone comes up with a good reason why it should be added after all, let me know and I'll stop mentioning it.
Arnd