gdb/gdbserver/linux-ppc-low.c - gdb

Global variables defined

Data types defined

Functions defined

Macros defined

Source code

  1. /* GNU/Linux/PowerPC specific low level interface, for the remote server for
  2.    GDB.
  3.    Copyright (C) 1995-2015 Free Software Foundation, Inc.

  4.    This file is part of GDB.

  5.    This program is free software; you can redistribute it and/or modify
  6.    it under the terms of the GNU General Public License as published by
  7.    the Free Software Foundation; either version 3 of the License, or
  8.    (at your option) any later version.

  9.    This program is distributed in the hope that it will be useful,
  10.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  11.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12.    GNU General Public License for more details.

  13.    You should have received a copy of the GNU General Public License
  14.    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */

  15. #include "server.h"
  16. #include "linux-low.h"

  17. #include <elf.h>
  18. #include <asm/ptrace.h>

  19. /* These are in <asm/cputable.h> in current kernels.  */
  20. #define PPC_FEATURE_HAS_VSX                0x00000080
  21. #define PPC_FEATURE_HAS_ALTIVEC         0x10000000
  22. #define PPC_FEATURE_HAS_SPE             0x00800000
  23. #define PPC_FEATURE_CELL                0x00010000
  24. #define PPC_FEATURE_HAS_DFP             0x00000400

  25. static unsigned long ppc_hwcap;


  26. /* Defined in auto-generated file powerpc-32l.c.  */
  27. void init_registers_powerpc_32l (void);
  28. extern const struct target_desc *tdesc_powerpc_32l;

  29. /* Defined in auto-generated file powerpc-altivec32l.c.  */
  30. void init_registers_powerpc_altivec32l (void);
  31. extern const struct target_desc *tdesc_powerpc_altivec32l;

  32. /* Defined in auto-generated file powerpc-cell32l.c.  */
  33. void init_registers_powerpc_cell32l (void);
  34. extern const struct target_desc *tdesc_powerpc_cell32l;

  35. /* Defined in auto-generated file powerpc-vsx32l.c.  */
  36. void init_registers_powerpc_vsx32l (void);
  37. extern const struct target_desc *tdesc_powerpc_vsx32l;

  38. /* Defined in auto-generated file powerpc-isa205-32l.c.  */
  39. void init_registers_powerpc_isa205_32l (void);
  40. extern const struct target_desc *tdesc_powerpc_isa205_32l;

  41. /* Defined in auto-generated file powerpc-isa205-altivec32l.c.  */
  42. void init_registers_powerpc_isa205_altivec32l (void);
  43. extern const struct target_desc *tdesc_powerpc_isa205_altivec32l;

  44. /* Defined in auto-generated file powerpc-isa205-vsx32l.c.  */
  45. void init_registers_powerpc_isa205_vsx32l (void);
  46. extern const struct target_desc *tdesc_powerpc_isa205_vsx32l;

  47. /* Defined in auto-generated file powerpc-e500l.c.  */
  48. void init_registers_powerpc_e500l (void);
  49. extern const struct target_desc *tdesc_powerpc_e500l;

  50. /* Defined in auto-generated file powerpc-64l.c.  */
  51. void init_registers_powerpc_64l (void);
  52. extern const struct target_desc *tdesc_powerpc_64l;

  53. /* Defined in auto-generated file powerpc-altivec64l.c.  */
  54. void init_registers_powerpc_altivec64l (void);
  55. extern const struct target_desc *tdesc_powerpc_altivec64l;

  56. /* Defined in auto-generated file powerpc-cell64l.c.  */
  57. void init_registers_powerpc_cell64l (void);
  58. extern const struct target_desc *tdesc_powerpc_cell64l;

  59. /* Defined in auto-generated file powerpc-vsx64l.c.  */
  60. void init_registers_powerpc_vsx64l (void);
  61. extern const struct target_desc *tdesc_powerpc_vsx64l;

  62. /* Defined in auto-generated file powerpc-isa205-64l.c.  */
  63. void init_registers_powerpc_isa205_64l (void);
  64. extern const struct target_desc *tdesc_powerpc_isa205_64l;

  65. /* Defined in auto-generated file powerpc-isa205-altivec64l.c.  */
  66. void init_registers_powerpc_isa205_altivec64l (void);
  67. extern const struct target_desc *tdesc_powerpc_isa205_altivec64l;

  68. /* Defined in auto-generated file powerpc-isa205-vsx64l.c.  */
  69. void init_registers_powerpc_isa205_vsx64l (void);
  70. extern const struct target_desc *tdesc_powerpc_isa205_vsx64l;

  71. #define ppc_num_regs 73

  72. /* This sometimes isn't defined.  */
  73. #ifndef PT_ORIG_R3
  74. #define PT_ORIG_R3 34
  75. #endif
  76. #ifndef PT_TRAP
  77. #define PT_TRAP 40
  78. #endif

  79. #ifdef __powerpc64__
  80. /* We use a constant for FPSCR instead of PT_FPSCR, because
  81.    many shipped PPC64 kernels had the wrong value in ptrace.h.  */
  82. static int ppc_regmap[] =
  83. {PT_R0 * 8,     PT_R1 * 8,     PT_R2 * 8,     PT_R3 * 8,
  84.   PT_R4 * 8,     PT_R5 * 8,     PT_R6 * 8,     PT_R7 * 8,
  85.   PT_R8 * 8,     PT_R9 * 8,     PT_R10 * 8,    PT_R11 * 8,
  86.   PT_R12 * 8,    PT_R13 * 8,    PT_R14 * 8,    PT_R15 * 8,
  87.   PT_R16 * 8,    PT_R17 * 8,    PT_R18 * 8,    PT_R19 * 8,
  88.   PT_R20 * 8,    PT_R21 * 8,    PT_R22 * 8,    PT_R23 * 8,
  89.   PT_R24 * 8,    PT_R25 * 8,    PT_R26 * 8,    PT_R27 * 8,
  90.   PT_R28 * 8,    PT_R29 * 8,    PT_R30 * 8,    PT_R31 * 8,
  91.   PT_FPR0*8,     PT_FPR0*8 + 8, PT_FPR0*8+16,  PT_FPR0*8+24,
  92.   PT_FPR0*8+32,  PT_FPR0*8+40,  PT_FPR0*8+48,  PT_FPR0*8+56,
  93.   PT_FPR0*8+64,  PT_FPR0*8+72,  PT_FPR0*8+80,  PT_FPR0*8+88,
  94.   PT_FPR0*8+96,  PT_FPR0*8+104,  PT_FPR0*8+112,  PT_FPR0*8+120,
  95.   PT_FPR0*8+128, PT_FPR0*8+136,  PT_FPR0*8+144,  PT_FPR0*8+152,
  96.   PT_FPR0*8+160,  PT_FPR0*8+168,  PT_FPR0*8+176,  PT_FPR0*8+184,
  97.   PT_FPR0*8+192,  PT_FPR0*8+200,  PT_FPR0*8+208,  PT_FPR0*8+216,
  98.   PT_FPR0*8+224,  PT_FPR0*8+232,  PT_FPR0*8+240,  PT_FPR0*8+248,
  99.   PT_NIP * 8,    PT_MSR * 8,    PT_CCR * 8,    PT_LNK * 8,
  100.   PT_CTR * 8,    PT_XER * 8,    PT_FPR0*8 + 256,
  101.   PT_ORIG_R3 * 8, PT_TRAP * 8 };
  102. #else
  103. /* Currently, don't check/send MQ.  */
  104. static int ppc_regmap[] =
  105. {PT_R0 * 4,     PT_R1 * 4,     PT_R2 * 4,     PT_R3 * 4,
  106.   PT_R4 * 4,     PT_R5 * 4,     PT_R6 * 4,     PT_R7 * 4,
  107.   PT_R8 * 4,     PT_R9 * 4,     PT_R10 * 4,    PT_R11 * 4,
  108.   PT_R12 * 4,    PT_R13 * 4,    PT_R14 * 4,    PT_R15 * 4,
  109.   PT_R16 * 4,    PT_R17 * 4,    PT_R18 * 4,    PT_R19 * 4,
  110.   PT_R20 * 4,    PT_R21 * 4,    PT_R22 * 4,    PT_R23 * 4,
  111.   PT_R24 * 4,    PT_R25 * 4,    PT_R26 * 4,    PT_R27 * 4,
  112.   PT_R28 * 4,    PT_R29 * 4,    PT_R30 * 4,    PT_R31 * 4,
  113.   PT_FPR0*4,     PT_FPR0*4 + 8, PT_FPR0*4+16,  PT_FPR0*4+24,
  114.   PT_FPR0*4+32,  PT_FPR0*4+40,  PT_FPR0*4+48,  PT_FPR0*4+56,
  115.   PT_FPR0*4+64,  PT_FPR0*4+72,  PT_FPR0*4+80,  PT_FPR0*4+88,
  116.   PT_FPR0*4+96,  PT_FPR0*4+104,  PT_FPR0*4+112,  PT_FPR0*4+120,
  117.   PT_FPR0*4+128, PT_FPR0*4+136,  PT_FPR0*4+144,  PT_FPR0*4+152,
  118.   PT_FPR0*4+160,  PT_FPR0*4+168,  PT_FPR0*4+176,  PT_FPR0*4+184,
  119.   PT_FPR0*4+192,  PT_FPR0*4+200,  PT_FPR0*4+208,  PT_FPR0*4+216,
  120.   PT_FPR0*4+224,  PT_FPR0*4+232,  PT_FPR0*4+240,  PT_FPR0*4+248,
  121.   PT_NIP * 4,    PT_MSR * 4,    PT_CCR * 4,    PT_LNK * 4,
  122.   PT_CTR * 4,    PT_XER * 4,    PT_FPSCR * 4,
  123.   PT_ORIG_R3 * 4, PT_TRAP * 4
  124. };

  125. static int ppc_regmap_e500[] =
  126. {PT_R0 * 4,     PT_R1 * 4,     PT_R2 * 4,     PT_R3 * 4,
  127.   PT_R4 * 4,     PT_R5 * 4,     PT_R6 * 4,     PT_R7 * 4,
  128.   PT_R8 * 4,     PT_R9 * 4,     PT_R10 * 4,    PT_R11 * 4,
  129.   PT_R12 * 4,    PT_R13 * 4,    PT_R14 * 4,    PT_R15 * 4,
  130.   PT_R16 * 4,    PT_R17 * 4,    PT_R18 * 4,    PT_R19 * 4,
  131.   PT_R20 * 4,    PT_R21 * 4,    PT_R22 * 4,    PT_R23 * 4,
  132.   PT_R24 * 4,    PT_R25 * 4,    PT_R26 * 4,    PT_R27 * 4,
  133.   PT_R28 * 4,    PT_R29 * 4,    PT_R30 * 4,    PT_R31 * 4,
  134.   -1,            -1,            -1,            -1,
  135.   -1,            -1,            -1,            -1,
  136.   -1,            -1,            -1,            -1,
  137.   -1,            -1,            -1,            -1,
  138.   -1,            -1,            -1,            -1,
  139.   -1,            -1,            -1,            -1,
  140.   -1,            -1,            -1,            -1,
  141.   -1,            -1,            -1,            -1,
  142.   PT_NIP * 4,    PT_MSR * 4,    PT_CCR * 4,    PT_LNK * 4,
  143.   PT_CTR * 4,    PT_XER * 4,    -1,
  144.   PT_ORIG_R3 * 4, PT_TRAP * 4
  145. };
  146. #endif

  147. static int
  148. ppc_cannot_store_register (int regno)
  149. {
  150.   const struct target_desc *tdesc = current_process ()->tdesc;

  151. #ifndef __powerpc64__
  152.   /* Some kernels do not allow us to store fpscr.  */
  153.   if (!(ppc_hwcap & PPC_FEATURE_HAS_SPE)
  154.       && regno == find_regno (tdesc, "fpscr"))
  155.     return 2;
  156. #endif

  157.   /* Some kernels do not allow us to store orig_r3 or trap.  */
  158.   if (regno == find_regno (tdesc, "orig_r3")
  159.       || regno == find_regno (tdesc, "trap"))
  160.     return 2;

  161.   return 0;
  162. }

  163. static int
  164. ppc_cannot_fetch_register (int regno)
  165. {
  166.   return 0;
  167. }

  168. static void
  169. ppc_collect_ptrace_register (struct regcache *regcache, int regno, char *buf)
  170. {
  171.   memset (buf, 0, sizeof (long));

  172.   if (__BYTE_ORDER == __LITTLE_ENDIAN)
  173.     {
  174.       /* Little-endian values always sit at the left end of the buffer.  */
  175.       collect_register (regcache, regno, buf);
  176.     }
  177.   else if (__BYTE_ORDER == __BIG_ENDIAN)
  178.     {
  179.       /* Big-endian values sit at the right end of the buffer.  In case of
  180.          registers whose sizes are smaller than sizeof (long), we must use a
  181.          padding to access them correctly.  */
  182.       int size = register_size (regcache->tdesc, regno);

  183.       if (size < sizeof (long))
  184.         collect_register (regcache, regno, buf + sizeof (long) - size);
  185.       else
  186.         collect_register (regcache, regno, buf);
  187.     }
  188.   else
  189.     perror_with_name ("Unexpected byte order");
  190. }

  191. static void
  192. ppc_supply_ptrace_register (struct regcache *regcache,
  193.                             int regno, const char *buf)
  194. {
  195.   if (__BYTE_ORDER == __LITTLE_ENDIAN)
  196.     {
  197.       /* Little-endian values always sit at the left end of the buffer.  */
  198.       supply_register (regcache, regno, buf);
  199.     }
  200.   else if (__BYTE_ORDER == __BIG_ENDIAN)
  201.     {
  202.       /* Big-endian values sit at the right end of the buffer.  In case of
  203.          registers whose sizes are smaller than sizeof (long), we must use a
  204.          padding to access them correctly.  */
  205.       int size = register_size (regcache->tdesc, regno);

  206.       if (size < sizeof (long))
  207.         supply_register (regcache, regno, buf + sizeof (long) - size);
  208.       else
  209.         supply_register (regcache, regno, buf);
  210.     }
  211.   else
  212.     perror_with_name ("Unexpected byte order");
  213. }


  214. #define INSTR_SC        0x44000002
  215. #define NR_spu_run      0x0116

  216. /* If the PPU thread is currently stopped on a spu_run system call,
  217.    return to FD and ADDR the file handle and NPC parameter address
  218.    used with the system call.  Return non-zero if successful.  */
  219. static int
  220. parse_spufs_run (struct regcache *regcache, int *fd, CORE_ADDR *addr)
  221. {
  222.   CORE_ADDR curr_pc;
  223.   int curr_insn;
  224.   int curr_r0;

  225.   if (register_size (regcache->tdesc, 0) == 4)
  226.     {
  227.       unsigned int pc, r0, r3, r4;
  228.       collect_register_by_name (regcache, "pc", &pc);
  229.       collect_register_by_name (regcache, "r0", &r0);
  230.       collect_register_by_name (regcache, "orig_r3", &r3);
  231.       collect_register_by_name (regcache, "r4", &r4);
  232.       curr_pc = (CORE_ADDR) pc;
  233.       curr_r0 = (int) r0;
  234.       *fd = (int) r3;
  235.       *addr = (CORE_ADDR) r4;
  236.     }
  237.   else
  238.     {
  239.       unsigned long pc, r0, r3, r4;
  240.       collect_register_by_name (regcache, "pc", &pc);
  241.       collect_register_by_name (regcache, "r0", &r0);
  242.       collect_register_by_name (regcache, "orig_r3", &r3);
  243.       collect_register_by_name (regcache, "r4", &r4);
  244.       curr_pc = (CORE_ADDR) pc;
  245.       curr_r0 = (int) r0;
  246.       *fd = (int) r3;
  247.       *addr = (CORE_ADDR) r4;
  248.     }

  249.   /* Fetch instruction preceding current NIP.  */
  250.   if ((*the_target->read_memory) (curr_pc - 4,
  251.                                   (unsigned char *) &curr_insn, 4) != 0)
  252.     return 0;
  253.   /* It should be a "sc" instruction.  */
  254.   if (curr_insn != INSTR_SC)
  255.     return 0;
  256.   /* System call number should be NR_spu_run.  */
  257.   if (curr_r0 != NR_spu_run)
  258.     return 0;

  259.   return 1;
  260. }

  261. static CORE_ADDR
  262. ppc_get_pc (struct regcache *regcache)
  263. {
  264.   CORE_ADDR addr;
  265.   int fd;

  266.   if (parse_spufs_run (regcache, &fd, &addr))
  267.     {
  268.       unsigned int pc;
  269.       (*the_target->read_memory) (addr, (unsigned char *) &pc, 4);
  270.       return ((CORE_ADDR)1 << 63)
  271.         | ((CORE_ADDR)fd << 32) | (CORE_ADDR) (pc - 4);
  272.     }
  273.   else if (register_size (regcache->tdesc, 0) == 4)
  274.     {
  275.       unsigned int pc;
  276.       collect_register_by_name (regcache, "pc", &pc);
  277.       return (CORE_ADDR) pc;
  278.     }
  279.   else
  280.     {
  281.       unsigned long pc;
  282.       collect_register_by_name (regcache, "pc", &pc);
  283.       return (CORE_ADDR) pc;
  284.     }
  285. }

  286. static void
  287. ppc_set_pc (struct regcache *regcache, CORE_ADDR pc)
  288. {
  289.   CORE_ADDR addr;
  290.   int fd;

  291.   if (parse_spufs_run (regcache, &fd, &addr))
  292.     {
  293.       unsigned int newpc = pc;
  294.       (*the_target->write_memory) (addr, (unsigned char *) &newpc, 4);
  295.     }
  296.   else if (register_size (regcache->tdesc, 0) == 4)
  297.     {
  298.       unsigned int newpc = pc;
  299.       supply_register_by_name (regcache, "pc", &newpc);
  300.     }
  301.   else
  302.     {
  303.       unsigned long newpc = pc;
  304.       supply_register_by_name (regcache, "pc", &newpc);
  305.     }
  306. }


  307. static int
  308. ppc_get_hwcap (unsigned long *valp)
  309. {
  310.   const struct target_desc *tdesc = current_process ()->tdesc;
  311.   int wordsize = register_size (tdesc, 0);
  312.   unsigned char *data = alloca (2 * wordsize);
  313.   int offset = 0;

  314.   while ((*the_target->read_auxv) (offset, data, 2 * wordsize) == 2 * wordsize)
  315.     {
  316.       if (wordsize == 4)
  317.         {
  318.           unsigned int *data_p = (unsigned int *)data;
  319.           if (data_p[0] == AT_HWCAP)
  320.             {
  321.               *valp = data_p[1];
  322.               return 1;
  323.             }
  324.         }
  325.       else
  326.         {
  327.           unsigned long *data_p = (unsigned long *)data;
  328.           if (data_p[0] == AT_HWCAP)
  329.             {
  330.               *valp = data_p[1];
  331.               return 1;
  332.             }
  333.         }

  334.       offset += 2 * wordsize;
  335.     }

  336.   *valp = 0;
  337.   return 0;
  338. }

  339. /* Forward declaration.  */
  340. static struct usrregs_info ppc_usrregs_info;
  341. #ifndef __powerpc64__
  342. static int ppc_regmap_adjusted;
  343. #endif

  344. static void
  345. ppc_arch_setup (void)
  346. {
  347.   const struct target_desc *tdesc;
  348. #ifdef __powerpc64__
  349.   long msr;
  350.   struct regcache *regcache;

  351.   /* On a 64-bit host, assume 64-bit inferior process with no
  352.      AltiVec registers.  Reset ppc_hwcap to ensure that the
  353.      collect_register call below does not fail.  */
  354.   tdesc = tdesc_powerpc_64l;
  355.   current_process ()->tdesc = tdesc;
  356.   ppc_hwcap = 0;

  357.   /* Only if the high bit of the MSR is set, we actually have
  358.      a 64-bit inferior.  */
  359.   regcache = new_register_cache (tdesc);
  360.   fetch_inferior_registers (regcache, find_regno (tdesc, "msr"));
  361.   collect_register_by_name (regcache, "msr", &msr);
  362.   free_register_cache (regcache);
  363.   if (msr < 0)
  364.     {
  365.       ppc_get_hwcap (&ppc_hwcap);
  366.       if (ppc_hwcap & PPC_FEATURE_CELL)
  367.         tdesc = tdesc_powerpc_cell64l;
  368.       else if (ppc_hwcap & PPC_FEATURE_HAS_VSX)
  369.         {
  370.           /* Power ISA 2.05 (implemented by Power 6 and newer processors)
  371.              increases the FPSCR from 32 bits to 64 bits. Even though Power 7
  372.              supports this ISA version, it doesn't have PPC_FEATURE_ARCH_2_05
  373.              set, only PPC_FEATURE_ARCH_2_06.  Since for now the only bits
  374.              used in the higher half of the register are for Decimal Floating
  375.              Point, we check if that feature is available to decide the size
  376.              of the FPSCR.  */
  377.           if (ppc_hwcap & PPC_FEATURE_HAS_DFP)
  378.             tdesc = tdesc_powerpc_isa205_vsx64l;
  379.           else
  380.             tdesc = tdesc_powerpc_vsx64l;
  381.         }
  382.       else if (ppc_hwcap & PPC_FEATURE_HAS_ALTIVEC)
  383.         {
  384.           if (ppc_hwcap & PPC_FEATURE_HAS_DFP)
  385.             tdesc = tdesc_powerpc_isa205_altivec64l;
  386.           else
  387.             tdesc = tdesc_powerpc_altivec64l;
  388.         }

  389.       current_process ()->tdesc = tdesc;
  390.       return;
  391.     }
  392. #endif

  393.   /* OK, we have a 32-bit inferior.  */
  394.   tdesc = tdesc_powerpc_32l;
  395.   current_process ()->tdesc = tdesc;

  396.   ppc_get_hwcap (&ppc_hwcap);
  397.   if (ppc_hwcap & PPC_FEATURE_CELL)
  398.     tdesc = tdesc_powerpc_cell32l;
  399.   else if (ppc_hwcap & PPC_FEATURE_HAS_VSX)
  400.     {
  401.       if (ppc_hwcap & PPC_FEATURE_HAS_DFP)
  402.         tdesc = tdesc_powerpc_isa205_vsx32l;
  403.       else
  404.         tdesc = tdesc_powerpc_vsx32l;
  405.     }
  406.   else if (ppc_hwcap & PPC_FEATURE_HAS_ALTIVEC)
  407.     {
  408.       if (ppc_hwcap & PPC_FEATURE_HAS_DFP)
  409.         tdesc = tdesc_powerpc_isa205_altivec32l;
  410.       else
  411.         tdesc = tdesc_powerpc_altivec32l;
  412.     }

  413.   /* On 32-bit machines, check for SPE registers.
  414.      Set the low target's regmap field as appropriately.  */
  415. #ifndef __powerpc64__
  416.   if (ppc_hwcap & PPC_FEATURE_HAS_SPE)
  417.     tdesc = tdesc_powerpc_e500l;

  418.   if (!ppc_regmap_adjusted)
  419.     {
  420.       if (ppc_hwcap & PPC_FEATURE_HAS_SPE)
  421.         ppc_usrregs_info.regmap = ppc_regmap_e500;

  422.       /* If the FPSCR is 64-bit wide, we need to fetch the whole
  423.          64-bit slot and not just its second word.  The PT_FPSCR
  424.          supplied in a 32-bit GDB compilation doesn't reflect
  425.          this.  */
  426.       if (register_size (tdesc, 70) == 8)
  427.         ppc_regmap[70] = (48 + 2*32) * sizeof (long);

  428.       ppc_regmap_adjusted = 1;
  429.    }
  430. #endif
  431.   current_process ()->tdesc = tdesc;
  432. }

  433. /* Correct in either endianness.
  434.    This instruction is "twge r2, r2", which GDB uses as a software
  435.    breakpoint.  */
  436. static const unsigned int ppc_breakpoint = 0x7d821008;
  437. #define ppc_breakpoint_len 4

  438. static int
  439. ppc_breakpoint_at (CORE_ADDR where)
  440. {
  441.   unsigned int insn;

  442.   if (where & ((CORE_ADDR)1 << 63))
  443.     {
  444.       char mem_annex[32];
  445.       sprintf (mem_annex, "%d/mem", (int)((where >> 32) & 0x7fffffff));
  446.       (*the_target->qxfer_spu) (mem_annex, (unsigned char *) &insn,
  447.                                 NULL, where & 0xffffffff, 4);
  448.       if (insn == 0x3fff)
  449.         return 1;
  450.     }
  451.   else
  452.     {
  453.       (*the_target->read_memory) (where, (unsigned char *) &insn, 4);
  454.       if (insn == ppc_breakpoint)
  455.         return 1;
  456.       /* If necessary, recognize more trap instructions here.  GDB only uses
  457.          the one.  */
  458.     }

  459.   return 0;
  460. }

  461. /* Provide only a fill function for the general register setps_lgetregs
  462.    will use this for NPTL support.  */

  463. static void ppc_fill_gregset (struct regcache *regcache, void *buf)
  464. {
  465.   int i;

  466.   for (i = 0; i < 32; i++)
  467.     ppc_collect_ptrace_register (regcache, i, (char *) buf + ppc_regmap[i]);

  468.   for (i = 64; i < 70; i++)
  469.     ppc_collect_ptrace_register (regcache, i, (char *) buf + ppc_regmap[i]);

  470.   for (i = 71; i < 73; i++)
  471.     ppc_collect_ptrace_register (regcache, i, (char *) buf + ppc_regmap[i]);
  472. }

  473. #ifndef PTRACE_GETVSXREGS
  474. #define PTRACE_GETVSXREGS 27
  475. #define PTRACE_SETVSXREGS 28
  476. #endif

  477. #define SIZEOF_VSXREGS 32*8

  478. static void
  479. ppc_fill_vsxregset (struct regcache *regcache, void *buf)
  480. {
  481.   int i, base;
  482.   char *regset = buf;

  483.   if (!(ppc_hwcap & PPC_FEATURE_HAS_VSX))
  484.     return;

  485.   base = find_regno (regcache->tdesc, "vs0h");
  486.   for (i = 0; i < 32; i++)
  487.     collect_register (regcache, base + i, &regset[i * 8]);
  488. }

  489. static void
  490. ppc_store_vsxregset (struct regcache *regcache, const void *buf)
  491. {
  492.   int i, base;
  493.   const char *regset = buf;

  494.   if (!(ppc_hwcap & PPC_FEATURE_HAS_VSX))
  495.     return;

  496.   base = find_regno (regcache->tdesc, "vs0h");
  497.   for (i = 0; i < 32; i++)
  498.     supply_register (regcache, base + i, &regset[i * 8]);
  499. }

  500. #ifndef PTRACE_GETVRREGS
  501. #define PTRACE_GETVRREGS 18
  502. #define PTRACE_SETVRREGS 19
  503. #endif

  504. #define SIZEOF_VRREGS 33*16+4

  505. static void
  506. ppc_fill_vrregset (struct regcache *regcache, void *buf)
  507. {
  508.   int i, base;
  509.   char *regset = buf;

  510.   if (!(ppc_hwcap & PPC_FEATURE_HAS_ALTIVEC))
  511.     return;

  512.   base = find_regno (regcache->tdesc, "vr0");
  513.   for (i = 0; i < 32; i++)
  514.     collect_register (regcache, base + i, &regset[i * 16]);

  515.   collect_register_by_name (regcache, "vscr", &regset[32 * 16 + 12]);
  516.   collect_register_by_name (regcache, "vrsave", &regset[33 * 16]);
  517. }

  518. static void
  519. ppc_store_vrregset (struct regcache *regcache, const void *buf)
  520. {
  521.   int i, base;
  522.   const char *regset = buf;

  523.   if (!(ppc_hwcap & PPC_FEATURE_HAS_ALTIVEC))
  524.     return;

  525.   base = find_regno (regcache->tdesc, "vr0");
  526.   for (i = 0; i < 32; i++)
  527.     supply_register (regcache, base + i, &regset[i * 16]);

  528.   supply_register_by_name (regcache, "vscr", &regset[32 * 16 + 12]);
  529.   supply_register_by_name (regcache, "vrsave", &regset[33 * 16]);
  530. }

  531. #ifndef PTRACE_GETEVRREGS
  532. #define PTRACE_GETEVRREGS        20
  533. #define PTRACE_SETEVRREGS        21
  534. #endif

  535. struct gdb_evrregset_t
  536. {
  537.   unsigned long evr[32];
  538.   unsigned long long acc;
  539.   unsigned long spefscr;
  540. };

  541. static void
  542. ppc_fill_evrregset (struct regcache *regcache, void *buf)
  543. {
  544.   int i, ev0;
  545.   struct gdb_evrregset_t *regset = buf;

  546.   if (!(ppc_hwcap & PPC_FEATURE_HAS_SPE))
  547.     return;

  548.   ev0 = find_regno (regcache->tdesc, "ev0h");
  549.   for (i = 0; i < 32; i++)
  550.     collect_register (regcache, ev0 + i, &regset->evr[i]);

  551.   collect_register_by_name (regcache, "acc", &regset->acc);
  552.   collect_register_by_name (regcache, "spefscr", &regset->spefscr);
  553. }

  554. static void
  555. ppc_store_evrregset (struct regcache *regcache, const void *buf)
  556. {
  557.   int i, ev0;
  558.   const struct gdb_evrregset_t *regset = buf;

  559.   if (!(ppc_hwcap & PPC_FEATURE_HAS_SPE))
  560.     return;

  561.   ev0 = find_regno (regcache->tdesc, "ev0h");
  562.   for (i = 0; i < 32; i++)
  563.     supply_register (regcache, ev0 + i, &regset->evr[i]);

  564.   supply_register_by_name (regcache, "acc", &regset->acc);
  565.   supply_register_by_name (regcache, "spefscr", &regset->spefscr);
  566. }

  567. static struct regset_info ppc_regsets[] = {
  568.   /* List the extra register sets before GENERAL_REGS.  That way we will
  569.      fetch them every time, but still fall back to PTRACE_PEEKUSER for the
  570.      general registers.  Some kernels support these, but not the newer
  571.      PPC_PTRACE_GETREGS.  */
  572.   { PTRACE_GETVSXREGS, PTRACE_SETVSXREGS, 0, SIZEOF_VSXREGS, EXTENDED_REGS,
  573.   ppc_fill_vsxregset, ppc_store_vsxregset },
  574.   { PTRACE_GETVRREGS, PTRACE_SETVRREGS, 0, SIZEOF_VRREGS, EXTENDED_REGS,
  575.     ppc_fill_vrregset, ppc_store_vrregset },
  576.   { PTRACE_GETEVRREGS, PTRACE_SETEVRREGS, 0, 32 * 4 + 8 + 4, EXTENDED_REGS,
  577.     ppc_fill_evrregset, ppc_store_evrregset },
  578.   { 0, 0, 0, 0, GENERAL_REGS, ppc_fill_gregset, NULL },
  579.   { 0, 0, 0, -1, -1, NULL, NULL }
  580. };

  581. static struct usrregs_info ppc_usrregs_info =
  582.   {
  583.     ppc_num_regs,
  584.     ppc_regmap,
  585.   };

  586. static struct regsets_info ppc_regsets_info =
  587.   {
  588.     ppc_regsets, /* regsets */
  589.     0, /* num_regsets */
  590.     NULL, /* disabled_regsets */
  591.   };

  592. static struct regs_info regs_info =
  593.   {
  594.     NULL, /* regset_bitmap */
  595.     &ppc_usrregs_info,
  596.     &ppc_regsets_info
  597.   };

  598. static const struct regs_info *
  599. ppc_regs_info (void)
  600. {
  601.   return &regs_info;
  602. }

  603. struct linux_target_ops the_low_target = {
  604.   ppc_arch_setup,
  605.   ppc_regs_info,
  606.   ppc_cannot_fetch_register,
  607.   ppc_cannot_store_register,
  608.   NULL, /* fetch_register */
  609.   ppc_get_pc,
  610.   ppc_set_pc,
  611.   (const unsigned char *) &ppc_breakpoint,
  612.   ppc_breakpoint_len,
  613.   NULL,
  614.   0,
  615.   ppc_breakpoint_at,
  616.   NULL, /* supports_z_point_type */
  617.   NULL,
  618.   NULL,
  619.   NULL,
  620.   NULL,
  621.   ppc_collect_ptrace_register,
  622.   ppc_supply_ptrace_register,
  623. };

  624. void
  625. initialize_low_arch (void)
  626. {
  627.   /* Initialize the Linux target descriptions.  */

  628.   init_registers_powerpc_32l ();
  629.   init_registers_powerpc_altivec32l ();
  630.   init_registers_powerpc_cell32l ();
  631.   init_registers_powerpc_vsx32l ();
  632.   init_registers_powerpc_isa205_32l ();
  633.   init_registers_powerpc_isa205_altivec32l ();
  634.   init_registers_powerpc_isa205_vsx32l ();
  635.   init_registers_powerpc_e500l ();
  636.   init_registers_powerpc_64l ();
  637.   init_registers_powerpc_altivec64l ();
  638.   init_registers_powerpc_cell64l ();
  639.   init_registers_powerpc_vsx64l ();
  640.   init_registers_powerpc_isa205_64l ();
  641.   init_registers_powerpc_isa205_altivec64l ();
  642.   init_registers_powerpc_isa205_vsx64l ();

  643.   initialize_regsets_info (&ppc_regsets_info);
  644. }