elfcore32.h 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. /*
  2. * IA-32 ELF core dump support.
  3. *
  4. * Copyright (C) 2003 Arun Sharma <arun.sharma@intel.com>
  5. *
  6. * Derived from the x86_64 version
  7. */
  8. #ifndef _ELFCORE32_H_
  9. #define _ELFCORE32_H_
  10. #include <asm/intrinsics.h>
  11. #include <asm/uaccess.h>
  12. #define USE_ELF_CORE_DUMP 1
  13. /* Override elfcore.h */
  14. #define _LINUX_ELFCORE_H 1
  15. typedef unsigned int elf_greg_t;
  16. #define ELF_NGREG (sizeof (struct user_regs_struct32) / sizeof(elf_greg_t))
  17. typedef elf_greg_t elf_gregset_t[ELF_NGREG];
  18. typedef struct ia32_user_i387_struct elf_fpregset_t;
  19. typedef struct ia32_user_fxsr_struct elf_fpxregset_t;
  20. struct elf_siginfo
  21. {
  22. int si_signo; /* signal number */
  23. int si_code; /* extra code */
  24. int si_errno; /* errno */
  25. };
  26. #ifdef CONFIG_VIRT_CPU_ACCOUNTING
  27. /*
  28. * Hacks are here since types between compat_timeval (= pair of s32) and
  29. * ia64-native timeval (= pair of s64) are not compatible, at least a file
  30. * arch/ia64/ia32/../../../fs/binfmt_elf.c will get warnings from compiler on
  31. * use of cputime_to_timeval(), which usually an alias of jiffies_to_timeval().
  32. */
  33. #define cputime_to_timeval(a,b) \
  34. do { (b)->tv_usec = 0; (b)->tv_sec = (a)/NSEC_PER_SEC; } while(0)
  35. #else
  36. #define jiffies_to_timeval(a,b) \
  37. do { (b)->tv_usec = 0; (b)->tv_sec = (a)/HZ; } while(0)
  38. #endif
  39. struct elf_prstatus
  40. {
  41. struct elf_siginfo pr_info; /* Info associated with signal */
  42. short pr_cursig; /* Current signal */
  43. unsigned int pr_sigpend; /* Set of pending signals */
  44. unsigned int pr_sighold; /* Set of held signals */
  45. pid_t pr_pid;
  46. pid_t pr_ppid;
  47. pid_t pr_pgrp;
  48. pid_t pr_sid;
  49. struct compat_timeval pr_utime; /* User time */
  50. struct compat_timeval pr_stime; /* System time */
  51. struct compat_timeval pr_cutime; /* Cumulative user time */
  52. struct compat_timeval pr_cstime; /* Cumulative system time */
  53. elf_gregset_t pr_reg; /* GP registers */
  54. int pr_fpvalid; /* True if math co-processor being used. */
  55. };
  56. #define ELF_PRARGSZ (80) /* Number of chars for args */
  57. struct elf_prpsinfo
  58. {
  59. char pr_state; /* numeric process state */
  60. char pr_sname; /* char for pr_state */
  61. char pr_zomb; /* zombie */
  62. char pr_nice; /* nice val */
  63. unsigned int pr_flag; /* flags */
  64. __u16 pr_uid;
  65. __u16 pr_gid;
  66. pid_t pr_pid, pr_ppid, pr_pgrp, pr_sid;
  67. /* Lots missing */
  68. char pr_fname[16]; /* filename of executable */
  69. char pr_psargs[ELF_PRARGSZ]; /* initial part of arg list */
  70. };
  71. #define ELF_CORE_COPY_REGS(pr_reg, regs) \
  72. pr_reg[0] = regs->r11; \
  73. pr_reg[1] = regs->r9; \
  74. pr_reg[2] = regs->r10; \
  75. pr_reg[3] = regs->r14; \
  76. pr_reg[4] = regs->r15; \
  77. pr_reg[5] = regs->r13; \
  78. pr_reg[6] = regs->r8; \
  79. pr_reg[7] = regs->r16 & 0xffff; \
  80. pr_reg[8] = (regs->r16 >> 16) & 0xffff; \
  81. pr_reg[9] = (regs->r16 >> 32) & 0xffff; \
  82. pr_reg[10] = (regs->r16 >> 48) & 0xffff; \
  83. pr_reg[11] = regs->r1; \
  84. pr_reg[12] = regs->cr_iip; \
  85. pr_reg[13] = regs->r17 & 0xffff; \
  86. pr_reg[14] = ia64_getreg(_IA64_REG_AR_EFLAG); \
  87. pr_reg[15] = regs->r12; \
  88. pr_reg[16] = (regs->r17 >> 16) & 0xffff;
  89. static inline void elf_core_copy_regs(elf_gregset_t *elfregs,
  90. struct pt_regs *regs)
  91. {
  92. ELF_CORE_COPY_REGS((*elfregs), regs)
  93. }
  94. static inline int elf_core_copy_task_regs(struct task_struct *t,
  95. elf_gregset_t* elfregs)
  96. {
  97. ELF_CORE_COPY_REGS((*elfregs), task_pt_regs(t));
  98. return 1;
  99. }
  100. static inline int
  101. elf_core_copy_task_fpregs(struct task_struct *tsk, struct pt_regs *regs, elf_fpregset_t *fpu)
  102. {
  103. struct ia32_user_i387_struct *fpstate = (void*)fpu;
  104. mm_segment_t old_fs;
  105. if (!tsk_used_math(tsk))
  106. return 0;
  107. old_fs = get_fs();
  108. set_fs(KERNEL_DS);
  109. save_ia32_fpstate(tsk, (struct ia32_user_i387_struct __user *) fpstate);
  110. set_fs(old_fs);
  111. return 1;
  112. }
  113. #define ELF_CORE_COPY_XFPREGS 1
  114. #define ELF_CORE_XFPREG_TYPE NT_PRXFPREG
  115. static inline int
  116. elf_core_copy_task_xfpregs(struct task_struct *tsk, elf_fpxregset_t *xfpu)
  117. {
  118. struct ia32_user_fxsr_struct *fpxstate = (void*) xfpu;
  119. mm_segment_t old_fs;
  120. if (!tsk_used_math(tsk))
  121. return 0;
  122. old_fs = get_fs();
  123. set_fs(KERNEL_DS);
  124. save_ia32_fpxstate(tsk, (struct ia32_user_fxsr_struct __user *) fpxstate);
  125. set_fs(old_fs);
  126. return 1;
  127. }
  128. #endif /* _ELFCORE32_H_ */