asm-offsets.c 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
  4. */
  5. #include <linux/sched.h>
  6. #include <linux/mm.h>
  7. #include <linux/interrupt.h>
  8. #include <linux/thread_info.h>
  9. #include <linux/kbuild.h>
  10. #include <linux/ptrace.h>
  11. #include <asm/hardirq.h>
  12. #include <asm/page.h>
  13. int main(void)
  14. {
  15. DEFINE(TASK_THREAD, offsetof(struct task_struct, thread));
  16. DEFINE(TASK_THREAD_INFO, offsetof(struct task_struct, stack));
  17. BLANK();
  18. DEFINE(THREAD_KSP, offsetof(struct thread_struct, ksp));
  19. DEFINE(THREAD_CALLEE_REG, offsetof(struct thread_struct, callee_reg));
  20. DEFINE(THREAD_FAULT_ADDR,
  21. offsetof(struct thread_struct, fault_address));
  22. BLANK();
  23. DEFINE(THREAD_INFO_FLAGS, offsetof(struct thread_info, flags));
  24. DEFINE(THREAD_INFO_PREEMPT_COUNT,
  25. offsetof(struct thread_info, preempt_count));
  26. BLANK();
  27. DEFINE(TASK_ACT_MM, offsetof(struct task_struct, active_mm));
  28. DEFINE(TASK_TGID, offsetof(struct task_struct, tgid));
  29. DEFINE(TASK_PID, offsetof(struct task_struct, pid));
  30. DEFINE(TASK_COMM, offsetof(struct task_struct, comm));
  31. DEFINE(MM_CTXT, offsetof(struct mm_struct, context));
  32. DEFINE(MM_PGD, offsetof(struct mm_struct, pgd));
  33. DEFINE(MM_CTXT_ASID, offsetof(mm_context_t, asid));
  34. BLANK();
  35. DEFINE(PT_status32, offsetof(struct pt_regs, status32));
  36. DEFINE(PT_event, offsetof(struct pt_regs, event));
  37. DEFINE(PT_sp, offsetof(struct pt_regs, sp));
  38. DEFINE(PT_r0, offsetof(struct pt_regs, r0));
  39. DEFINE(PT_r1, offsetof(struct pt_regs, r1));
  40. DEFINE(PT_r2, offsetof(struct pt_regs, r2));
  41. DEFINE(PT_r3, offsetof(struct pt_regs, r3));
  42. DEFINE(PT_r4, offsetof(struct pt_regs, r4));
  43. DEFINE(PT_r5, offsetof(struct pt_regs, r5));
  44. DEFINE(PT_r6, offsetof(struct pt_regs, r6));
  45. DEFINE(PT_r7, offsetof(struct pt_regs, r7));
  46. DEFINE(PT_r8, offsetof(struct pt_regs, r8));
  47. DEFINE(PT_r10, offsetof(struct pt_regs, r10));
  48. DEFINE(PT_r26, offsetof(struct pt_regs, r26));
  49. DEFINE(PT_ret, offsetof(struct pt_regs, ret));
  50. DEFINE(PT_blink, offsetof(struct pt_regs, blink));
  51. DEFINE(PT_lpe, offsetof(struct pt_regs, lp_end));
  52. DEFINE(PT_lpc, offsetof(struct pt_regs, lp_count));
  53. DEFINE(PT_user_r25, offsetof(struct pt_regs, user_r25));
  54. DEFINE(SZ_CALLEE_REGS, sizeof(struct callee_regs));
  55. DEFINE(SZ_PT_REGS, sizeof(struct pt_regs));
  56. #ifdef CONFIG_ISA_ARCV2
  57. OFFSET(PT_r12, pt_regs, r12);
  58. OFFSET(PT_r30, pt_regs, r30);
  59. #endif
  60. #ifdef CONFIG_ARC_HAS_ACCL_REGS
  61. OFFSET(PT_r58, pt_regs, r58);
  62. OFFSET(PT_r59, pt_regs, r59);
  63. #endif
  64. #ifdef CONFIG_ARC_DSP_SAVE_RESTORE_REGS
  65. OFFSET(PT_DSP_CTRL, pt_regs, DSP_CTRL);
  66. #endif
  67. return 0;
  68. }