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>
19 #define DEFINE(sym, val) \
20 asm volatile("\n->" #sym " %0 " #val : : "i" (val))
22 #define BLANK() asm volatile("\n->" : : )
26 /* offsets into the task struct */
27 DEFINE(TASK_STATE
, offsetof(struct task_struct
, state
));
28 DEFINE(TASK_FLAGS
, offsetof(struct task_struct
, flags
));
29 DEFINE(TASK_PTRACE
, offsetof(struct task_struct
, ptrace
));
30 DEFINE(TASK_BLOCKED
, offsetof(struct task_struct
, blocked
));
31 DEFINE(TASK_THREAD
, offsetof(struct task_struct
, thread
));
32 DEFINE(TASK_THREAD_INFO
, offsetof(struct task_struct
, thread_info
));
33 DEFINE(TASK_MM
, offsetof(struct task_struct
, mm
));
34 DEFINE(TASK_ACTIVE_MM
, offsetof(struct task_struct
, active_mm
));
36 /* offsets into the kernel_stat struct */
37 DEFINE(STAT_IRQ
, offsetof(struct kernel_stat
, irqs
));
39 /* offsets into the irq_cpustat_t struct */
40 DEFINE(CPUSTAT_SOFTIRQ_PENDING
, offsetof(irq_cpustat_t
, __softirq_pending
));
42 /* offsets into the thread struct */
43 DEFINE(THREAD_KSP
, offsetof(struct thread_struct
, ksp
));
44 DEFINE(THREAD_USP
, offsetof(struct thread_struct
, usp
));
45 DEFINE(THREAD_SR
, offsetof(struct thread_struct
, sr
));
46 DEFINE(THREAD_FS
, offsetof(struct thread_struct
, fs
));
47 DEFINE(THREAD_CRP
, offsetof(struct thread_struct
, crp
));
48 DEFINE(THREAD_ESP0
, offsetof(struct thread_struct
, esp0
));
49 DEFINE(THREAD_FPREG
, offsetof(struct thread_struct
, fp
));
50 DEFINE(THREAD_FPCNTL
, offsetof(struct thread_struct
, fpcntl
));
51 DEFINE(THREAD_FPSTATE
, offsetof(struct thread_struct
, fpstate
));
53 /* offsets into the pt_regs */
54 DEFINE(PT_D0
, offsetof(struct pt_regs
, d0
));
55 DEFINE(PT_ORIG_D0
, offsetof(struct pt_regs
, orig_d0
));
56 DEFINE(PT_D1
, offsetof(struct pt_regs
, d1
));
57 DEFINE(PT_D2
, offsetof(struct pt_regs
, d2
));
58 DEFINE(PT_D3
, offsetof(struct pt_regs
, d3
));
59 DEFINE(PT_D4
, offsetof(struct pt_regs
, d4
));
60 DEFINE(PT_D5
, offsetof(struct pt_regs
, d5
));
61 DEFINE(PT_A0
, offsetof(struct pt_regs
, a0
));
62 DEFINE(PT_A1
, offsetof(struct pt_regs
, a1
));
63 DEFINE(PT_A2
, offsetof(struct pt_regs
, a2
));
64 DEFINE(PT_PC
, offsetof(struct pt_regs
, pc
));
65 DEFINE(PT_SR
, offsetof(struct pt_regs
, sr
));
66 /* bitfields are a bit difficult */
67 DEFINE(PT_VECTOR
, offsetof(struct pt_regs
, pc
) + 4);
69 #ifndef CONFIG_COLDFIRE
70 /* offsets into the irq_handler struct */
71 DEFINE(IRQ_HANDLER
, offsetof(struct irq_node
, handler
));
72 DEFINE(IRQ_DEVID
, offsetof(struct irq_node
, dev_id
));
73 DEFINE(IRQ_NEXT
, offsetof(struct irq_node
, next
));
76 /* offsets into the kernel_stat struct */
77 DEFINE(STAT_IRQ
, offsetof(struct kernel_stat
, irqs
));
80 DEFINE(SIGSEGV
, SIGSEGV
);
81 DEFINE(SEGV_MAPERR
, SEGV_MAPERR
);
82 DEFINE(SIGTRAP
, SIGTRAP
);
83 DEFINE(TRAP_TRACE
, TRAP_TRACE
);
85 DEFINE(PT_PTRACED
, PT_PTRACED
);
86 DEFINE(PT_DTRACE
, PT_DTRACE
);