blob: 7bdd7c8ebc91410f6d3eb616fab0d3660a13add7 [file] [log] [blame]
Martin Schwidefskyb0206322008-12-25 13:38:36 +01001#ifndef __S390_VDSO_H__
2#define __S390_VDSO_H__
3
4#ifdef __KERNEL__
5
6/* Default link addresses for the vDSOs */
7#define VDSO32_LBASE 0
8#define VDSO64_LBASE 0
9
10#define VDSO_VERSION_STRING LINUX_2.6.26
11
12#ifndef __ASSEMBLY__
13
14/*
Martin Schwidefskyc742b312008-12-31 15:11:42 +010015 * Note about the vdso_data and vdso_per_cpu_data structures:
Martin Schwidefskyb0206322008-12-25 13:38:36 +010016 *
Martin Schwidefskyc742b312008-12-31 15:11:42 +010017 * NEVER USE THEM IN USERSPACE CODE DIRECTLY. The layout of the
Martin Schwidefskyb0206322008-12-25 13:38:36 +010018 * structure is supposed to be known only to the function in the vdso
19 * itself and may change without notice.
20 */
21
22struct vdso_data {
23 __u64 tb_update_count; /* Timebase atomicity ctr 0x00 */
24 __u64 xtime_tod_stamp; /* TOD clock for xtime 0x08 */
25 __u64 xtime_clock_sec; /* Kernel time 0x10 */
26 __u64 xtime_clock_nsec; /* 0x18 */
27 __u64 wtom_clock_sec; /* Wall to monotonic clock 0x20 */
28 __u64 wtom_clock_nsec; /* 0x28 */
29 __u32 tz_minuteswest; /* Minutes west of Greenwich 0x30 */
30 __u32 tz_dsttime; /* Type of dst correction 0x34 */
Martin Schwidefskyc742b312008-12-31 15:11:42 +010031 __u32 ectg_available;
32};
33
34struct vdso_per_cpu_data {
35 __u64 ectg_timer_base;
36 __u64 ectg_user_time;
Martin Schwidefskyb0206322008-12-25 13:38:36 +010037};
38
39extern struct vdso_data *vdso_data;
40
Martin Schwidefskyc742b312008-12-31 15:11:42 +010041#ifdef CONFIG_64BIT
42int vdso_alloc_per_cpu(int cpu, struct _lowcore *lowcore);
43void vdso_free_per_cpu(int cpu, struct _lowcore *lowcore);
44#endif
45
Martin Schwidefskyb0206322008-12-25 13:38:36 +010046#endif /* __ASSEMBLY__ */
47
48#endif /* __KERNEL__ */
49
50#endif /* __S390_VDSO_H__ */