H. Peter Anvin | 1965aae | 2008-10-22 22:26:29 -0700 | [diff] [blame] | 1 | #ifndef _ASM_X86_VSYSCALL_H |
| 2 | #define _ASM_X86_VSYSCALL_H |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 3 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 4 | enum vsyscall_num { |
| 5 | __NR_vgettimeofday, |
| 6 | __NR_vtime, |
Vojtech Pavlik | c08c820 | 2006-09-26 10:52:28 +0200 | [diff] [blame] | 7 | __NR_vgetcpu, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 8 | }; |
| 9 | |
| 10 | #define VSYSCALL_START (-10UL << 20) |
| 11 | #define VSYSCALL_SIZE 1024 |
| 12 | #define VSYSCALL_END (-2UL << 20) |
Ernie Petrides | 103efcd | 2006-12-07 02:14:09 +0100 | [diff] [blame] | 13 | #define VSYSCALL_MAPPED_PAGES 1 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 14 | #define VSYSCALL_ADDR(vsyscall_nr) (VSYSCALL_START+VSYSCALL_SIZE*(vsyscall_nr)) |
| 15 | |
| 16 | #ifdef __KERNEL__ |
David Woodhouse | 75da736 | 2006-09-16 12:15:48 -0700 | [diff] [blame] | 17 | #include <linux/seqlock.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 18 | |
Vojtech Pavlik | c08c820 | 2006-09-26 10:52:28 +0200 | [diff] [blame] | 19 | #define VGETCPU_RDTSCP 1 |
| 20 | #define VGETCPU_LSL 2 |
| 21 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 22 | /* kernel space (writeable) */ |
Vojtech Pavlik | c08c820 | 2006-09-26 10:52:28 +0200 | [diff] [blame] | 23 | extern int vgetcpu_mode; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 24 | extern struct timezone sys_tz; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 25 | |
Andy Lutomirski | 8c49d9a | 2011-05-23 09:31:24 -0400 | [diff] [blame] | 26 | #include <asm/vvar.h> |
| 27 | |
Ingo Molnar | e402644 | 2008-01-30 13:32:39 +0100 | [diff] [blame] | 28 | extern void map_vsyscall(void); |
| 29 | |
Andy Lutomirski | 3ae3665 | 2011-08-10 11:15:32 -0400 | [diff] [blame] | 30 | /* |
| 31 | * Called on instruction fetch fault in vsyscall page. |
| 32 | * Returns true if handled. |
| 33 | */ |
| 34 | extern bool emulate_vsyscall(struct pt_regs *regs, unsigned long address); |
| 35 | |
Marcelo Tosatti | 51c19b4 | 2012-11-27 23:28:57 -0200 | [diff] [blame] | 36 | #ifdef CONFIG_X86_64 |
| 37 | |
| 38 | #define VGETCPU_CPU_MASK 0xfff |
| 39 | |
| 40 | static 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 Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 56 | #endif /* __KERNEL__ */ |
| 57 | |
H. Peter Anvin | 1965aae | 2008-10-22 22:26:29 -0700 | [diff] [blame] | 58 | #endif /* _ASM_X86_VSYSCALL_H */ |