blob: 01d1c17e2849abb50a2bf4bffb4185a726d886f5 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _ASM_X86_64_VSYSCALL_H_
2#define _ASM_X86_64_VSYSCALL_H_
3
Linus Torvalds1da177e2005-04-16 15:20:36 -07004enum vsyscall_num {
5 __NR_vgettimeofday,
6 __NR_vtime,
Vojtech Pavlikc08c8202006-09-26 10:52:28 +02007 __NR_vgetcpu,
Linus Torvalds1da177e2005-04-16 15:20:36 -07008};
9
10#define VSYSCALL_START (-10UL << 20)
11#define VSYSCALL_SIZE 1024
12#define VSYSCALL_END (-2UL << 20)
13#define VSYSCALL_ADDR(vsyscall_nr) (VSYSCALL_START+VSYSCALL_SIZE*(vsyscall_nr))
14
15#ifdef __KERNEL__
David Woodhouse75da7362006-09-16 12:15:48 -070016#include <linux/seqlock.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070017
18#define __section_vxtime __attribute__ ((unused, __section__ (".vxtime"), aligned(16)))
Vojtech Pavlikc08c8202006-09-26 10:52:28 +020019#define __section_vgetcpu_mode __attribute__ ((unused, __section__ (".vgetcpu_mode"), aligned(16)))
Linus Torvalds1da177e2005-04-16 15:20:36 -070020#define __section_jiffies __attribute__ ((unused, __section__ (".jiffies"), aligned(16)))
21#define __section_sys_tz __attribute__ ((unused, __section__ (".sys_tz"), aligned(16)))
22#define __section_sysctl_vsyscall __attribute__ ((unused, __section__ (".sysctl_vsyscall"), aligned(16)))
23#define __section_xtime __attribute__ ((unused, __section__ (".xtime"), aligned(16)))
24#define __section_xtime_lock __attribute__ ((unused, __section__ (".xtime_lock"), aligned(16)))
25
26#define VXTIME_TSC 1
27#define VXTIME_HPET 2
Andi Kleen312df5f2005-05-16 21:53:28 -070028#define VXTIME_PMTMR 3
Linus Torvalds1da177e2005-04-16 15:20:36 -070029
Vojtech Pavlikc08c8202006-09-26 10:52:28 +020030#define VGETCPU_RDTSCP 1
31#define VGETCPU_LSL 2
32
Linus Torvalds1da177e2005-04-16 15:20:36 -070033struct vxtime_data {
34 long hpet_address; /* HPET base address */
Linus Torvalds1da177e2005-04-16 15:20:36 -070035 int last;
36 unsigned long last_tsc;
37 long quot;
38 long tsc_quot;
39 int mode;
40};
41
Stephen Hemminger77a75332006-01-11 22:46:30 +010042#define hpet_readl(a) readl((const void __iomem *)fix_to_virt(FIX_HPET_BASE) + a)
43#define hpet_writel(d,a) writel(d, (void __iomem *)fix_to_virt(FIX_HPET_BASE) + a)
Linus Torvalds1da177e2005-04-16 15:20:36 -070044
45/* vsyscall space (readonly) */
46extern struct vxtime_data __vxtime;
Vojtech Pavlikc08c8202006-09-26 10:52:28 +020047extern int __vgetcpu_mode;
Linus Torvalds1da177e2005-04-16 15:20:36 -070048extern struct timespec __xtime;
49extern volatile unsigned long __jiffies;
Linus Torvalds1da177e2005-04-16 15:20:36 -070050extern struct timezone __sys_tz;
51extern seqlock_t __xtime_lock;
52
53/* kernel space (writeable) */
54extern struct vxtime_data vxtime;
Vojtech Pavlikc08c8202006-09-26 10:52:28 +020055extern int vgetcpu_mode;
Linus Torvalds1da177e2005-04-16 15:20:36 -070056extern struct timezone sys_tz;
57extern int sysctl_vsyscall;
58extern seqlock_t xtime_lock;
59
Andi Kleen312df5f2005-05-16 21:53:28 -070060extern int sysctl_vsyscall;
61
Linus Torvalds1da177e2005-04-16 15:20:36 -070062#define ARCH_HAVE_XTIME_LOCK 1
63
64#endif /* __KERNEL__ */
65
66#endif /* _ASM_X86_64_VSYSCALL_H_ */