Merge "bionic: add vdso time()"
This commit is contained in:
commit
25a3087d6d
|
@ -60,11 +60,21 @@ int gettimeofday(timeval* tv, struct timezone* tz) {
|
||||||
return __gettimeofday(tv, tz);
|
return __gettimeofday(tv, tz);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
time_t time(time_t* t) {
|
||||||
|
auto vdso_time = reinterpret_cast<decltype(&time)>(
|
||||||
|
__libc_globals->vdso[VDSO_TIME].fn);
|
||||||
|
if (__predict_true(vdso_time)) {
|
||||||
|
return vdso_time(t);
|
||||||
|
}
|
||||||
|
return __time(t);
|
||||||
|
}
|
||||||
|
|
||||||
void __libc_init_vdso(libc_globals* globals, KernelArgumentBlock& args) {
|
void __libc_init_vdso(libc_globals* globals, KernelArgumentBlock& args) {
|
||||||
auto&& vdso = globals->vdso;
|
auto&& vdso = globals->vdso;
|
||||||
vdso[VDSO_CLOCK_GETTIME] = { VDSO_CLOCK_GETTIME_SYMBOL, nullptr };
|
vdso[VDSO_CLOCK_GETTIME] = { VDSO_CLOCK_GETTIME_SYMBOL, nullptr };
|
||||||
vdso[VDSO_CLOCK_GETRES] = { VDSO_CLOCK_GETRES_SYMBOL, nullptr };
|
vdso[VDSO_CLOCK_GETRES] = { VDSO_CLOCK_GETRES_SYMBOL, nullptr };
|
||||||
vdso[VDSO_GETTIMEOFDAY] = { VDSO_GETTIMEOFDAY_SYMBOL, nullptr };
|
vdso[VDSO_GETTIMEOFDAY] = { VDSO_GETTIMEOFDAY_SYMBOL, nullptr };
|
||||||
|
vdso[VDSO_TIME] = { VDSO_TIME_SYMBOL, nullptr };
|
||||||
|
|
||||||
// Do we have a vdso?
|
// Do we have a vdso?
|
||||||
uintptr_t vdso_ehdr_addr = args.getauxval(AT_SYSINFO_EHDR);
|
uintptr_t vdso_ehdr_addr = args.getauxval(AT_SYSINFO_EHDR);
|
||||||
|
|
|
@ -35,15 +35,18 @@
|
||||||
#define VDSO_CLOCK_GETTIME_SYMBOL "__kernel_clock_gettime"
|
#define VDSO_CLOCK_GETTIME_SYMBOL "__kernel_clock_gettime"
|
||||||
#define VDSO_CLOCK_GETRES_SYMBOL "__kernel_clock_getres"
|
#define VDSO_CLOCK_GETRES_SYMBOL "__kernel_clock_getres"
|
||||||
#define VDSO_GETTIMEOFDAY_SYMBOL "__kernel_gettimeofday"
|
#define VDSO_GETTIMEOFDAY_SYMBOL "__kernel_gettimeofday"
|
||||||
|
#define VDSO_TIME_SYMBOL "__kernel_time"
|
||||||
#else
|
#else
|
||||||
#define VDSO_CLOCK_GETTIME_SYMBOL "__vdso_clock_gettime"
|
#define VDSO_CLOCK_GETTIME_SYMBOL "__vdso_clock_gettime"
|
||||||
#define VDSO_CLOCK_GETRES_SYMBOL "__vdso_clock_getres"
|
#define VDSO_CLOCK_GETRES_SYMBOL "__vdso_clock_getres"
|
||||||
#define VDSO_GETTIMEOFDAY_SYMBOL "__vdso_gettimeofday"
|
#define VDSO_GETTIMEOFDAY_SYMBOL "__vdso_gettimeofday"
|
||||||
|
#define VDSO_TIME_SYMBOL "__vdso_time"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern "C" int __clock_gettime(int, timespec*);
|
extern "C" int __clock_gettime(int, timespec*);
|
||||||
extern "C" int __clock_getres(int, timespec*);
|
extern "C" int __clock_getres(int, timespec*);
|
||||||
extern "C" int __gettimeofday(timeval*, struct timezone*);
|
extern "C" int __gettimeofday(timeval*, struct timezone*);
|
||||||
|
extern "C" time_t __time(time_t*);
|
||||||
|
|
||||||
struct vdso_entry {
|
struct vdso_entry {
|
||||||
const char* name;
|
const char* name;
|
||||||
|
@ -54,6 +57,7 @@ enum {
|
||||||
VDSO_CLOCK_GETTIME = 0,
|
VDSO_CLOCK_GETTIME = 0,
|
||||||
VDSO_CLOCK_GETRES,
|
VDSO_CLOCK_GETRES,
|
||||||
VDSO_GETTIMEOFDAY,
|
VDSO_GETTIMEOFDAY,
|
||||||
|
VDSO_TIME,
|
||||||
VDSO_END
|
VDSO_END
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -28,11 +28,12 @@
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <sys/cdefs.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
|
||||||
time_t
|
__LIBC_HIDDEN__ time_t
|
||||||
time(time_t *t)
|
__time(time_t *t)
|
||||||
{
|
{
|
||||||
struct timeval tt;
|
struct timeval tt;
|
||||||
|
|
||||||
|
@ -42,4 +43,3 @@ time(time_t *t)
|
||||||
*t = (time_t)tt.tv_sec;
|
*t = (time_t)tt.tv_sec;
|
||||||
return (tt.tv_sec);
|
return (tt.tv_sec);
|
||||||
}
|
}
|
||||||
DEF_STRONG(time);
|
|
||||||
|
|
Loading…
Reference in New Issue