blob: 80f80955cfd8a781d25490f835add893bc0cf898 [file] [log] [blame]
H. Peter Anvin1965aae2008-10-22 22:26:29 -07001#ifndef _ASM_X86_VSYSCALL_H
2#define _ASM_X86_VSYSCALL_H
Linus Torvalds1da177e2005-04-16 15:20:36 -07003
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)
Ernie Petrides103efcd2006-12-07 02:14:09 +010013#define VSYSCALL_MAPPED_PAGES 1
Linus Torvalds1da177e2005-04-16 15:20:36 -070014#define VSYSCALL_ADDR(vsyscall_nr) (VSYSCALL_START+VSYSCALL_SIZE*(vsyscall_nr))
15
16#ifdef __KERNEL__
David Woodhouse75da7362006-09-16 12:15:48 -070017#include <linux/seqlock.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070018
Vojtech Pavlikc08c8202006-09-26 10:52:28 +020019#define VGETCPU_RDTSCP 1
20#define VGETCPU_LSL 2
21
Linus Torvalds1da177e2005-04-16 15:20:36 -070022/* kernel space (writeable) */
Vojtech Pavlikc08c8202006-09-26 10:52:28 +020023extern int vgetcpu_mode;
Linus Torvalds1da177e2005-04-16 15:20:36 -070024extern struct timezone sys_tz;
Linus Torvalds1da177e2005-04-16 15:20:36 -070025
Andy Lutomirski8c49d9a2011-05-23 09:31:24 -040026#include <asm/vvar.h>
27
Ingo Molnare4026442008-01-30 13:32:39 +010028extern void map_vsyscall(void);
29
Andy Lutomirski3ae36652011-08-10 11:15:32 -040030/*
31 * Called on instruction fetch fault in vsyscall page.
32 * Returns true if handled.
33 */
34extern bool emulate_vsyscall(struct pt_regs *regs, unsigned long address);
35
Marcelo Tosatti51c19b42012-11-27 23:28:57 -020036#ifdef CONFIG_X86_64
37
38#define VGETCPU_CPU_MASK 0xfff
39
40static inline unsigned int __getcpu(void)
41{
42 unsigned int p;
43
44 if (VVAR(vgetcpu_mode) == VGETCPU_RDTSCP) {
45 /* Load per CPU data from RDTSCP */
46 native_read_tscp(&p);
47 } else {
48 /* Load per CPU data from GDT */
49 asm("lsl %1,%0" : "=r" (p) : "r" (__PER_CPU_SEG));
50 }
51
52 return p;
53}
54#endif /* CONFIG_X86_64 */
55
Linus Torvalds1da177e2005-04-16 15:20:36 -070056#endif /* __KERNEL__ */
57
H. Peter Anvin1965aae2008-10-22 22:26:29 -070058#endif /* _ASM_X86_VSYSCALL_H */