| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* | 
 | 2 |  * Generate definitions needed by assembly language modules. | 
 | 3 |  * This code generates raw asm output which is post-processed to extract | 
 | 4 |  * and format the required data. | 
 | 5 |  */ | 
 | 6 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 7 | #include <linux/sched.h> | 
| Christoph Lameter | 7a88d7a | 2008-04-29 01:04:09 -0700 | [diff] [blame] | 8 | #include <linux/kbuild.h> | 
| Martin Schwidefsky | b020632 | 2008-12-25 13:38:36 +0100 | [diff] [blame] | 9 | #include <asm/vdso.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 10 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 11 | int main(void) | 
 | 12 | { | 
| Christoph Lameter | 4ca4d7b | 2008-04-29 01:04:10 -0700 | [diff] [blame] | 13 | 	DEFINE(__THREAD_info, offsetof(struct task_struct, stack)); | 
 | 14 | 	DEFINE(__THREAD_ksp, offsetof(struct task_struct, thread.ksp)); | 
 | 15 | 	DEFINE(__THREAD_per, offsetof(struct task_struct, thread.per_info)); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 16 | 	DEFINE(__THREAD_mm_segment, | 
| Christoph Lameter | 4ca4d7b | 2008-04-29 01:04:10 -0700 | [diff] [blame] | 17 | 	       offsetof(struct task_struct, thread.mm_segment)); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 18 | 	BLANK(); | 
| Christoph Lameter | 4ca4d7b | 2008-04-29 01:04:10 -0700 | [diff] [blame] | 19 | 	DEFINE(__TASK_pid, offsetof(struct task_struct, pid)); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 20 | 	BLANK(); | 
| Christoph Lameter | 4ca4d7b | 2008-04-29 01:04:10 -0700 | [diff] [blame] | 21 | 	DEFINE(__PER_atmid, offsetof(per_struct, lowcore.words.perc_atmid)); | 
 | 22 | 	DEFINE(__PER_address, offsetof(per_struct, lowcore.words.address)); | 
 | 23 | 	DEFINE(__PER_access_id, offsetof(per_struct, lowcore.words.access_id)); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 24 | 	BLANK(); | 
| Christoph Lameter | 4ca4d7b | 2008-04-29 01:04:10 -0700 | [diff] [blame] | 25 | 	DEFINE(__TI_task, offsetof(struct thread_info, task)); | 
 | 26 | 	DEFINE(__TI_domain, offsetof(struct thread_info, exec_domain)); | 
 | 27 | 	DEFINE(__TI_flags, offsetof(struct thread_info, flags)); | 
 | 28 | 	DEFINE(__TI_cpu, offsetof(struct thread_info, cpu)); | 
 | 29 | 	DEFINE(__TI_precount, offsetof(struct thread_info, preempt_count)); | 
| Martin Schwidefsky | 5b409ed | 2009-04-14 15:36:27 +0200 | [diff] [blame] | 30 | 	DEFINE(__TI_user_timer, offsetof(struct thread_info, user_timer)); | 
 | 31 | 	DEFINE(__TI_system_timer, offsetof(struct thread_info, system_timer)); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 32 | 	BLANK(); | 
| Christoph Lameter | 4ca4d7b | 2008-04-29 01:04:10 -0700 | [diff] [blame] | 33 | 	DEFINE(__PT_ARGS, offsetof(struct pt_regs, args)); | 
 | 34 | 	DEFINE(__PT_PSW, offsetof(struct pt_regs, psw)); | 
 | 35 | 	DEFINE(__PT_GPRS, offsetof(struct pt_regs, gprs)); | 
 | 36 | 	DEFINE(__PT_ORIG_GPR2, offsetof(struct pt_regs, orig_gpr2)); | 
 | 37 | 	DEFINE(__PT_ILC, offsetof(struct pt_regs, ilc)); | 
| Martin Schwidefsky | 59da213 | 2008-11-27 11:05:55 +0100 | [diff] [blame] | 38 | 	DEFINE(__PT_SVCNR, offsetof(struct pt_regs, svcnr)); | 
| Christoph Lameter | 4ca4d7b | 2008-04-29 01:04:10 -0700 | [diff] [blame] | 39 | 	DEFINE(__PT_SIZE, sizeof(struct pt_regs)); | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 40 | 	BLANK(); | 
| Christoph Lameter | 4ca4d7b | 2008-04-29 01:04:10 -0700 | [diff] [blame] | 41 | 	DEFINE(__SF_BACKCHAIN, offsetof(struct stack_frame, back_chain)); | 
 | 42 | 	DEFINE(__SF_GPRS, offsetof(struct stack_frame, gprs)); | 
 | 43 | 	DEFINE(__SF_EMPTY, offsetof(struct stack_frame, empty1)); | 
| Martin Schwidefsky | b020632 | 2008-12-25 13:38:36 +0100 | [diff] [blame] | 44 | 	BLANK(); | 
 | 45 | 	/* timeval/timezone offsets for use by vdso */ | 
 | 46 | 	DEFINE(__VDSO_UPD_COUNT, offsetof(struct vdso_data, tb_update_count)); | 
 | 47 | 	DEFINE(__VDSO_XTIME_STAMP, offsetof(struct vdso_data, xtime_tod_stamp)); | 
 | 48 | 	DEFINE(__VDSO_XTIME_SEC, offsetof(struct vdso_data, xtime_clock_sec)); | 
 | 49 | 	DEFINE(__VDSO_XTIME_NSEC, offsetof(struct vdso_data, xtime_clock_nsec)); | 
 | 50 | 	DEFINE(__VDSO_WTOM_SEC, offsetof(struct vdso_data, wtom_clock_sec)); | 
 | 51 | 	DEFINE(__VDSO_WTOM_NSEC, offsetof(struct vdso_data, wtom_clock_nsec)); | 
 | 52 | 	DEFINE(__VDSO_TIMEZONE, offsetof(struct vdso_data, tz_minuteswest)); | 
| Martin Schwidefsky | c742b31 | 2008-12-31 15:11:42 +0100 | [diff] [blame] | 53 | 	DEFINE(__VDSO_ECTG_OK, offsetof(struct vdso_data, ectg_available)); | 
 | 54 | 	DEFINE(__VDSO_ECTG_BASE, | 
 | 55 | 	       offsetof(struct vdso_per_cpu_data, ectg_timer_base)); | 
 | 56 | 	DEFINE(__VDSO_ECTG_USER, | 
 | 57 | 	       offsetof(struct vdso_per_cpu_data, ectg_user_time)); | 
| Martin Schwidefsky | b020632 | 2008-12-25 13:38:36 +0100 | [diff] [blame] | 58 | 	/* constants used by the vdso */ | 
 | 59 | 	DEFINE(CLOCK_REALTIME, CLOCK_REALTIME); | 
 | 60 | 	DEFINE(CLOCK_MONOTONIC, CLOCK_MONOTONIC); | 
 | 61 | 	DEFINE(CLOCK_REALTIME_RES, MONOTONIC_RES_NSEC); | 
 | 62 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 63 | 	return 0; | 
 | 64 | } |