unwind-libdw.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. // SPDX-License-Identifier: GPL-2.0
  2. #include <elfutils/libdwfl.h>
  3. #include "../../util/unwind-libdw.h"
  4. #include "../../util/perf_regs.h"
  5. #include "../../util/event.h"
  6. bool libdw__arch_set_initial_registers(Dwfl_Thread *thread, void *arg)
  7. {
  8. struct unwind_info *ui = arg;
  9. struct regs_dump *user_regs = &ui->sample->user_regs;
  10. Dwarf_Word dwarf_regs[17];
  11. unsigned nregs;
  12. #define REG(r) ({ \
  13. Dwarf_Word val = 0; \
  14. perf_reg_value(&val, user_regs, PERF_REG_X86_##r); \
  15. val; \
  16. })
  17. if (user_regs->abi == PERF_SAMPLE_REGS_ABI_32) {
  18. dwarf_regs[0] = REG(AX);
  19. dwarf_regs[1] = REG(CX);
  20. dwarf_regs[2] = REG(DX);
  21. dwarf_regs[3] = REG(BX);
  22. dwarf_regs[4] = REG(SP);
  23. dwarf_regs[5] = REG(BP);
  24. dwarf_regs[6] = REG(SI);
  25. dwarf_regs[7] = REG(DI);
  26. dwarf_regs[8] = REG(IP);
  27. nregs = 9;
  28. } else {
  29. dwarf_regs[0] = REG(AX);
  30. dwarf_regs[1] = REG(DX);
  31. dwarf_regs[2] = REG(CX);
  32. dwarf_regs[3] = REG(BX);
  33. dwarf_regs[4] = REG(SI);
  34. dwarf_regs[5] = REG(DI);
  35. dwarf_regs[6] = REG(BP);
  36. dwarf_regs[7] = REG(SP);
  37. dwarf_regs[8] = REG(R8);
  38. dwarf_regs[9] = REG(R9);
  39. dwarf_regs[10] = REG(R10);
  40. dwarf_regs[11] = REG(R11);
  41. dwarf_regs[12] = REG(R12);
  42. dwarf_regs[13] = REG(R13);
  43. dwarf_regs[14] = REG(R14);
  44. dwarf_regs[15] = REG(R15);
  45. dwarf_regs[16] = REG(IP);
  46. nregs = 17;
  47. }
  48. return dwfl_thread_state_registers(thread, 0, nregs, dwarf_regs);
  49. }