1*b2441318SGreg Kroah-Hartman // SPDX-License-Identifier: GPL-2.0
21da177e4SLinus Torvalds /*
31da177e4SLinus Torvalds * This program is used to generate definitions needed by
41da177e4SLinus Torvalds * assembly language modules.
51da177e4SLinus Torvalds *
61da177e4SLinus Torvalds * We use the technique used in the OSF Mach kernel code:
71da177e4SLinus Torvalds * generate asm statements containing #defines,
81da177e4SLinus Torvalds * compile this file to assembler, and then extract the
91da177e4SLinus Torvalds * #defines from the assembly-language output.
101da177e4SLinus Torvalds *
111da177e4SLinus Torvalds * On sparc, thread_info data is static and TI_XXX offsets are computed by hand.
121da177e4SLinus Torvalds */
131da177e4SLinus Torvalds
141da177e4SLinus Torvalds #include <linux/sched.h>
15589ee628SIngo Molnar #include <linux/mm_types.h>
161da177e4SLinus Torvalds // #include <linux/mm.h>
1732b07679SChristoph Lameter #include <linux/kbuild.h>
181da177e4SLinus Torvalds
19bdde6b3cSTkhai Kirill #include <asm/hibernate.h>
20bdde6b3cSTkhai Kirill
21b5db854aSSam Ravnborg #ifdef CONFIG_SPARC32
sparc32_foo(void)22b5db854aSSam Ravnborg int sparc32_foo(void)
231da177e4SLinus Torvalds {
241da177e4SLinus Torvalds DEFINE(AOFF_thread_fork_kpsr,
251da177e4SLinus Torvalds offsetof(struct thread_struct, fork_kpsr));
26b5db854aSSam Ravnborg return 0;
27b5db854aSSam Ravnborg }
28b5db854aSSam Ravnborg #else
sparc64_foo(void)29b5db854aSSam Ravnborg int sparc64_foo(void)
30b5db854aSSam Ravnborg {
31bdde6b3cSTkhai Kirill #ifdef CONFIG_HIBERNATION
32bdde6b3cSTkhai Kirill BLANK();
33bdde6b3cSTkhai Kirill OFFSET(SC_REG_FP, saved_context, fp);
34bdde6b3cSTkhai Kirill OFFSET(SC_REG_CWP, saved_context, cwp);
35bdde6b3cSTkhai Kirill OFFSET(SC_REG_WSTATE, saved_context, wstate);
36bdde6b3cSTkhai Kirill
37bdde6b3cSTkhai Kirill OFFSET(SC_REG_TICK, saved_context, tick);
38bdde6b3cSTkhai Kirill OFFSET(SC_REG_PSTATE, saved_context, pstate);
39bdde6b3cSTkhai Kirill
40bdde6b3cSTkhai Kirill OFFSET(SC_REG_G4, saved_context, g4);
41bdde6b3cSTkhai Kirill OFFSET(SC_REG_G5, saved_context, g5);
42bdde6b3cSTkhai Kirill OFFSET(SC_REG_G6, saved_context, g6);
43bdde6b3cSTkhai Kirill #endif
44b5db854aSSam Ravnborg return 0;
45b5db854aSSam Ravnborg }
46b5db854aSSam Ravnborg #endif
47b5db854aSSam Ravnborg
foo(void)48b5db854aSSam Ravnborg int foo(void)
49b5db854aSSam Ravnborg {
50b5db854aSSam Ravnborg BLANK();
51b5db854aSSam Ravnborg DEFINE(AOFF_task_thread, offsetof(struct task_struct, thread));
521da177e4SLinus Torvalds BLANK();
531da177e4SLinus Torvalds DEFINE(AOFF_mm_context, offsetof(struct mm_struct, context));
54961246b4SOlivier DANET BLANK();
55961246b4SOlivier DANET DEFINE(VMA_VM_MM, offsetof(struct vm_area_struct, vm_mm));
561da177e4SLinus Torvalds
571da177e4SLinus Torvalds /* DEFINE(NUM_USER_SEGMENTS, TASK_SIZE>>28); */
581da177e4SLinus Torvalds return 0;
591da177e4SLinus Torvalds }
60b5db854aSSam Ravnborg
61