Phase 1 of the ptid_t changes.
[deliverable/binutils-gdb.git] / gdb / rs6000-nat.c
CommitLineData
c906108c 1/* IBM RS/6000 native-dependent code for GDB, the GNU debugger.
b6ba6518
KB
2 Copyright 1986, 1987, 1989, 1991, 1992, 1993, 1994, 1995, 1996, 1997,
3 1998, 1999, 2000, 2001
c5aa993b 4 Free Software Foundation, Inc.
c906108c 5
c5aa993b 6 This file is part of GDB.
c906108c 7
c5aa993b
JM
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.
c906108c 12
c5aa993b
JM
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.
c906108c 17
c5aa993b
JM
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. */
c906108c
SS
22
23#include "defs.h"
24#include "inferior.h"
25#include "target.h"
26#include "gdbcore.h"
27#include "xcoffsolib.h"
28#include "symfile.h"
29#include "objfiles.h"
c5aa993b 30#include "libbfd.h" /* For bfd_cache_lookup (FIXME) */
c906108c
SS
31#include "bfd.h"
32#include "gdb-stabs.h"
4e052eda 33#include "regcache.h"
c906108c
SS
34
35#include <sys/ptrace.h>
36#include <sys/reg.h>
37
38#include <sys/param.h>
39#include <sys/dir.h>
40#include <sys/user.h>
41#include <signal.h>
42#include <sys/ioctl.h>
43#include <fcntl.h>
7a78ae4e 44#include <errno.h>
c906108c
SS
45
46#include <a.out.h>
47#include <sys/file.h>
48#include "gdb_stat.h"
49#include <sys/core.h>
7a78ae4e
ND
50#define __LDINFO_PTRACE32__ /* for __ld_info32 */
51#define __LDINFO_PTRACE64__ /* for __ld_info64 */
c906108c 52#include <sys/ldr.h>
7a78ae4e 53#include <sys/systemcfg.h>
c906108c 54
7a78ae4e
ND
55/* On AIX4.3+, sys/ldr.h provides different versions of struct ld_info for
56 debugging 32-bit and 64-bit processes. Define a typedef and macros for
57 accessing fields in the appropriate structures. */
58
59/* In 32-bit compilation mode (which is the only mode from which ptrace()
60 works on 4.3), __ld_info32 is #defined as equivalent to ld_info. */
61
62#ifdef __ld_info32
63# define ARCH3264
64#endif
65
66/* Return whether the current architecture is 64-bit. */
67
68#ifndef ARCH3264
69# define ARCH64() 0
70#else
71# define ARCH64() (REGISTER_RAW_SIZE (0) == 8)
72#endif
73
74/* Union of 32-bit and 64-bit ".reg" core file sections. */
75
76typedef union {
77#ifdef ARCH3264
78 struct __context64 r64;
79#else
80 struct mstsave r64;
81#endif
82 struct mstsave r32;
83} CoreRegs;
84
85/* Union of 32-bit and 64-bit versions of ld_info. */
86
87typedef union {
88#ifndef ARCH3264
89 struct ld_info l32;
90 struct ld_info l64;
91#else
92 struct __ld_info32 l32;
93 struct __ld_info64 l64;
94#endif
95} LdInfo;
96
97/* If compiling with 32-bit and 64-bit debugging capability (e.g. AIX 4.x),
98 declare and initialize a variable named VAR suitable for use as the arch64
99 parameter to the various LDI_*() macros. */
100
101#ifndef ARCH3264
102# define ARCH64_DECL(var)
103#else
104# define ARCH64_DECL(var) int var = ARCH64 ()
105#endif
106
107/* Return LDI's FIELD for a 64-bit process if ARCH64 and for a 32-bit process
108 otherwise. This technique only works for FIELDs with the same data type in
109 32-bit and 64-bit versions of ld_info. */
110
111#ifndef ARCH3264
112# define LDI_FIELD(ldi, arch64, field) (ldi)->l32.ldinfo_##field
113#else
114# define LDI_FIELD(ldi, arch64, field) \
115 (arch64 ? (ldi)->l64.ldinfo_##field : (ldi)->l32.ldinfo_##field)
116#endif
117
118/* Return various LDI fields for a 64-bit process if ARCH64 and for a 32-bit
119 process otherwise. */
120
121#define LDI_NEXT(ldi, arch64) LDI_FIELD(ldi, arch64, next)
122#define LDI_FD(ldi, arch64) LDI_FIELD(ldi, arch64, fd)
123#define LDI_FILENAME(ldi, arch64) LDI_FIELD(ldi, arch64, filename)
c906108c 124
a14ed312 125extern struct vmap *map_vmap (bfd * bf, bfd * arch);
c906108c
SS
126
127extern struct target_ops exec_ops;
128
a14ed312 129static void vmap_exec (void);
c906108c 130
7a78ae4e 131static void vmap_ldinfo (LdInfo *);
c906108c 132
7a78ae4e 133static struct vmap *add_vmap (LdInfo *);
c906108c 134
7a78ae4e 135static int objfile_symbol_add (void *);
c906108c 136
a14ed312 137static void vmap_symtab (struct vmap *);
c906108c 138
a14ed312 139static void fetch_core_registers (char *, unsigned int, int, CORE_ADDR);
c906108c 140
a14ed312 141static void exec_one_dummy_insn (void);
c906108c
SS
142
143extern void
a14ed312 144fixup_breakpoints (CORE_ADDR low, CORE_ADDR high, CORE_ADDR delta);
c906108c 145
7a78ae4e 146/* Conversion from gdb-to-system special purpose register numbers. */
c906108c 147
c5aa993b
JM
148static int special_regs[] =
149{
150 IAR, /* PC_REGNUM */
151 MSR, /* PS_REGNUM */
152 CR, /* CR_REGNUM */
153 LR, /* LR_REGNUM */
154 CTR, /* CTR_REGNUM */
c906108c 155 XER, /* XER_REGNUM */
c5aa993b 156 MQ /* MQ_REGNUM */
c906108c
SS
157};
158
7a78ae4e 159/* Call ptrace(REQ, ID, ADDR, DATA, BUF). */
c906108c 160
7a78ae4e
ND
161static int
162ptrace32 (int req, int id, int *addr, int data, int *buf)
163{
164 int ret = ptrace (req, id, (int *)addr, data, buf);
165#if 0
166 printf ("ptrace32 (%d, %d, 0x%x, %08x, 0x%x) = 0x%x\n",
167 req, id, (unsigned int)addr, data, (unsigned int)buf, ret);
168#endif
169 return ret;
170}
c906108c 171
7a78ae4e 172/* Call ptracex(REQ, ID, ADDR, DATA, BUF). */
c906108c 173
7a78ae4e
ND
174static int
175ptrace64 (int req, int id, long long addr, int data, int *buf)
176{
177#ifdef ARCH3264
178 int ret = ptracex (req, id, addr, data, buf);
179#else
180 int ret = 0;
181#endif
182#if 0
183 printf ("ptrace64 (%d, %d, 0x%llx, %08x, 0x%x) = 0x%x\n",
184 req, id, addr, data, (unsigned int)buf, ret);
185#endif
186 return ret;
187}
c906108c 188
7a78ae4e 189/* Fetch register REGNO from the inferior. */
c906108c 190
7a78ae4e
ND
191static void
192fetch_register (int regno)
193{
194 int *addr = (int *) &registers[REGISTER_BYTE (regno)];
195 int nr;
c906108c 196
7a78ae4e
ND
197 /* Retrieved values may be -1, so infer errors from errno. */
198 errno = 0;
c906108c 199
7a78ae4e
ND
200 /* Floating-point registers. */
201 if (regno >= FP0_REGNUM && regno <= FPLAST_REGNUM)
202 {
203 nr = regno - FP0_REGNUM + FPR0;
39f77062 204 ptrace32 (PT_READ_FPR, PIDGET (inferior_ptid), addr, nr, 0);
c5aa993b 205 }
c906108c 206
7a78ae4e
ND
207 /* Bogus register number. */
208 else if (regno > LAST_UISA_SP_REGNUM)
c5aa993b 209 fprintf_unfiltered (gdb_stderr,
c906108c
SS
210 "gdb error: register no %d not implemented.\n",
211 regno);
212
7a78ae4e
ND
213 /* Fixed-point registers. */
214 else
215 {
216 if (regno >= FIRST_UISA_SP_REGNUM)
217 nr = special_regs[regno - FIRST_UISA_SP_REGNUM];
218 else
219 nr = regno;
220
221 if (!ARCH64 ())
39f77062 222 *addr = ptrace32 (PT_READ_GPR, PIDGET (inferior_ptid), (int *)nr, 0, 0);
7a78ae4e
ND
223 else
224 {
225 /* PT_READ_GPR requires the buffer parameter to point to long long,
226 even if the register is really only 32 bits. */
227 long long buf;
39f77062 228 ptrace64 (PT_READ_GPR, PIDGET (inferior_ptid), nr, 0, (int *)&buf);
7a78ae4e
ND
229 if (REGISTER_RAW_SIZE (regno) == 8)
230 memcpy (addr, &buf, 8);
231 else
232 *addr = buf;
233 }
234 }
235
236 if (!errno)
237 register_valid[regno] = 1;
238 else
239 {
240#if 0
241 /* FIXME: this happens 3 times at the start of each 64-bit program. */
242 perror ("ptrace read");
243#endif
244 errno = 0;
245 }
c906108c
SS
246}
247
7a78ae4e 248/* Store register REGNO back into the inferior. */
c906108c 249
7a78ae4e
ND
250static void
251store_register (int regno)
c906108c 252{
7a78ae4e
ND
253 int *addr = (int *) &registers[REGISTER_BYTE (regno)];
254 int nr;
c906108c 255
7a78ae4e 256 /* -1 can be a successful return value, so infer errors from errno. */
c906108c
SS
257 errno = 0;
258
7a78ae4e
ND
259 /* Floating-point registers. */
260 if (regno >= FP0_REGNUM && regno <= FPLAST_REGNUM)
261 {
262 nr = regno - FP0_REGNUM + FPR0;
39f77062 263 ptrace32 (PT_WRITE_FPR, PIDGET (inferior_ptid), addr, nr, 0);
7a78ae4e 264 }
c906108c 265
7a78ae4e
ND
266 /* Bogus register number. */
267 else if (regno > LAST_UISA_SP_REGNUM)
268 {
269 if (regno >= NUM_REGS)
270 fprintf_unfiltered (gdb_stderr,
271 "gdb error: register no %d not implemented.\n",
272 regno);
273 }
c906108c 274
7a78ae4e
ND
275 /* Fixed-point registers. */
276 else
277 {
278 if (regno == SP_REGNUM)
279 /* Execute one dummy instruction (which is a breakpoint) in inferior
280 process to give kernel a chance to do internal housekeeping.
281 Otherwise the following ptrace(2) calls will mess up user stack
282 since kernel will get confused about the bottom of the stack
283 (%sp). */
284 exec_one_dummy_insn ();
c906108c 285
7a78ae4e
ND
286 if (regno >= FIRST_UISA_SP_REGNUM)
287 nr = special_regs[regno - FIRST_UISA_SP_REGNUM];
288 else
289 nr = regno;
c906108c 290
7a78ae4e 291 if (!ARCH64 ())
39f77062 292 ptrace32 (PT_WRITE_GPR, PIDGET (inferior_ptid), (int *)nr, *addr, 0);
7a78ae4e 293 else
c906108c 294 {
7a78ae4e
ND
295 /* PT_WRITE_GPR requires the buffer parameter to point to an 8-byte
296 area, even if the register is really only 32 bits. */
297 long long buf;
298 if (REGISTER_RAW_SIZE (regno) == 8)
299 memcpy (&buf, addr, 8);
300 else
301 buf = *addr;
39f77062 302 ptrace64 (PT_WRITE_GPR, PIDGET (inferior_ptid), nr, 0, (int *)&buf);
c906108c
SS
303 }
304 }
305
7a78ae4e 306 if (errno)
c906108c 307 {
7a78ae4e
ND
308 perror ("ptrace write");
309 errno = 0;
c906108c 310 }
7a78ae4e 311}
c906108c 312
7a78ae4e
ND
313/* Read from the inferior all registers if REGNO == -1 and just register
314 REGNO otherwise. */
c906108c 315
7a78ae4e
ND
316void
317fetch_inferior_registers (int regno)
318{
319 if (regno != -1)
320 fetch_register (regno);
321
322 else
c906108c 323 {
7a78ae4e
ND
324 /* read 32 general purpose registers. */
325 for (regno = 0; regno < 32; regno++)
326 fetch_register (regno);
327
328 /* read general purpose floating point registers. */
329 for (regno = FP0_REGNUM; regno <= FPLAST_REGNUM; regno++)
330 fetch_register (regno);
331
332 /* read special registers. */
333 for (regno = FIRST_UISA_SP_REGNUM; regno <= LAST_UISA_SP_REGNUM; regno++)
334 fetch_register (regno);
c906108c 335 }
7a78ae4e 336}
c906108c 337
7a78ae4e
ND
338/* Store our register values back into the inferior.
339 If REGNO is -1, do this for all registers.
340 Otherwise, REGNO specifies which register (so we can save time). */
341
342void
343store_inferior_registers (int regno)
344{
345 if (regno != -1)
346 store_register (regno);
347
348 else
f6077098 349 {
7a78ae4e
ND
350 /* write general purpose registers first! */
351 for (regno = GPR0; regno <= GPR31; regno++)
352 store_register (regno);
353
354 /* write floating point registers now. */
355 for (regno = FP0_REGNUM; regno <= FPLAST_REGNUM; regno++)
356 store_register (regno);
357
358 /* write special registers. */
359
360 for (regno = FIRST_UISA_SP_REGNUM; regno <= LAST_UISA_SP_REGNUM; regno++)
361 store_register (regno);
f6077098 362 }
7a78ae4e 363}
f6077098 364
7a78ae4e
ND
365/* Store in *TO the 32-bit word at 32-bit-aligned ADDR in the child
366 process, which is 64-bit if ARCH64 and 32-bit otherwise. Return
367 success. */
368
369static int
370read_word (CORE_ADDR from, int *to, int arch64)
371{
372 /* Retrieved values may be -1, so infer errors from errno. */
373 errno = 0;
374
375 if (arch64)
39f77062 376 *to = ptrace64 (PT_READ_I, PIDGET (inferior_ptid), from, 0, NULL);
c906108c 377 else
39f77062
KB
378 *to = ptrace32 (PT_READ_I, PIDGET (inferior_ptid), (int *)(long) from,
379 0, NULL);
c906108c 380
7a78ae4e
ND
381 return !errno;
382}
383
384/* Copy LEN bytes to or from inferior's memory starting at MEMADDR
385 to debugger memory starting at MYADDR. Copy to inferior if
386 WRITE is nonzero.
387
388 Returns the length copied, which is either the LEN argument or zero.
389 This xfer function does not do partial moves, since child_ops
390 doesn't allow memory operations to cross below us in the target stack
391 anyway. */
392
393int
394child_xfer_memory (CORE_ADDR memaddr, char *myaddr, int len,
d737ece6
PS
395 int write, struct mem_attrib *attrib,
396 struct target_ops *target)
7a78ae4e
ND
397{
398 /* Round starting address down to 32-bit word boundary. */
399 int mask = sizeof (int) - 1;
400 CORE_ADDR addr = memaddr & ~(CORE_ADDR)mask;
401
402 /* Round ending address up to 32-bit word boundary. */
403 int count = ((memaddr + len - addr + mask) & ~(CORE_ADDR)mask)
404 / sizeof (int);
405
406 /* Allocate word transfer buffer. */
407 int *buf = (int *) alloca (count * sizeof (int));
408
409 int arch64 = ARCH64 ();
410 int i;
411
412 if (!write)
c906108c 413 {
7a78ae4e
ND
414 /* Retrieve memory a word at a time. */
415 for (i = 0; i < count; i++, addr += sizeof (int))
416 {
417 if (!read_word (addr, buf + i, arch64))
418 return 0;
419 QUIT;
420 }
421
422 /* Copy memory to supplied buffer. */
423 addr -= count * sizeof (int);
424 memcpy (myaddr, (char *)buf + (memaddr - addr), len);
c906108c 425 }
7a78ae4e
ND
426 else
427 {
428 /* Fetch leading memory needed for alignment. */
429 if (addr < memaddr)
430 if (!read_word (addr, buf, arch64))
431 return 0;
432
433 /* Fetch trailing memory needed for alignment. */
434 if (addr + count * sizeof (int) > memaddr + len)
435 if (!read_word (addr, buf + count - 1, arch64))
436 return 0;
437
438 /* Copy supplied data into memory buffer. */
439 memcpy ((char *)buf + (memaddr - addr), myaddr, len);
440
441 /* Store memory one word at a time. */
442 for (i = 0, errno = 0; i < count; i++, addr += sizeof (int))
443 {
444 if (arch64)
39f77062 445 ptrace64 (PT_WRITE_D, PIDGET (inferior_ptid), addr, buf[i], NULL);
7a78ae4e 446 else
39f77062 447 ptrace32 (PT_WRITE_D, PIDGET (inferior_ptid), (int *)(long) addr,
7a78ae4e
ND
448 buf[i], NULL);
449
450 if (errno)
451 return 0;
452 QUIT;
453 }
454 }
455
456 return len;
c906108c
SS
457}
458
459/* Execute one dummy breakpoint instruction. This way we give the kernel
460 a chance to do some housekeeping and update inferior's internal data,
461 including u_area. */
462
463static void
7a78ae4e 464exec_one_dummy_insn (void)
c906108c
SS
465{
466#define DUMMY_INSN_ADDR (TEXT_SEGMENT_BASE)+0x200
467
c5aa993b 468 char shadow_contents[BREAKPOINT_MAX]; /* Stash old bkpt addr contents */
7a78ae4e 469 int ret, status, pid;
c906108c
SS
470 CORE_ADDR prev_pc;
471
472 /* We plant one dummy breakpoint into DUMMY_INSN_ADDR address. We
473 assume that this address will never be executed again by the real
474 code. */
475
476 target_insert_breakpoint (DUMMY_INSN_ADDR, shadow_contents);
477
c906108c
SS
478 /* You might think this could be done with a single ptrace call, and
479 you'd be correct for just about every platform I've ever worked
480 on. However, rs6000-ibm-aix4.1.3 seems to have screwed this up --
481 the inferior never hits the breakpoint (it's also worth noting
482 powerpc-ibm-aix4.1.3 works correctly). */
483 prev_pc = read_pc ();
484 write_pc (DUMMY_INSN_ADDR);
7a78ae4e 485 if (ARCH64 ())
39f77062 486 ret = ptrace64 (PT_CONTINUE, PIDGET (inferior_ptid), 1, 0, NULL);
7a78ae4e 487 else
39f77062 488 ret = ptrace32 (PT_CONTINUE, PIDGET (inferior_ptid), (int *)1, 0, NULL);
c906108c 489
7a78ae4e 490 if (ret != 0)
c906108c
SS
491 perror ("pt_continue");
492
c5aa993b
JM
493 do
494 {
495 pid = wait (&status);
496 }
39f77062 497 while (pid != PIDGET (inferior_ptid));
c5aa993b 498
c906108c
SS
499 write_pc (prev_pc);
500 target_remove_breakpoint (DUMMY_INSN_ADDR, shadow_contents);
501}
502
7a78ae4e
ND
503/* Fetch registers from the register section in core bfd. */
504
c906108c 505static void
7a78ae4e
ND
506fetch_core_registers (char *core_reg_sect, unsigned core_reg_size,
507 int which, CORE_ADDR reg_addr)
c906108c 508{
7a78ae4e
ND
509 CoreRegs *regs;
510 double *fprs;
511 int arch64, i, size;
512 void *gprs, *sprs[7];
513
514 if (which != 0)
c906108c 515 {
7a78ae4e
ND
516 fprintf_unfiltered
517 (gdb_stderr,
518 "Gdb error: unknown parameter to fetch_core_registers().\n");
519 return;
c906108c
SS
520 }
521
7a78ae4e
ND
522 arch64 = ARCH64 ();
523 regs = (CoreRegs *) core_reg_sect;
c906108c 524
7a78ae4e
ND
525 /* Retrieve register pointers. */
526
527 if (arch64)
528 {
529 gprs = regs->r64.gpr;
530 fprs = regs->r64.fpr;
531 sprs[0] = &regs->r64.iar;
532 sprs[1] = &regs->r64.msr;
533 sprs[2] = &regs->r64.cr;
534 sprs[3] = &regs->r64.lr;
535 sprs[4] = &regs->r64.ctr;
536 sprs[5] = &regs->r64.xer;
537 }
c906108c 538 else
7a78ae4e
ND
539 {
540 gprs = regs->r32.gpr;
541 fprs = regs->r32.fpr;
542 sprs[0] = &regs->r32.iar;
543 sprs[1] = &regs->r32.msr;
544 sprs[2] = &regs->r32.cr;
545 sprs[3] = &regs->r32.lr;
546 sprs[4] = &regs->r32.ctr;
547 sprs[5] = &regs->r32.xer;
548 sprs[6] = &regs->r32.mq;
549 }
550
551 /* Copy from pointers to registers[]. */
552
553 memcpy (registers, gprs, 32 * (arch64 ? 8 : 4));
554 memcpy (registers + REGISTER_BYTE (FP0_REGNUM), fprs, 32 * 8);
555 for (i = FIRST_UISA_SP_REGNUM; i <= LAST_UISA_SP_REGNUM; i++)
556 {
557 size = REGISTER_RAW_SIZE (i);
558 if (size)
559 memcpy (registers + REGISTER_BYTE (i),
560 sprs[i - FIRST_UISA_SP_REGNUM], size);
561 }
c906108c
SS
562}
563\f
7a78ae4e
ND
564
565/* Copy information about text and data sections from LDI to VP for a 64-bit
566 process if ARCH64 and for a 32-bit process otherwise. */
567
568static void
569vmap_secs (struct vmap *vp, LdInfo *ldi, int arch64)
570{
571 if (arch64)
572 {
573 vp->tstart = (CORE_ADDR) ldi->l64.ldinfo_textorg;
574 vp->tend = vp->tstart + ldi->l64.ldinfo_textsize;
575 vp->dstart = (CORE_ADDR) ldi->l64.ldinfo_dataorg;
576 vp->dend = vp->dstart + ldi->l64.ldinfo_datasize;
577 }
578 else
579 {
580 vp->tstart = (unsigned long) ldi->l32.ldinfo_textorg;
581 vp->tend = vp->tstart + ldi->l32.ldinfo_textsize;
582 vp->dstart = (unsigned long) ldi->l32.ldinfo_dataorg;
583 vp->dend = vp->dstart + ldi->l32.ldinfo_datasize;
584 }
585
586 /* The run time loader maps the file header in addition to the text
587 section and returns a pointer to the header in ldinfo_textorg.
588 Adjust the text start address to point to the real start address
589 of the text section. */
590 vp->tstart += vp->toffs;
591}
592
c906108c
SS
593/* handle symbol translation on vmapping */
594
595static void
7a78ae4e 596vmap_symtab (struct vmap *vp)
c906108c
SS
597{
598 register struct objfile *objfile;
599 struct section_offsets *new_offsets;
600 int i;
c5aa993b 601
c906108c
SS
602 objfile = vp->objfile;
603 if (objfile == NULL)
604 {
605 /* OK, it's not an objfile we opened ourselves.
c5aa993b
JM
606 Currently, that can only happen with the exec file, so
607 relocate the symbols for the symfile. */
c906108c
SS
608 if (symfile_objfile == NULL)
609 return;
610 objfile = symfile_objfile;
611 }
63f58cc5
PS
612 else if (!vp->loaded)
613 /* If symbols are not yet loaded, offsets are not yet valid. */
614 return;
c906108c 615
d4f3574e 616 new_offsets = (struct section_offsets *) alloca (SIZEOF_SECTION_OFFSETS);
c906108c
SS
617
618 for (i = 0; i < objfile->num_sections; ++i)
f0a58b0b 619 new_offsets->offsets[i] = ANOFFSET (objfile->section_offsets, i);
c5aa993b 620
c906108c
SS
621 /* The symbols in the object file are linked to the VMA of the section,
622 relocate them VMA relative. */
f0a58b0b
EZ
623 new_offsets->offsets[SECT_OFF_TEXT (objfile)] = vp->tstart - vp->tvma;
624 new_offsets->offsets[SECT_OFF_DATA (objfile)] = vp->dstart - vp->dvma;
625 new_offsets->offsets[SECT_OFF_BSS (objfile)] = vp->dstart - vp->dvma;
c906108c
SS
626
627 objfile_relocate (objfile, new_offsets);
628}
629\f
630/* Add symbols for an objfile. */
631
632static int
7a78ae4e 633objfile_symbol_add (void *arg)
c906108c
SS
634{
635 struct objfile *obj = (struct objfile *) arg;
636
2acceee2 637 syms_from_objfile (obj, NULL, 0, 0);
c906108c
SS
638 new_symfile_objfile (obj, 0, 0);
639 return 1;
640}
641
63f58cc5
PS
642/* Add symbols for a vmap. Return zero upon error. */
643
644int
645vmap_add_symbols (struct vmap *vp)
646{
647 if (catch_errors (objfile_symbol_add, vp->objfile,
648 "Error while reading shared library symbols:\n",
649 RETURN_MASK_ALL))
650 {
651 /* Note this is only done if symbol reading was successful. */
652 vp->loaded = 1;
653 vmap_symtab (vp);
654 return 1;
655 }
656 return 0;
657}
658
c906108c
SS
659/* Add a new vmap entry based on ldinfo() information.
660
661 If ldi->ldinfo_fd is not valid (e.g. this struct ld_info is from a
662 core file), the caller should set it to -1, and we will open the file.
663
664 Return the vmap new entry. */
665
666static struct vmap *
7a78ae4e 667add_vmap (LdInfo *ldi)
c906108c
SS
668{
669 bfd *abfd, *last;
7a78ae4e 670 register char *mem, *objname, *filename;
c906108c
SS
671 struct objfile *obj;
672 struct vmap *vp;
7a78ae4e
ND
673 int fd;
674 ARCH64_DECL (arch64);
c906108c
SS
675
676 /* This ldi structure was allocated using alloca() in
677 xcoff_relocate_symtab(). Now we need to have persistent object
678 and member names, so we should save them. */
679
7a78ae4e
ND
680 filename = LDI_FILENAME (ldi, arch64);
681 mem = filename + strlen (filename) + 1;
c906108c 682 mem = savestring (mem, strlen (mem));
7a78ae4e 683 objname = savestring (filename, strlen (filename));
c906108c 684
7a78ae4e
ND
685 fd = LDI_FD (ldi, arch64);
686 if (fd < 0)
c906108c
SS
687 /* Note that this opens it once for every member; a possible
688 enhancement would be to only open it once for every object. */
689 abfd = bfd_openr (objname, gnutarget);
690 else
7a78ae4e 691 abfd = bfd_fdopenr (objname, gnutarget, fd);
c906108c 692 if (!abfd)
63f58cc5
PS
693 {
694 warning ("Could not open `%s' as an executable file: %s",
695 objname, bfd_errmsg (bfd_get_error ()));
696 return NULL;
697 }
c906108c
SS
698
699 /* make sure we have an object file */
700
701 if (bfd_check_format (abfd, bfd_object))
702 vp = map_vmap (abfd, 0);
703
704 else if (bfd_check_format (abfd, bfd_archive))
705 {
706 last = 0;
707 /* FIXME??? am I tossing BFDs? bfd? */
708 while ((last = bfd_openr_next_archived_file (abfd, last)))
709 if (STREQ (mem, last->filename))
710 break;
711
712 if (!last)
713 {
63f58cc5 714 warning ("\"%s\": member \"%s\" missing.", objname, mem);
c906108c 715 bfd_close (abfd);
63f58cc5 716 return NULL;
c906108c
SS
717 }
718
c5aa993b 719 if (!bfd_check_format (last, bfd_object))
c906108c 720 {
63f58cc5
PS
721 warning ("\"%s\": member \"%s\" not in executable format: %s.",
722 objname, mem, bfd_errmsg (bfd_get_error ()));
723 bfd_close (last);
724 bfd_close (abfd);
725 return NULL;
c906108c
SS
726 }
727
728 vp = map_vmap (last, abfd);
729 }
730 else
731 {
63f58cc5
PS
732 warning ("\"%s\": not in executable format: %s.",
733 objname, bfd_errmsg (bfd_get_error ()));
c906108c 734 bfd_close (abfd);
63f58cc5 735 return NULL;
c906108c 736 }
2df3850c 737 obj = allocate_objfile (vp->bfd, 0);
c906108c
SS
738 vp->objfile = obj;
739
63f58cc5
PS
740 /* Always add symbols for the main objfile. */
741 if (vp == vmap || auto_solib_add)
742 vmap_add_symbols (vp);
c906108c
SS
743 return vp;
744}
745\f
746/* update VMAP info with ldinfo() information
747 Input is ptr to ldinfo() results. */
748
749static void
7a78ae4e 750vmap_ldinfo (LdInfo *ldi)
c906108c
SS
751{
752 struct stat ii, vi;
753 register struct vmap *vp;
754 int got_one, retried;
755 int got_exec_file = 0;
7a78ae4e
ND
756 uint next;
757 int arch64 = ARCH64 ();
c906108c
SS
758
759 /* For each *ldi, see if we have a corresponding *vp.
760 If so, update the mapping, and symbol table.
761 If not, add an entry and symbol table. */
762
c5aa993b
JM
763 do
764 {
7a78ae4e 765 char *name = LDI_FILENAME (ldi, arch64);
c5aa993b 766 char *memb = name + strlen (name) + 1;
7a78ae4e 767 int fd = LDI_FD (ldi, arch64);
c5aa993b
JM
768
769 retried = 0;
770
7a78ae4e 771 if (fstat (fd, &ii) < 0)
c5aa993b
JM
772 {
773 /* The kernel sets ld_info to -1, if the process is still using the
774 object, and the object is removed. Keep the symbol info for the
775 removed object and issue a warning. */
776 warning ("%s (fd=%d) has disappeared, keeping its symbols",
7a78ae4e 777 name, fd);
c906108c 778 continue;
c5aa993b
JM
779 }
780 retry:
781 for (got_one = 0, vp = vmap; vp; vp = vp->nxt)
782 {
783 struct objfile *objfile;
c906108c 784
c5aa993b
JM
785 /* First try to find a `vp', which is the same as in ldinfo.
786 If not the same, just continue and grep the next `vp'. If same,
787 relocate its tstart, tend, dstart, dend values. If no such `vp'
788 found, get out of this for loop, add this ldi entry as a new vmap
789 (add_vmap) and come back, find its `vp' and so on... */
790
791 /* The filenames are not always sufficient to match on. */
792
793 if ((name[0] == '/' && !STREQ (name, vp->name))
794 || (memb[0] && !STREQ (memb, vp->member)))
c906108c 795 continue;
c906108c 796
c5aa993b
JM
797 /* See if we are referring to the same file.
798 We have to check objfile->obfd, symfile.c:reread_symbols might
799 have updated the obfd after a change. */
800 objfile = vp->objfile == NULL ? symfile_objfile : vp->objfile;
801 if (objfile == NULL
802 || objfile->obfd == NULL
803 || bfd_stat (objfile->obfd, &vi) < 0)
804 {
805 warning ("Unable to stat %s, keeping its symbols", name);
806 continue;
807 }
c906108c 808
c5aa993b
JM
809 if (ii.st_dev != vi.st_dev || ii.st_ino != vi.st_ino)
810 continue;
c906108c 811
c5aa993b 812 if (!retried)
7a78ae4e 813 close (fd);
c906108c 814
c5aa993b 815 ++got_one;
c906108c 816
c5aa993b 817 /* Found a corresponding VMAP. Remap! */
c906108c 818
7a78ae4e 819 vmap_secs (vp, ldi, arch64);
c906108c 820
c5aa993b
JM
821 /* The objfile is only NULL for the exec file. */
822 if (vp->objfile == NULL)
823 got_exec_file = 1;
c906108c 824
c5aa993b
JM
825 /* relocate symbol table(s). */
826 vmap_symtab (vp);
c906108c 827
c5aa993b
JM
828 /* There may be more, so we don't break out of the loop. */
829 }
830
831 /* if there was no matching *vp, we must perforce create the sucker(s) */
832 if (!got_one && !retried)
833 {
834 add_vmap (ldi);
835 ++retried;
836 goto retry;
837 }
838 }
7a78ae4e
ND
839 while ((next = LDI_NEXT (ldi, arch64))
840 && (ldi = (void *) (next + (char *) ldi)));
c906108c
SS
841
842 /* If we don't find the symfile_objfile anywhere in the ldinfo, it
843 is unlikely that the symbol file is relocated to the proper
844 address. And we might have attached to a process which is
845 running a different copy of the same executable. */
846 if (symfile_objfile != NULL && !got_exec_file)
847 {
848 warning_begin ();
849 fputs_unfiltered ("Symbol file ", gdb_stderr);
850 fputs_unfiltered (symfile_objfile->name, gdb_stderr);
851 fputs_unfiltered ("\nis not mapped; discarding it.\n\
852If in fact that file has symbols which the mapped files listed by\n\
853\"info files\" lack, you can load symbols with the \"symbol-file\" or\n\
854\"add-symbol-file\" commands (note that you must take care of relocating\n\
855symbols to the proper address).\n", gdb_stderr);
856 free_objfile (symfile_objfile);
857 symfile_objfile = NULL;
858 }
859 breakpoint_re_set ();
860}
861\f
862/* As well as symbol tables, exec_sections need relocation. After
863 the inferior process' termination, there will be a relocated symbol
864 table exist with no corresponding inferior process. At that time, we
865 need to use `exec' bfd, rather than the inferior process's memory space
866 to look up symbols.
867
868 `exec_sections' need to be relocated only once, as long as the exec
869 file remains unchanged.
c5aa993b 870 */
c906108c
SS
871
872static void
7a78ae4e 873vmap_exec (void)
c906108c
SS
874{
875 static bfd *execbfd;
876 int i;
877
878 if (execbfd == exec_bfd)
879 return;
880
881 execbfd = exec_bfd;
882
883 if (!vmap || !exec_ops.to_sections)
884 error ("vmap_exec: vmap or exec_ops.to_sections == 0\n");
885
c5aa993b 886 for (i = 0; &exec_ops.to_sections[i] < exec_ops.to_sections_end; i++)
c906108c 887 {
c5aa993b 888 if (STREQ (".text", exec_ops.to_sections[i].the_bfd_section->name))
c906108c
SS
889 {
890 exec_ops.to_sections[i].addr += vmap->tstart - vmap->tvma;
891 exec_ops.to_sections[i].endaddr += vmap->tstart - vmap->tvma;
892 }
c5aa993b 893 else if (STREQ (".data", exec_ops.to_sections[i].the_bfd_section->name))
c906108c
SS
894 {
895 exec_ops.to_sections[i].addr += vmap->dstart - vmap->dvma;
896 exec_ops.to_sections[i].endaddr += vmap->dstart - vmap->dvma;
897 }
c5aa993b 898 else if (STREQ (".bss", exec_ops.to_sections[i].the_bfd_section->name))
c906108c
SS
899 {
900 exec_ops.to_sections[i].addr += vmap->dstart - vmap->dvma;
901 exec_ops.to_sections[i].endaddr += vmap->dstart - vmap->dvma;
902 }
903 }
904}
7a78ae4e
ND
905
906/* Set the current architecture from the host running GDB. Called when
907 starting a child process. */
908
909static void
910set_host_arch (int pid)
911{
912 enum bfd_architecture arch;
913 unsigned long mach;
914 bfd abfd;
915 struct gdbarch_info info;
916
917 if (__power_rs ())
918 {
919 arch = bfd_arch_rs6000;
920 mach = bfd_mach_rs6k;
921 }
922 else
923 {
924 arch = bfd_arch_powerpc;
925 mach = bfd_mach_ppc;
926 }
927 bfd_default_set_arch_mach (&abfd, arch, mach);
928
929 memset (&info, 0, sizeof info);
930 info.bfd_arch_info = bfd_get_arch_info (&abfd);
931
16f33e29
AC
932 if (!gdbarch_update_p (info))
933 {
8e65ff28
AC
934 internal_error (__FILE__, __LINE__,
935 "set_host_arch: failed to select architecture");
16f33e29 936 }
7a78ae4e
ND
937}
938
c906108c 939\f
c5aa993b 940/* xcoff_relocate_symtab - hook for symbol table relocation.
c906108c
SS
941 also reads shared libraries.. */
942
943void
7a78ae4e 944xcoff_relocate_symtab (unsigned int pid)
c906108c 945{
c18e0d23 946 int load_segs = 64; /* number of load segments */
380b774b 947 int rc;
7a78ae4e
ND
948 LdInfo *ldi = NULL;
949 int arch64 = ARCH64 ();
950 int ldisize = arch64 ? sizeof (ldi->l64) : sizeof (ldi->l32);
951 int size;
c906108c 952
c18e0d23
GM
953 do
954 {
7a78ae4e 955 size = load_segs * ldisize;
3a84337c 956 ldi = (void *) xrealloc (ldi, size);
c906108c 957
7a78ae4e 958#if 0
380b774b
GM
959 /* According to my humble theory, AIX has some timing problems and
960 when the user stack grows, kernel doesn't update stack info in time
961 and ptrace calls step on user stack. That is why we sleep here a
962 little, and give kernel to update its internals. */
380b774b 963 usleep (36000);
7a78ae4e
ND
964#endif
965
966 if (arch64)
967 rc = ptrace64 (PT_LDINFO, pid, (unsigned long) ldi, size, NULL);
968 else
969 rc = ptrace32 (PT_LDINFO, pid, (int *) ldi, size, NULL);
c906108c 970
c18e0d23
GM
971 if (rc == -1)
972 {
380b774b
GM
973 if (errno == ENOMEM)
974 load_segs *= 2;
975 else
976 perror_with_name ("ptrace ldinfo");
c18e0d23
GM
977 }
978 else
979 {
380b774b
GM
980 vmap_ldinfo (ldi);
981 vmap_exec (); /* relocate the exec and core sections as well. */
c18e0d23
GM
982 }
983 } while (rc == -1);
380b774b 984 if (ldi)
b8c9b27d 985 xfree (ldi);
c906108c
SS
986}
987\f
988/* Core file stuff. */
989
990/* Relocate symtabs and read in shared library info, based on symbols
991 from the core file. */
992
993void
7a78ae4e 994xcoff_relocate_core (struct target_ops *target)
c906108c 995{
c906108c
SS
996 sec_ptr ldinfo_sec;
997 int offset = 0;
7a78ae4e 998 LdInfo *ldi;
c906108c 999 struct vmap *vp;
7a78ae4e
ND
1000 int arch64 = ARCH64 ();
1001
1002 /* Size of a struct ld_info except for the variable-length filename. */
1003 int nonfilesz = (int)LDI_FILENAME ((LdInfo *)0, arch64);
c906108c
SS
1004
1005 /* Allocated size of buffer. */
7a78ae4e 1006 int buffer_size = nonfilesz;
c906108c
SS
1007 char *buffer = xmalloc (buffer_size);
1008 struct cleanup *old = make_cleanup (free_current_contents, &buffer);
c5aa993b 1009
c906108c
SS
1010 ldinfo_sec = bfd_get_section_by_name (core_bfd, ".ldinfo");
1011 if (ldinfo_sec == NULL)
1012 {
1013 bfd_err:
1014 fprintf_filtered (gdb_stderr, "Couldn't get ldinfo from core file: %s\n",
1015 bfd_errmsg (bfd_get_error ()));
1016 do_cleanups (old);
1017 return;
1018 }
1019 do
1020 {
1021 int i;
1022 int names_found = 0;
1023
1024 /* Read in everything but the name. */
1025 if (bfd_get_section_contents (core_bfd, ldinfo_sec, buffer,
7a78ae4e 1026 offset, nonfilesz) == 0)
c906108c
SS
1027 goto bfd_err;
1028
1029 /* Now the name. */
7a78ae4e 1030 i = nonfilesz;
c906108c
SS
1031 do
1032 {
1033 if (i == buffer_size)
1034 {
1035 buffer_size *= 2;
1036 buffer = xrealloc (buffer, buffer_size);
1037 }
1038 if (bfd_get_section_contents (core_bfd, ldinfo_sec, &buffer[i],
1039 offset + i, 1) == 0)
1040 goto bfd_err;
1041 if (buffer[i++] == '\0')
1042 ++names_found;
c5aa993b
JM
1043 }
1044 while (names_found < 2);
c906108c 1045
7a78ae4e 1046 ldi = (LdInfo *) buffer;
c906108c
SS
1047
1048 /* Can't use a file descriptor from the core file; need to open it. */
7a78ae4e
ND
1049 if (arch64)
1050 ldi->l64.ldinfo_fd = -1;
1051 else
1052 ldi->l32.ldinfo_fd = -1;
c5aa993b 1053
c906108c 1054 /* The first ldinfo is for the exec file, allocated elsewhere. */
63f58cc5 1055 if (offset == 0 && vmap != NULL)
c906108c
SS
1056 vp = vmap;
1057 else
7a78ae4e 1058 vp = add_vmap (ldi);
c906108c 1059
63f58cc5 1060 /* Process next shared library upon error. */
7a78ae4e 1061 offset += LDI_NEXT (ldi, arch64);
63f58cc5
PS
1062 if (vp == NULL)
1063 continue;
1064
7a78ae4e 1065 vmap_secs (vp, ldi, arch64);
c906108c
SS
1066
1067 /* Unless this is the exec file,
c5aa993b 1068 add our sections to the section table for the core target. */
c906108c
SS
1069 if (vp != vmap)
1070 {
c906108c 1071 struct section_table *stp;
6426a772
JM
1072
1073 target_resize_to_sections (target, 2);
c906108c
SS
1074 stp = target->to_sections_end - 2;
1075
1076 stp->bfd = vp->bfd;
1077 stp->the_bfd_section = bfd_get_section_by_name (stp->bfd, ".text");
1078 stp->addr = vp->tstart;
1079 stp->endaddr = vp->tend;
1080 stp++;
c5aa993b 1081
c906108c
SS
1082 stp->bfd = vp->bfd;
1083 stp->the_bfd_section = bfd_get_section_by_name (stp->bfd, ".data");
1084 stp->addr = vp->dstart;
1085 stp->endaddr = vp->dend;
1086 }
1087
1088 vmap_symtab (vp);
c5aa993b 1089 }
7a78ae4e 1090 while (LDI_NEXT (ldi, arch64) != 0);
c906108c
SS
1091 vmap_exec ();
1092 breakpoint_re_set ();
1093 do_cleanups (old);
1094}
1095
1096int
7a78ae4e 1097kernel_u_size (void)
c906108c
SS
1098{
1099 return (sizeof (struct user));
1100}
1101\f
1102/* Under AIX, we have to pass the correct TOC pointer to a function
1103 when calling functions in the inferior.
1104 We try to find the relative toc offset of the objfile containing PC
1105 and add the current load address of the data segment from the vmap. */
1106
1107static CORE_ADDR
7a78ae4e 1108find_toc_address (CORE_ADDR pc)
c906108c
SS
1109{
1110 struct vmap *vp;
7a78ae4e 1111 extern CORE_ADDR get_toc_offset (struct objfile *); /* xcoffread.c */
c906108c
SS
1112
1113 for (vp = vmap; vp; vp = vp->nxt)
1114 {
1115 if (pc >= vp->tstart && pc < vp->tend)
1116 {
1117 /* vp->objfile is only NULL for the exec file. */
1118 return vp->dstart + get_toc_offset (vp->objfile == NULL
1119 ? symfile_objfile
1120 : vp->objfile);
1121 }
1122 }
1123 error ("Unable to find TOC entry for pc 0x%x\n", pc);
1124}
1125\f
1126/* Register that we are able to handle rs6000 core file formats. */
1127
1128static struct core_fns rs6000_core_fns =
1129{
7a78ae4e 1130 bfd_target_xcoff_flavour, /* core_flavour */
2acceee2
JM
1131 default_check_format, /* check_format */
1132 default_core_sniffer, /* core_sniffer */
1133 fetch_core_registers, /* core_read_registers */
1134 NULL /* next */
c906108c
SS
1135};
1136
1137void
7a78ae4e 1138_initialize_core_rs6000 (void)
c906108c
SS
1139{
1140 /* Initialize hook in rs6000-tdep.c for determining the TOC address when
1141 calling functions in the inferior. */
7a78ae4e
ND
1142 rs6000_find_toc_address_hook = find_toc_address;
1143
1144 /* Initialize hook in rs6000-tdep.c to set the current architecture when
1145 starting a child process. */
1146 rs6000_set_host_arch_hook = set_host_arch;
c906108c 1147
c906108c
SS
1148 add_core_fns (&rs6000_core_fns);
1149}
This page took 0.19949 seconds and 4 git commands to generate.