2007-10-11 11:14:19 +02:00
/*
* Generate definitions needed by assembly language modules .
* This code generates raw asm output which is post - processed to extract
* and format the required data .
*/
2009-08-26 12:09:10 -04:00
# define COMPILE_OFFSETS
2007-10-11 11:14:19 +02:00
# include <linux/crypto.h>
# include <linux/sched.h>
# include <linux/stddef.h>
# include <linux/errno.h>
# include <linux/hardirq.h>
# include <linux/suspend.h>
2008-04-29 01:03:54 -07:00
# include <linux/kbuild.h>
2007-10-11 11:14:19 +02:00
# include <asm/processor.h>
# include <asm/segment.h>
# include <asm/thread_info.h>
# include <asm/ia32.h>
2007-10-26 11:29:04 -06:00
# include <asm/bootparam.h>
2009-03-31 15:23:37 -07:00
# include <asm/suspend.h>
2007-10-11 11:14:19 +02:00
2008-07-08 15:06:45 -07:00
# include <xen/interface/xen.h>
2008-12-18 14:46:52 -08:00
# include <asm/sigframe.h>
2007-10-11 11:14:19 +02:00
# define __NO_STUBS 1
# undef __SYSCALL
2008-10-22 22:26:29 -07:00
# undef _ASM_X86_UNISTD_64_H
2007-10-11 11:14:19 +02:00
# define __SYSCALL(nr, sym) [nr] = 1,
static char syscalls [ ] = {
# include <asm/unistd.h>
} ;
int main ( void )
{
# define ENTRY(entry) DEFINE(tsk_ ## entry, offsetof(struct task_struct, entry))
ENTRY ( state ) ;
ENTRY ( flags ) ;
ENTRY ( pid ) ;
BLANK ( ) ;
# undef ENTRY
2008-06-24 11:19:35 -03:00
# define ENTRY(entry) DEFINE(TI_ ## entry, offsetof(struct thread_info, entry))
2007-10-11 11:14:19 +02:00
ENTRY ( flags ) ;
ENTRY ( addr_limit ) ;
ENTRY ( preempt_count ) ;
ENTRY ( status ) ;
2008-01-30 13:30:43 +01:00
# ifdef CONFIG_IA32_EMULATION
ENTRY ( sysenter_return ) ;
# endif
2007-10-11 11:14:19 +02:00
BLANK ( ) ;
# undef ENTRY
2008-01-30 13:33:19 +01:00
# ifdef CONFIG_PARAVIRT
BLANK ( ) ;
OFFSET ( PARAVIRT_enabled , pv_info , paravirt_enabled ) ;
OFFSET ( PARAVIRT_PATCH_pv_cpu_ops , paravirt_patch_template , pv_cpu_ops ) ;
OFFSET ( PARAVIRT_PATCH_pv_irq_ops , paravirt_patch_template , pv_irq_ops ) ;
OFFSET ( PV_IRQ_irq_disable , pv_irq_ops , irq_disable ) ;
OFFSET ( PV_IRQ_irq_enable , pv_irq_ops , irq_enable ) ;
2008-06-25 00:19:31 -04:00
OFFSET ( PV_IRQ_adjust_exception_frame , pv_irq_ops , adjust_exception_frame ) ;
2008-01-30 13:33:19 +01:00
OFFSET ( PV_CPU_iret , pv_cpu_ops , iret ) ;
2008-06-25 00:19:28 -04:00
OFFSET ( PV_CPU_usergs_sysret32 , pv_cpu_ops , usergs_sysret32 ) ;
OFFSET ( PV_CPU_usergs_sysret64 , pv_cpu_ops , usergs_sysret64 ) ;
OFFSET ( PV_CPU_irq_enable_sysexit , pv_cpu_ops , irq_enable_sysexit ) ;
2008-01-30 13:33:19 +01:00
OFFSET ( PV_CPU_swapgs , pv_cpu_ops , swapgs ) ;
OFFSET ( PV_MMU_read_cr2 , pv_mmu_ops , read_cr2 ) ;
# endif
2007-10-11 11:14:19 +02:00
# ifdef CONFIG_IA32_EMULATION
# define ENTRY(entry) DEFINE(IA32_SIGCONTEXT_ ## entry, offsetof(struct sigcontext_ia32, entry))
2008-01-30 13:30:56 +01:00
ENTRY ( ax ) ;
ENTRY ( bx ) ;
ENTRY ( cx ) ;
ENTRY ( dx ) ;
ENTRY ( si ) ;
ENTRY ( di ) ;
ENTRY ( bp ) ;
ENTRY ( sp ) ;
ENTRY ( ip ) ;
2007-10-11 11:14:19 +02:00
BLANK ( ) ;
# undef ENTRY
DEFINE ( IA32_RT_SIGFRAME_sigcontext ,
2008-12-18 14:46:52 -08:00
offsetof ( struct rt_sigframe_ia32 , uc . uc_mcontext ) ) ;
2007-10-11 11:14:19 +02:00
BLANK ( ) ;
# endif
DEFINE ( pbe_address , offsetof ( struct pbe , address ) ) ;
DEFINE ( pbe_orig_address , offsetof ( struct pbe , orig_address ) ) ;
DEFINE ( pbe_next , offsetof ( struct pbe , next ) ) ;
BLANK ( ) ;
2007-10-23 22:37:24 +02:00
# define ENTRY(entry) DEFINE(pt_regs_ ## entry, offsetof(struct pt_regs, entry))
2008-01-30 13:30:56 +01:00
ENTRY ( bx ) ;
ENTRY ( bx ) ;
ENTRY ( cx ) ;
ENTRY ( dx ) ;
ENTRY ( sp ) ;
ENTRY ( bp ) ;
ENTRY ( si ) ;
ENTRY ( di ) ;
2007-10-23 22:37:24 +02:00
ENTRY ( r8 ) ;
ENTRY ( r9 ) ;
ENTRY ( r10 ) ;
ENTRY ( r11 ) ;
ENTRY ( r12 ) ;
ENTRY ( r13 ) ;
ENTRY ( r14 ) ;
ENTRY ( r15 ) ;
2008-01-30 13:30:56 +01:00
ENTRY ( flags ) ;
2007-10-23 22:37:24 +02:00
BLANK ( ) ;
# undef ENTRY
# define ENTRY(entry) DEFINE(saved_context_ ## entry, offsetof(struct saved_context, entry))
ENTRY ( cr0 ) ;
ENTRY ( cr2 ) ;
ENTRY ( cr3 ) ;
ENTRY ( cr4 ) ;
ENTRY ( cr8 ) ;
BLANK ( ) ;
# undef ENTRY
2008-01-30 13:31:31 +01:00
DEFINE ( TSS_ist , offsetof ( struct tss_struct , x86_tss . ist ) ) ;
2007-10-11 11:14:19 +02:00
BLANK ( ) ;
DEFINE ( crypto_tfm_ctx_offset , offsetof ( struct crypto_tfm , __crt_ctx ) ) ;
BLANK ( ) ;
DEFINE ( __NR_syscall_max , sizeof ( syscalls ) - 1 ) ;
2007-10-26 11:29:04 -06:00
BLANK ( ) ;
OFFSET ( BP_scratch , boot_params , scratch ) ;
OFFSET ( BP_loadflags , boot_params , hdr . loadflags ) ;
OFFSET ( BP_hardware_subarch , boot_params , hdr . hardware_subarch ) ;
OFFSET ( BP_version , boot_params , hdr . version ) ;
2009-05-11 15:56:08 -07:00
OFFSET ( BP_kernel_alignment , boot_params , hdr . kernel_alignment ) ;
2008-07-08 15:06:44 -07:00
BLANK ( ) ;
DEFINE ( PAGE_SIZE_asm , PAGE_SIZE ) ;
2008-07-08 15:06:45 -07:00
# ifdef CONFIG_XEN
BLANK ( ) ;
OFFSET ( XEN_vcpu_info_mask , vcpu_info , evtchn_upcall_mask ) ;
OFFSET ( XEN_vcpu_info_pending , vcpu_info , evtchn_upcall_pending ) ;
# undef ENTRY
# endif
2007-10-11 11:14:19 +02:00
return 0 ;
}