]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blob - gdb/ppc-linux-nat.c
* config/rs6000/tm-rs6000.h (FP0_REGNUM): Document that this
[thirdparty/binutils-gdb.git] / gdb / ppc-linux-nat.c
1 /* PPC GNU/Linux native support.
2
3 Copyright 1988, 1989, 1991, 1992, 1994, 1996, 2000, 2001, 2002,
4 2003 Free Software Foundation, Inc.
5
6 This file is part of GDB.
7
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
12
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place - Suite 330,
21 Boston, MA 02111-1307, USA. */
22
23 #include "defs.h"
24 #include "gdb_string.h"
25 #include "frame.h"
26 #include "inferior.h"
27 #include "gdbcore.h"
28 #include "regcache.h"
29
30 #include <sys/types.h>
31 #include <sys/param.h>
32 #include <signal.h>
33 #include <sys/user.h>
34 #include <sys/ioctl.h>
35 #include "gdb_wait.h"
36 #include <fcntl.h>
37 #include <sys/procfs.h>
38 #include <sys/ptrace.h>
39
40 /* Prototypes for supply_gregset etc. */
41 #include "gregset.h"
42 #include "ppc-tdep.h"
43
44 #ifndef PT_READ_U
45 #define PT_READ_U PTRACE_PEEKUSR
46 #endif
47 #ifndef PT_WRITE_U
48 #define PT_WRITE_U PTRACE_POKEUSR
49 #endif
50
51 /* Default the type of the ptrace transfer to int. */
52 #ifndef PTRACE_XFER_TYPE
53 #define PTRACE_XFER_TYPE int
54 #endif
55
56 /* Glibc's headers don't define PTRACE_GETVRREGS so we cannot use a
57 configure time check. Some older glibc's (for instance 2.2.1)
58 don't have a specific powerpc version of ptrace.h, and fall back on
59 a generic one. In such cases, sys/ptrace.h defines
60 PTRACE_GETFPXREGS and PTRACE_SETFPXREGS to the same numbers that
61 ppc kernel's asm/ptrace.h defines PTRACE_GETVRREGS and
62 PTRACE_SETVRREGS to be. This also makes a configury check pretty
63 much useless. */
64
65 /* These definitions should really come from the glibc header files,
66 but Glibc doesn't know about the vrregs yet. */
67 #ifndef PTRACE_GETVRREGS
68 #define PTRACE_GETVRREGS 18
69 #define PTRACE_SETVRREGS 19
70 #endif
71
72 /* This oddity is because the Linux kernel defines elf_vrregset_t as
73 an array of 33 16 bytes long elements. I.e. it leaves out vrsave.
74 However the PTRACE_GETVRREGS and PTRACE_SETVRREGS requests return
75 the vrsave as an extra 4 bytes at the end. I opted for creating a
76 flat array of chars, so that it is easier to manipulate for gdb.
77
78 There are 32 vector registers 16 bytes longs, plus a VSCR register
79 which is only 4 bytes long, but is fetched as a 16 bytes
80 quantity. Up to here we have the elf_vrregset_t structure.
81 Appended to this there is space for the VRSAVE register: 4 bytes.
82 Even though this vrsave register is not included in the regset
83 typedef, it is handled by the ptrace requests.
84
85 Note that GNU/Linux doesn't support little endian PPC hardware,
86 therefore the offset at which the real value of the VSCR register
87 is located will be always 12 bytes.
88
89 The layout is like this (where x is the actual value of the vscr reg): */
90
91 /* *INDENT-OFF* */
92 /*
93 |.|.|.|.|.....|.|.|.|.||.|.|.|x||.|
94 <-------> <-------><-------><->
95 VR0 VR31 VSCR VRSAVE
96 */
97 /* *INDENT-ON* */
98
99 #define SIZEOF_VRREGS 33*16+4
100
101 typedef char gdb_vrregset_t[SIZEOF_VRREGS];
102
103 /* For runtime check of ptrace support for VRREGS. */
104 int have_ptrace_getvrregs = 1;
105
106 int
107 kernel_u_size (void)
108 {
109 return (sizeof (struct user));
110 }
111
112 /* *INDENT-OFF* */
113 /* registers layout, as presented by the ptrace interface:
114 PT_R0, PT_R1, PT_R2, PT_R3, PT_R4, PT_R5, PT_R6, PT_R7,
115 PT_R8, PT_R9, PT_R10, PT_R11, PT_R12, PT_R13, PT_R14, PT_R15,
116 PT_R16, PT_R17, PT_R18, PT_R19, PT_R20, PT_R21, PT_R22, PT_R23,
117 PT_R24, PT_R25, PT_R26, PT_R27, PT_R28, PT_R29, PT_R30, PT_R31,
118 PT_FPR0, PT_FPR0 + 2, PT_FPR0 + 4, PT_FPR0 + 6, PT_FPR0 + 8, PT_FPR0 + 10, PT_FPR0 + 12, PT_FPR0 + 14,
119 PT_FPR0 + 16, PT_FPR0 + 18, PT_FPR0 + 20, PT_FPR0 + 22, PT_FPR0 + 24, PT_FPR0 + 26, PT_FPR0 + 28, PT_FPR0 + 30,
120 PT_FPR0 + 32, PT_FPR0 + 34, PT_FPR0 + 36, PT_FPR0 + 38, PT_FPR0 + 40, PT_FPR0 + 42, PT_FPR0 + 44, PT_FPR0 + 46,
121 PT_FPR0 + 48, PT_FPR0 + 50, PT_FPR0 + 52, PT_FPR0 + 54, PT_FPR0 + 56, PT_FPR0 + 58, PT_FPR0 + 60, PT_FPR0 + 62,
122 PT_NIP, PT_MSR, PT_CCR, PT_LNK, PT_CTR, PT_XER, PT_MQ */
123 /* *INDENT_ON * */
124
125 static int
126 ppc_register_u_addr (int regno)
127 {
128 int u_addr = -1;
129 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
130 /* NOTE: cagney/2003-11-25: This is the word size used by the ptrace
131 interface, and not the wordsize of the program's ABI. */
132 int wordsize = sizeof (PTRACE_XFER_TYPE);
133
134 /* General purpose registers occupy 1 slot each in the buffer */
135 if (regno >= tdep->ppc_gp0_regnum
136 && regno < tdep->ppc_gp0_regnum + ppc_num_gprs)
137 u_addr = ((regno - tdep->ppc_gp0_regnum + PT_R0) * wordsize);
138
139 /* Floating point regs: eight bytes each in both 32- and 64-bit
140 ptrace interfaces. Thus, two slots each in 32-bit interface, one
141 slot each in 64-bit interface. */
142 if (regno >= tdep->ppc_fp0_regnum
143 && regno < tdep->ppc_fp0_regnum + ppc_num_fprs)
144 u_addr = (PT_FPR0 * wordsize) + ((regno - tdep->ppc_fp0_regnum) * 8);
145
146 /* UISA special purpose registers: 1 slot each */
147 if (regno == PC_REGNUM)
148 u_addr = PT_NIP * wordsize;
149 if (regno == tdep->ppc_lr_regnum)
150 u_addr = PT_LNK * wordsize;
151 if (regno == tdep->ppc_cr_regnum)
152 u_addr = PT_CCR * wordsize;
153 if (regno == tdep->ppc_xer_regnum)
154 u_addr = PT_XER * wordsize;
155 if (regno == tdep->ppc_ctr_regnum)
156 u_addr = PT_CTR * wordsize;
157 #ifdef PT_MQ
158 if (regno == tdep->ppc_mq_regnum)
159 u_addr = PT_MQ * wordsize;
160 #endif
161 if (regno == tdep->ppc_ps_regnum)
162 u_addr = PT_MSR * wordsize;
163 if (regno == tdep->ppc_fpscr_regnum)
164 u_addr = PT_FPSCR * wordsize;
165
166 return u_addr;
167 }
168
169 /* The Linux kernel ptrace interface for AltiVec registers uses the
170 registers set mechanism, as opposed to the interface for all the
171 other registers, that stores/fetches each register individually. */
172 static void
173 fetch_altivec_register (int tid, int regno)
174 {
175 int ret;
176 int offset = 0;
177 gdb_vrregset_t regs;
178 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
179 int vrregsize = DEPRECATED_REGISTER_RAW_SIZE (tdep->ppc_vr0_regnum);
180
181 ret = ptrace (PTRACE_GETVRREGS, tid, 0, &regs);
182 if (ret < 0)
183 {
184 if (errno == EIO)
185 {
186 have_ptrace_getvrregs = 0;
187 return;
188 }
189 perror_with_name ("Unable to fetch AltiVec register");
190 }
191
192 /* VSCR is fetched as a 16 bytes quantity, but it is really 4 bytes
193 long on the hardware. We deal only with the lower 4 bytes of the
194 vector. VRSAVE is at the end of the array in a 4 bytes slot, so
195 there is no need to define an offset for it. */
196 if (regno == (tdep->ppc_vrsave_regnum - 1))
197 offset = vrregsize - DEPRECATED_REGISTER_RAW_SIZE (tdep->ppc_vrsave_regnum);
198
199 supply_register (regno,
200 regs + (regno - tdep->ppc_vr0_regnum) * vrregsize + offset);
201 }
202
203 static void
204 fetch_register (int tid, int regno)
205 {
206 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
207 /* This isn't really an address. But ptrace thinks of it as one. */
208 char mess[128]; /* For messages */
209 int i;
210 unsigned int offset; /* Offset of registers within the u area. */
211 char buf[MAX_REGISTER_SIZE];
212 CORE_ADDR regaddr = ppc_register_u_addr (regno);
213
214 if (altivec_register_p (regno))
215 {
216 /* If this is the first time through, or if it is not the first
217 time through, and we have comfirmed that there is kernel
218 support for such a ptrace request, then go and fetch the
219 register. */
220 if (have_ptrace_getvrregs)
221 {
222 fetch_altivec_register (tid, regno);
223 return;
224 }
225 /* If we have discovered that there is no ptrace support for
226 AltiVec registers, fall through and return zeroes, because
227 regaddr will be -1 in this case. */
228 }
229
230 if (regaddr == -1)
231 {
232 memset (buf, '\0', DEPRECATED_REGISTER_RAW_SIZE (regno)); /* Supply zeroes */
233 supply_register (regno, buf);
234 return;
235 }
236
237 /* Read the raw register using PTRACE_XFER_TYPE sized chunks. On a
238 32-bit platform, 64-bit floating-point registers will require two
239 transfers. */
240 for (i = 0; i < DEPRECATED_REGISTER_RAW_SIZE (regno); i += sizeof (PTRACE_XFER_TYPE))
241 {
242 errno = 0;
243 *(PTRACE_XFER_TYPE *) & buf[i] = ptrace (PT_READ_U, tid,
244 (PTRACE_ARG3_TYPE) regaddr, 0);
245 regaddr += sizeof (PTRACE_XFER_TYPE);
246 if (errno != 0)
247 {
248 sprintf (mess, "reading register %s (#%d)",
249 REGISTER_NAME (regno), regno);
250 perror_with_name (mess);
251 }
252 }
253
254 /* Now supply the register. Be careful to map between ptrace's and
255 the current_regcache's idea of the current wordsize. */
256 if ((regno >= tdep->ppc_fp0_regnum
257 && regno < tdep->ppc_fp0_regnum + ppc_num_fprs)
258 || gdbarch_byte_order (current_gdbarch) == BFD_ENDIAN_LITTLE)
259 /* FPs are always 64 bits. Little endian values are always found
260 at the left-hand end of the register. */
261 regcache_raw_supply (current_regcache, regno, buf);
262 else
263 /* Big endian register, need to fetch the right-hand end. */
264 regcache_raw_supply (current_regcache, regno,
265 (buf + sizeof (PTRACE_XFER_TYPE)
266 - register_size (current_gdbarch, regno)));
267 }
268
269 static void
270 supply_vrregset (gdb_vrregset_t *vrregsetp)
271 {
272 int i;
273 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
274 int num_of_vrregs = tdep->ppc_vrsave_regnum - tdep->ppc_vr0_regnum + 1;
275 int vrregsize = DEPRECATED_REGISTER_RAW_SIZE (tdep->ppc_vr0_regnum);
276 int offset = vrregsize - DEPRECATED_REGISTER_RAW_SIZE (tdep->ppc_vrsave_regnum);
277
278 for (i = 0; i < num_of_vrregs; i++)
279 {
280 /* The last 2 registers of this set are only 32 bit long, not
281 128. However an offset is necessary only for VSCR because it
282 occupies a whole vector, while VRSAVE occupies a full 4 bytes
283 slot. */
284 if (i == (num_of_vrregs - 2))
285 supply_register (tdep->ppc_vr0_regnum + i,
286 *vrregsetp + i * vrregsize + offset);
287 else
288 supply_register (tdep->ppc_vr0_regnum + i, *vrregsetp + i * vrregsize);
289 }
290 }
291
292 static void
293 fetch_altivec_registers (int tid)
294 {
295 int ret;
296 gdb_vrregset_t regs;
297
298 ret = ptrace (PTRACE_GETVRREGS, tid, 0, &regs);
299 if (ret < 0)
300 {
301 if (errno == EIO)
302 {
303 have_ptrace_getvrregs = 0;
304 return;
305 }
306 perror_with_name ("Unable to fetch AltiVec registers");
307 }
308 supply_vrregset (&regs);
309 }
310
311 static void
312 fetch_ppc_registers (int tid)
313 {
314 int i;
315 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
316
317 for (i = 0; i <= tdep->ppc_fpscr_regnum; i++)
318 fetch_register (tid, i);
319 if (tdep->ppc_mq_regnum != -1)
320 fetch_register (tid, tdep->ppc_mq_regnum);
321 if (have_ptrace_getvrregs)
322 if (tdep->ppc_vr0_regnum != -1 && tdep->ppc_vrsave_regnum != -1)
323 fetch_altivec_registers (tid);
324 }
325
326 /* Fetch registers from the child process. Fetch all registers if
327 regno == -1, otherwise fetch all general registers or all floating
328 point registers depending upon the value of regno. */
329 void
330 fetch_inferior_registers (int regno)
331 {
332 /* Overload thread id onto process id */
333 int tid = TIDGET (inferior_ptid);
334
335 /* No thread id, just use process id */
336 if (tid == 0)
337 tid = PIDGET (inferior_ptid);
338
339 if (regno == -1)
340 fetch_ppc_registers (tid);
341 else
342 fetch_register (tid, regno);
343 }
344
345 /* Store one register. */
346 static void
347 store_altivec_register (int tid, int regno)
348 {
349 int ret;
350 int offset = 0;
351 gdb_vrregset_t regs;
352 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
353 int vrregsize = DEPRECATED_REGISTER_RAW_SIZE (tdep->ppc_vr0_regnum);
354
355 ret = ptrace (PTRACE_GETVRREGS, tid, 0, &regs);
356 if (ret < 0)
357 {
358 if (errno == EIO)
359 {
360 have_ptrace_getvrregs = 0;
361 return;
362 }
363 perror_with_name ("Unable to fetch AltiVec register");
364 }
365
366 /* VSCR is fetched as a 16 bytes quantity, but it is really 4 bytes
367 long on the hardware. */
368 if (regno == (tdep->ppc_vrsave_regnum - 1))
369 offset = vrregsize - DEPRECATED_REGISTER_RAW_SIZE (tdep->ppc_vrsave_regnum);
370
371 regcache_collect (regno,
372 regs + (regno - tdep->ppc_vr0_regnum) * vrregsize + offset);
373
374 ret = ptrace (PTRACE_SETVRREGS, tid, 0, &regs);
375 if (ret < 0)
376 perror_with_name ("Unable to store AltiVec register");
377 }
378
379 static void
380 store_register (int tid, int regno)
381 {
382 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
383 /* This isn't really an address. But ptrace thinks of it as one. */
384 CORE_ADDR regaddr = ppc_register_u_addr (regno);
385 char mess[128]; /* For messages */
386 int i;
387 unsigned int offset; /* Offset of registers within the u area. */
388 char buf[MAX_REGISTER_SIZE];
389
390 if (altivec_register_p (regno))
391 {
392 store_altivec_register (tid, regno);
393 return;
394 }
395
396 if (regaddr == -1)
397 return;
398
399 /* First collect the register value from the regcache. Be careful
400 to to convert the regcache's wordsize into ptrace's wordsize. */
401 memset (buf, 0, sizeof buf);
402 if ((regno >= tdep->ppc_fp0_regnum
403 && regno < tdep->ppc_fp0_regnum + ppc_num_fprs)
404 || TARGET_BYTE_ORDER == BFD_ENDIAN_LITTLE)
405 /* Floats are always 64-bit. Little endian registers are always
406 at the left-hand end of the register cache. */
407 regcache_raw_collect (current_regcache, regno, buf);
408 else
409 /* Big-endian registers belong at the right-hand end of the
410 buffer. */
411 regcache_raw_collect (current_regcache, regno,
412 (buf + sizeof (PTRACE_XFER_TYPE)
413 - register_size (current_gdbarch, regno)));
414
415 for (i = 0; i < DEPRECATED_REGISTER_RAW_SIZE (regno); i += sizeof (PTRACE_XFER_TYPE))
416 {
417 errno = 0;
418 ptrace (PT_WRITE_U, tid, (PTRACE_ARG3_TYPE) regaddr,
419 *(PTRACE_XFER_TYPE *) & buf[i]);
420 regaddr += sizeof (PTRACE_XFER_TYPE);
421
422 if (errno == EIO
423 && regno == gdbarch_tdep (current_gdbarch)->ppc_fpscr_regnum)
424 {
425 /* Some older kernel versions don't allow fpscr to be written. */
426 continue;
427 }
428
429 if (errno != 0)
430 {
431 sprintf (mess, "writing register %s (#%d)",
432 REGISTER_NAME (regno), regno);
433 perror_with_name (mess);
434 }
435 }
436 }
437
438 static void
439 fill_vrregset (gdb_vrregset_t *vrregsetp)
440 {
441 int i;
442 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
443 int num_of_vrregs = tdep->ppc_vrsave_regnum - tdep->ppc_vr0_regnum + 1;
444 int vrregsize = DEPRECATED_REGISTER_RAW_SIZE (tdep->ppc_vr0_regnum);
445 int offset = vrregsize - DEPRECATED_REGISTER_RAW_SIZE (tdep->ppc_vrsave_regnum);
446
447 for (i = 0; i < num_of_vrregs; i++)
448 {
449 /* The last 2 registers of this set are only 32 bit long, not
450 128, but only VSCR is fetched as a 16 bytes quantity. */
451 if (i == (num_of_vrregs - 2))
452 regcache_collect (tdep->ppc_vr0_regnum + i,
453 *vrregsetp + i * vrregsize + offset);
454 else
455 regcache_collect (tdep->ppc_vr0_regnum + i, *vrregsetp + i * vrregsize);
456 }
457 }
458
459 static void
460 store_altivec_registers (int tid)
461 {
462 int ret;
463 gdb_vrregset_t regs;
464
465 ret = ptrace (PTRACE_GETVRREGS, tid, 0, &regs);
466 if (ret < 0)
467 {
468 if (errno == EIO)
469 {
470 have_ptrace_getvrregs = 0;
471 return;
472 }
473 perror_with_name ("Couldn't get AltiVec registers");
474 }
475
476 fill_vrregset (&regs);
477
478 if (ptrace (PTRACE_SETVRREGS, tid, 0, &regs) < 0)
479 perror_with_name ("Couldn't write AltiVec registers");
480 }
481
482 static void
483 store_ppc_registers (int tid)
484 {
485 int i;
486 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
487
488 for (i = 0; i <= tdep->ppc_fpscr_regnum; i++)
489 store_register (tid, i);
490 if (tdep->ppc_mq_regnum != -1)
491 store_register (tid, tdep->ppc_mq_regnum);
492 if (have_ptrace_getvrregs)
493 if (tdep->ppc_vr0_regnum != -1 && tdep->ppc_vrsave_regnum != -1)
494 store_altivec_registers (tid);
495 }
496
497 void
498 store_inferior_registers (int regno)
499 {
500 /* Overload thread id onto process id */
501 int tid = TIDGET (inferior_ptid);
502
503 /* No thread id, just use process id */
504 if (tid == 0)
505 tid = PIDGET (inferior_ptid);
506
507 if (regno >= 0)
508 store_register (tid, regno);
509 else
510 store_ppc_registers (tid);
511 }
512
513 void
514 supply_gregset (gdb_gregset_t *gregsetp)
515 {
516 /* NOTE: cagney/2003-11-25: This is the word size used by the ptrace
517 interface, and not the wordsize of the program's ABI. */
518 int wordsize = sizeof (PTRACE_XFER_TYPE);
519 ppc_linux_supply_gregset (current_regcache, -1, gregsetp,
520 sizeof (gdb_gregset_t), wordsize);
521 }
522
523 static void
524 right_fill_reg (int regnum, void *reg)
525 {
526 /* NOTE: cagney/2003-11-25: This is the word size used by the ptrace
527 interface, and not the wordsize of the program's ABI. */
528 int wordsize = sizeof (PTRACE_XFER_TYPE);
529 /* Right fill the register. */
530 regcache_raw_collect (current_regcache, regnum,
531 ((bfd_byte *) reg
532 + wordsize
533 - register_size (current_gdbarch, regnum)));
534 }
535
536 void
537 fill_gregset (gdb_gregset_t *gregsetp, int regno)
538 {
539 int regi;
540 elf_greg_t *regp = (elf_greg_t *) gregsetp;
541 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
542 const int elf_ngreg = 48;
543
544
545 /* Start with zeros. */
546 memset (regp, 0, elf_ngreg * sizeof (*regp));
547
548 for (regi = 0; regi < 32; regi++)
549 {
550 if ((regno == -1) || regno == regi)
551 right_fill_reg (regi, (regp + PT_R0 + regi));
552 }
553
554 if ((regno == -1) || regno == PC_REGNUM)
555 right_fill_reg (PC_REGNUM, regp + PT_NIP);
556 if ((regno == -1) || regno == tdep->ppc_lr_regnum)
557 right_fill_reg (tdep->ppc_lr_regnum, regp + PT_LNK);
558 if ((regno == -1) || regno == tdep->ppc_cr_regnum)
559 regcache_collect (tdep->ppc_cr_regnum, regp + PT_CCR);
560 if ((regno == -1) || regno == tdep->ppc_xer_regnum)
561 regcache_collect (tdep->ppc_xer_regnum, regp + PT_XER);
562 if ((regno == -1) || regno == tdep->ppc_ctr_regnum)
563 right_fill_reg (tdep->ppc_ctr_regnum, regp + PT_CTR);
564 #ifdef PT_MQ
565 if (((regno == -1) || regno == tdep->ppc_mq_regnum)
566 && (tdep->ppc_mq_regnum != -1))
567 right_fill_reg (tdep->ppc_mq_regnum, regp + PT_MQ);
568 #endif
569 if ((regno == -1) || regno == tdep->ppc_ps_regnum)
570 right_fill_reg (tdep->ppc_ps_regnum, regp + PT_MSR);
571 }
572
573 void
574 supply_fpregset (gdb_fpregset_t * fpregsetp)
575 {
576 ppc_linux_supply_fpregset (NULL, current_regcache, -1, fpregsetp,
577 sizeof (gdb_fpregset_t));
578 }
579
580 /* Given a pointer to a floating point register set in /proc format
581 (fpregset_t *), update the register specified by REGNO from gdb's
582 idea of the current floating point register set. If REGNO is -1,
583 update them all. */
584 void
585 fill_fpregset (gdb_fpregset_t *fpregsetp, int regno)
586 {
587 int regi;
588 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
589 bfd_byte *fpp = (void *) fpregsetp;
590
591 for (regi = 0; regi < 32; regi++)
592 {
593 if ((regno == -1) || (regno == tdep->ppc_fp0_regnum + regi))
594 regcache_collect (tdep->ppc_fp0_regnum + regi, fpp + 8 * regi);
595 }
596 if ((regno == -1) || regno == tdep->ppc_fpscr_regnum)
597 right_fill_reg (tdep->ppc_fpscr_regnum, (fpp + 8 * 32));
598 }