hc
2023-10-25 6c2073b7aa40e29d0eca7d571dd7bc590c7ecaa7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
/*
 * Copyright (C) 2011 Richard Weinberger <richrd@nod.at>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 * This vDSO turns all calls into a syscall so that UML can trap them.
 */
 
 
/* Disable profiling for userspace code */
#define DISABLE_BRANCH_PROFILING
 
#include <linux/time.h>
#include <linux/getcpu.h>
#include <asm/unistd.h>
 
int __vdso_clock_gettime(clockid_t clock, struct timespec *ts)
{
   long ret;
 
   asm("syscall" : "=a" (ret) :
       "0" (__NR_clock_gettime), "D" (clock), "S" (ts) : "memory");
 
   return ret;
}
int clock_gettime(clockid_t, struct timespec *)
   __attribute__((weak, alias("__vdso_clock_gettime")));
 
int __vdso_gettimeofday(struct timeval *tv, struct timezone *tz)
{
   long ret;
 
   asm("syscall" : "=a" (ret) :
       "0" (__NR_gettimeofday), "D" (tv), "S" (tz) : "memory");
 
   return ret;
}
int gettimeofday(struct timeval *, struct timezone *)
   __attribute__((weak, alias("__vdso_gettimeofday")));
 
time_t __vdso_time(time_t *t)
{
   long secs;
 
   asm volatile("syscall"
       : "=a" (secs)
       : "0" (__NR_time), "D" (t) : "cc", "r11", "cx", "memory");
 
   return secs;
}
int time(time_t *t) __attribute__((weak, alias("__vdso_time")));
 
long
__vdso_getcpu(unsigned *cpu, unsigned *node, struct getcpu_cache *unused)
{
   /*
    * UML does not support SMP, we can cheat here. :)
    */
 
   if (cpu)
       *cpu = 0;
   if (node)
       *node = 0;
 
   return 0;
}
 
long getcpu(unsigned *cpu, unsigned *node, struct getcpu_cache *tcache)
   __attribute__((weak, alias("__vdso_getcpu")));