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