2 * This program is used to generate definitions needed by
3 * assembly language modules.
5 * We use the technique used in the OSF Mach kernel code:
6 * generate asm statements containing #defines,
7 * compile this file to assembler, and then extract the
8 * #defines from the assembly-language output.
11 #include <linux/stddef.h>
12 #include <linux/sched.h>
13 #include <linux/kernel_stat.h>
14 #include <linux/ptrace.h>
15 #include <linux/hardirq.h>
16 #include <asm/bootinfo.h>
18 #include <asm/thread_info.h>
20 #define DEFINE(sym, val) \
21 asm volatile("\n->" #sym " %0 " #val : : "i" (val))
23 #define BLANK() asm volatile("\n->" : : )
27 /* offsets into the task struct */
28 DEFINE(TASK_STATE
, offsetof(struct task_struct
, state
));
29 DEFINE(TASK_FLAGS
, offsetof(struct task_struct
, flags
));
30 DEFINE(TASK_PTRACE
, offsetof(struct task_struct
, ptrace
));
31 DEFINE(TASK_BLOCKED
, offsetof(struct task_struct
, blocked
));
32 DEFINE(TASK_THREAD
, offsetof(struct task_struct
, thread
));
33 DEFINE(TASK_THREAD_INFO
, offsetof(struct task_struct
, thread_info
));
34 DEFINE(TASK_MM
, offsetof(struct task_struct
, mm
));
35 DEFINE(TASK_ACTIVE_MM
, offsetof(struct task_struct
, active_mm
));
37 /* offsets into the kernel_stat struct */
38 DEFINE(STAT_IRQ
, offsetof(struct kernel_stat
, irqs
));
40 /* offsets into the irq_cpustat_t struct */
41 DEFINE(CPUSTAT_SOFTIRQ_PENDING
, offsetof(irq_cpustat_t
, __softirq_pending
));
43 /* offsets into the thread struct */
44 DEFINE(THREAD_KSP
, offsetof(struct thread_struct
, ksp
));
45 DEFINE(THREAD_USP
, offsetof(struct thread_struct
, usp
));
46 DEFINE(THREAD_SR
, offsetof(struct thread_struct
, sr
));
47 DEFINE(THREAD_FS
, offsetof(struct thread_struct
, fs
));
48 DEFINE(THREAD_CRP
, offsetof(struct thread_struct
, crp
));
49 DEFINE(THREAD_ESP0
, offsetof(struct thread_struct
, esp0
));
50 DEFINE(THREAD_FPREG
, offsetof(struct thread_struct
, fp
));
51 DEFINE(THREAD_FPCNTL
, offsetof(struct thread_struct
, fpcntl
));
52 DEFINE(THREAD_FPSTATE
, offsetof(struct thread_struct
, fpstate
));
54 /* offsets into the pt_regs */
55 DEFINE(PT_D0
, offsetof(struct pt_regs
, d0
));
56 DEFINE(PT_ORIG_D0
, offsetof(struct pt_regs
, orig_d0
));
57 DEFINE(PT_D1
, offsetof(struct pt_regs
, d1
));
58 DEFINE(PT_D2
, offsetof(struct pt_regs
, d2
));
59 DEFINE(PT_D3
, offsetof(struct pt_regs
, d3
));
60 DEFINE(PT_D4
, offsetof(struct pt_regs
, d4
));
61 DEFINE(PT_D5
, offsetof(struct pt_regs
, d5
));
62 DEFINE(PT_A0
, offsetof(struct pt_regs
, a0
));
63 DEFINE(PT_A1
, offsetof(struct pt_regs
, a1
));
64 DEFINE(PT_A2
, offsetof(struct pt_regs
, a2
));
65 DEFINE(PT_PC
, offsetof(struct pt_regs
, pc
));
66 DEFINE(PT_SR
, offsetof(struct pt_regs
, sr
));
68 #ifdef CONFIG_COLDFIRE
69 /* bitfields are a bit difficult */
70 DEFINE(PT_FORMATVEC
, offsetof(struct pt_regs
, sr
) - 2);
72 /* bitfields are a bit difficult */
73 DEFINE(PT_VECTOR
, offsetof(struct pt_regs
, pc
) + 4);
74 /* offsets into the irq_handler struct */
75 DEFINE(IRQ_HANDLER
, offsetof(struct irq_node
, handler
));
76 DEFINE(IRQ_DEVID
, offsetof(struct irq_node
, dev_id
));
77 DEFINE(IRQ_NEXT
, offsetof(struct irq_node
, next
));
80 /* offsets into the kernel_stat struct */
81 DEFINE(STAT_IRQ
, offsetof(struct kernel_stat
, irqs
));
84 DEFINE(SIGSEGV
, SIGSEGV
);
85 DEFINE(SEGV_MAPERR
, SEGV_MAPERR
);
86 DEFINE(SIGTRAP
, SIGTRAP
);
87 DEFINE(TRAP_TRACE
, TRAP_TRACE
);
89 DEFINE(PT_PTRACED
, PT_PTRACED
);
90 DEFINE(PT_DTRACE
, PT_DTRACE
);
92 DEFINE(THREAD_SIZE
, THREAD_SIZE
);
94 /* Offsets in thread_info structure */
95 DEFINE(TI_TASK
, offsetof(struct thread_info
, task
));
96 DEFINE(TI_EXECDOMAIN
, offsetof(struct thread_info
, exec_domain
));
97 DEFINE(TI_FLAGS
, offsetof(struct thread_info
, flags
));
98 DEFINE(TI_CPU
, offsetof(struct thread_info
, cpu
));