1 /* IBM RS/6000 native-dependent code for GDB, the GNU debugger.
2 Copyright 1986, 1987, 1989, 1991, 1992, 1993, 1994, 1995, 1996, 1997,
4 Free Software Foundation, Inc.
6 This file is part of GDB.
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.
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.
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. */
27 #include "xcoffsolib.h"
30 #include "libbfd.h" /* For bfd_cache_lookup (FIXME) */
32 #include "gdb-stabs.h"
35 #include <sys/ptrace.h>
38 #include <sys/param.h>
42 #include <sys/ioctl.h>
50 #define __LDINFO_PTRACE32__ /* for __ld_info32 */
51 #define __LDINFO_PTRACE64__ /* for __ld_info64 */
53 #include <sys/systemcfg.h>
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. */
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. */
66 /* Return whether the current architecture is 64-bit. */
71 # define ARCH64() (REGISTER_RAW_SIZE (0) == 8)
74 /* Union of 32-bit and 64-bit ".reg" core file sections. */
78 struct __context64 r64
;
85 /* Union of 32-bit and 64-bit versions of ld_info. */
92 struct __ld_info32 l32
;
93 struct __ld_info64 l64
;
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. */
102 # define ARCH64_DECL(var)
104 # define ARCH64_DECL(var) int var = ARCH64 ()
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. */
112 # define LDI_FIELD(ldi, arch64, field) (ldi)->l32.ldinfo_##field
114 # define LDI_FIELD(ldi, arch64, field) \
115 (arch64 ? (ldi)->l64.ldinfo_##field : (ldi)->l32.ldinfo_##field)
118 /* Return various LDI fields for a 64-bit process if ARCH64 and for a 32-bit
119 process otherwise. */
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)
125 extern struct vmap
*map_vmap (bfd
* bf
, bfd
* arch
);
127 extern struct target_ops exec_ops
;
129 static void vmap_exec (void);
131 static void vmap_ldinfo (LdInfo
*);
133 static struct vmap
*add_vmap (LdInfo
*);
135 static int objfile_symbol_add (void *);
137 static void vmap_symtab (struct vmap
*);
139 static void fetch_core_registers (char *, unsigned int, int, CORE_ADDR
);
141 static void exec_one_dummy_insn (void);
144 fixup_breakpoints (CORE_ADDR low
, CORE_ADDR high
, CORE_ADDR delta
);
146 /* Conversion from gdb-to-system special purpose register numbers. */
148 static int special_regs
[] =
154 CTR
, /* CTR_REGNUM */
155 XER
, /* XER_REGNUM */
159 /* Call ptrace(REQ, ID, ADDR, DATA, BUF). */
162 ptrace32 (int req
, int id
, int *addr
, int data
, int *buf
)
164 int ret
= ptrace (req
, id
, (int *)addr
, data
, buf
);
166 printf ("ptrace32 (%d, %d, 0x%x, %08x, 0x%x) = 0x%x\n",
167 req
, id
, (unsigned int)addr
, data
, (unsigned int)buf
, ret
);
172 /* Call ptracex(REQ, ID, ADDR, DATA, BUF). */
175 ptrace64 (int req
, int id
, long long addr
, int data
, int *buf
)
178 int ret
= ptracex (req
, id
, addr
, data
, buf
);
183 printf ("ptrace64 (%d, %d, 0x%llx, %08x, 0x%x) = 0x%x\n",
184 req
, id
, addr
, data
, (unsigned int)buf
, ret
);
189 /* Fetch register REGNO from the inferior. */
192 fetch_register (int regno
)
194 int *addr
= (int *) ®isters
[REGISTER_BYTE (regno
)];
197 /* Retrieved values may be -1, so infer errors from errno. */
200 /* Floating-point registers. */
201 if (regno
>= FP0_REGNUM
&& regno
<= FPLAST_REGNUM
)
203 nr
= regno
- FP0_REGNUM
+ FPR0
;
204 ptrace32 (PT_READ_FPR
, inferior_pid
, addr
, nr
, 0);
207 /* Bogus register number. */
208 else if (regno
> LAST_UISA_SP_REGNUM
)
209 fprintf_unfiltered (gdb_stderr
,
210 "gdb error: register no %d not implemented.\n",
213 /* Fixed-point registers. */
216 if (regno
>= FIRST_UISA_SP_REGNUM
)
217 nr
= special_regs
[regno
- FIRST_UISA_SP_REGNUM
];
222 *addr
= ptrace32 (PT_READ_GPR
, inferior_pid
, (int *)nr
, 0, 0);
225 /* PT_READ_GPR requires the buffer parameter to point to long long,
226 even if the register is really only 32 bits. */
228 ptrace64 (PT_READ_GPR
, inferior_pid
, nr
, 0, (int *)&buf
);
229 if (REGISTER_RAW_SIZE (regno
) == 8)
230 memcpy (addr
, &buf
, 8);
237 register_valid
[regno
] = 1;
241 /* FIXME: this happens 3 times at the start of each 64-bit program. */
242 perror ("ptrace read");
248 /* Store register REGNO back into the inferior. */
251 store_register (int regno
)
253 int *addr
= (int *) ®isters
[REGISTER_BYTE (regno
)];
256 /* -1 can be a successful return value, so infer errors from errno. */
259 /* Floating-point registers. */
260 if (regno
>= FP0_REGNUM
&& regno
<= FPLAST_REGNUM
)
262 nr
= regno
- FP0_REGNUM
+ FPR0
;
263 ptrace32 (PT_WRITE_FPR
, inferior_pid
, addr
, nr
, 0);
266 /* Bogus register number. */
267 else if (regno
> LAST_UISA_SP_REGNUM
)
269 if (regno
>= NUM_REGS
)
270 fprintf_unfiltered (gdb_stderr
,
271 "gdb error: register no %d not implemented.\n",
275 /* Fixed-point registers. */
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
284 exec_one_dummy_insn ();
286 if (regno
>= FIRST_UISA_SP_REGNUM
)
287 nr
= special_regs
[regno
- FIRST_UISA_SP_REGNUM
];
292 ptrace32 (PT_WRITE_GPR
, inferior_pid
, (int *)nr
, *addr
, 0);
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. */
298 if (REGISTER_RAW_SIZE (regno
) == 8)
299 memcpy (&buf
, addr
, 8);
302 ptrace64 (PT_WRITE_GPR
, inferior_pid
, nr
, 0, (int *)&buf
);
308 perror ("ptrace write");
313 /* Read from the inferior all registers if REGNO == -1 and just register
317 fetch_inferior_registers (int regno
)
320 fetch_register (regno
);
324 /* read 32 general purpose registers. */
325 for (regno
= 0; regno
< 32; regno
++)
326 fetch_register (regno
);
328 /* read general purpose floating point registers. */
329 for (regno
= FP0_REGNUM
; regno
<= FPLAST_REGNUM
; regno
++)
330 fetch_register (regno
);
332 /* read special registers. */
333 for (regno
= FIRST_UISA_SP_REGNUM
; regno
<= LAST_UISA_SP_REGNUM
; regno
++)
334 fetch_register (regno
);
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). */
343 store_inferior_registers (int regno
)
346 store_register (regno
);
350 /* write general purpose registers first! */
351 for (regno
= GPR0
; regno
<= GPR31
; regno
++)
352 store_register (regno
);
354 /* write floating point registers now. */
355 for (regno
= FP0_REGNUM
; regno
<= FPLAST_REGNUM
; regno
++)
356 store_register (regno
);
358 /* write special registers. */
360 for (regno
= FIRST_UISA_SP_REGNUM
; regno
<= LAST_UISA_SP_REGNUM
; regno
++)
361 store_register (regno
);
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
370 read_word (CORE_ADDR from
, int *to
, int arch64
)
372 /* Retrieved values may be -1, so infer errors from errno. */
376 *to
= ptrace64 (PT_READ_I
, inferior_pid
, from
, 0, NULL
);
378 *to
= ptrace32 (PT_READ_I
, inferior_pid
, (int *)(long) from
, 0, NULL
);
383 /* Copy LEN bytes to or from inferior's memory starting at MEMADDR
384 to debugger memory starting at MYADDR. Copy to inferior if
387 Returns the length copied, which is either the LEN argument or zero.
388 This xfer function does not do partial moves, since child_ops
389 doesn't allow memory operations to cross below us in the target stack
393 child_xfer_memory (CORE_ADDR memaddr
, char *myaddr
, int len
,
394 int write
, struct mem_attrib
*attrib
,
395 struct target_ops
*target
)
397 /* Round starting address down to 32-bit word boundary. */
398 int mask
= sizeof (int) - 1;
399 CORE_ADDR addr
= memaddr
& ~(CORE_ADDR
)mask
;
401 /* Round ending address up to 32-bit word boundary. */
402 int count
= ((memaddr
+ len
- addr
+ mask
) & ~(CORE_ADDR
)mask
)
405 /* Allocate word transfer buffer. */
406 int *buf
= (int *) alloca (count
* sizeof (int));
408 int arch64
= ARCH64 ();
413 /* Retrieve memory a word at a time. */
414 for (i
= 0; i
< count
; i
++, addr
+= sizeof (int))
416 if (!read_word (addr
, buf
+ i
, arch64
))
421 /* Copy memory to supplied buffer. */
422 addr
-= count
* sizeof (int);
423 memcpy (myaddr
, (char *)buf
+ (memaddr
- addr
), len
);
427 /* Fetch leading memory needed for alignment. */
429 if (!read_word (addr
, buf
, arch64
))
432 /* Fetch trailing memory needed for alignment. */
433 if (addr
+ count
* sizeof (int) > memaddr
+ len
)
434 if (!read_word (addr
, buf
+ count
- 1, arch64
))
437 /* Copy supplied data into memory buffer. */
438 memcpy ((char *)buf
+ (memaddr
- addr
), myaddr
, len
);
440 /* Store memory one word at a time. */
441 for (i
= 0, errno
= 0; i
< count
; i
++, addr
+= sizeof (int))
444 ptrace64 (PT_WRITE_D
, inferior_pid
, addr
, buf
[i
], NULL
);
446 ptrace32 (PT_WRITE_D
, inferior_pid
, (int *)(long) addr
,
458 /* Execute one dummy breakpoint instruction. This way we give the kernel
459 a chance to do some housekeeping and update inferior's internal data,
463 exec_one_dummy_insn (void)
465 #define DUMMY_INSN_ADDR (TEXT_SEGMENT_BASE)+0x200
467 char shadow_contents
[BREAKPOINT_MAX
]; /* Stash old bkpt addr contents */
468 int ret
, status
, pid
;
471 /* We plant one dummy breakpoint into DUMMY_INSN_ADDR address. We
472 assume that this address will never be executed again by the real
475 target_insert_breakpoint (DUMMY_INSN_ADDR
, shadow_contents
);
477 /* You might think this could be done with a single ptrace call, and
478 you'd be correct for just about every platform I've ever worked
479 on. However, rs6000-ibm-aix4.1.3 seems to have screwed this up --
480 the inferior never hits the breakpoint (it's also worth noting
481 powerpc-ibm-aix4.1.3 works correctly). */
482 prev_pc
= read_pc ();
483 write_pc (DUMMY_INSN_ADDR
);
485 ret
= ptrace64 (PT_CONTINUE
, inferior_pid
, 1, 0, NULL
);
487 ret
= ptrace32 (PT_CONTINUE
, inferior_pid
, (int *)1, 0, NULL
);
490 perror ("pt_continue");
494 pid
= wait (&status
);
496 while (pid
!= inferior_pid
);
499 target_remove_breakpoint (DUMMY_INSN_ADDR
, shadow_contents
);
502 /* Fetch registers from the register section in core bfd. */
505 fetch_core_registers (char *core_reg_sect
, unsigned core_reg_size
,
506 int which
, CORE_ADDR reg_addr
)
511 void *gprs
, *sprs
[7];
517 "Gdb error: unknown parameter to fetch_core_registers().\n");
522 regs
= (CoreRegs
*) core_reg_sect
;
524 /* Retrieve register pointers. */
528 gprs
= regs
->r64
.gpr
;
529 fprs
= regs
->r64
.fpr
;
530 sprs
[0] = ®s
->r64
.iar
;
531 sprs
[1] = ®s
->r64
.msr
;
532 sprs
[2] = ®s
->r64
.cr
;
533 sprs
[3] = ®s
->r64
.lr
;
534 sprs
[4] = ®s
->r64
.ctr
;
535 sprs
[5] = ®s
->r64
.xer
;
539 gprs
= regs
->r32
.gpr
;
540 fprs
= regs
->r32
.fpr
;
541 sprs
[0] = ®s
->r32
.iar
;
542 sprs
[1] = ®s
->r32
.msr
;
543 sprs
[2] = ®s
->r32
.cr
;
544 sprs
[3] = ®s
->r32
.lr
;
545 sprs
[4] = ®s
->r32
.ctr
;
546 sprs
[5] = ®s
->r32
.xer
;
547 sprs
[6] = ®s
->r32
.mq
;
550 /* Copy from pointers to registers[]. */
552 memcpy (registers
, gprs
, 32 * (arch64
? 8 : 4));
553 memcpy (registers
+ REGISTER_BYTE (FP0_REGNUM
), fprs
, 32 * 8);
554 for (i
= FIRST_UISA_SP_REGNUM
; i
<= LAST_UISA_SP_REGNUM
; i
++)
556 size
= REGISTER_RAW_SIZE (i
);
558 memcpy (registers
+ REGISTER_BYTE (i
),
559 sprs
[i
- FIRST_UISA_SP_REGNUM
], size
);
564 /* Copy information about text and data sections from LDI to VP for a 64-bit
565 process if ARCH64 and for a 32-bit process otherwise. */
568 vmap_secs (struct vmap
*vp
, LdInfo
*ldi
, int arch64
)
572 vp
->tstart
= (CORE_ADDR
) ldi
->l64
.ldinfo_textorg
;
573 vp
->tend
= vp
->tstart
+ ldi
->l64
.ldinfo_textsize
;
574 vp
->dstart
= (CORE_ADDR
) ldi
->l64
.ldinfo_dataorg
;
575 vp
->dend
= vp
->dstart
+ ldi
->l64
.ldinfo_datasize
;
579 vp
->tstart
= (unsigned long) ldi
->l32
.ldinfo_textorg
;
580 vp
->tend
= vp
->tstart
+ ldi
->l32
.ldinfo_textsize
;
581 vp
->dstart
= (unsigned long) ldi
->l32
.ldinfo_dataorg
;
582 vp
->dend
= vp
->dstart
+ ldi
->l32
.ldinfo_datasize
;
585 /* The run time loader maps the file header in addition to the text
586 section and returns a pointer to the header in ldinfo_textorg.
587 Adjust the text start address to point to the real start address
588 of the text section. */
589 vp
->tstart
+= vp
->toffs
;
592 /* handle symbol translation on vmapping */
595 vmap_symtab (struct vmap
*vp
)
597 register struct objfile
*objfile
;
598 struct section_offsets
*new_offsets
;
601 objfile
= vp
->objfile
;
604 /* OK, it's not an objfile we opened ourselves.
605 Currently, that can only happen with the exec file, so
606 relocate the symbols for the symfile. */
607 if (symfile_objfile
== NULL
)
609 objfile
= symfile_objfile
;
611 else if (!vp
->loaded
)
612 /* If symbols are not yet loaded, offsets are not yet valid. */
615 new_offsets
= (struct section_offsets
*) alloca (SIZEOF_SECTION_OFFSETS
);
617 for (i
= 0; i
< objfile
->num_sections
; ++i
)
618 new_offsets
->offsets
[i
] = ANOFFSET (objfile
->section_offsets
, i
);
620 /* The symbols in the object file are linked to the VMA of the section,
621 relocate them VMA relative. */
622 new_offsets
->offsets
[SECT_OFF_TEXT (objfile
)] = vp
->tstart
- vp
->tvma
;
623 new_offsets
->offsets
[SECT_OFF_DATA (objfile
)] = vp
->dstart
- vp
->dvma
;
624 new_offsets
->offsets
[SECT_OFF_BSS (objfile
)] = vp
->dstart
- vp
->dvma
;
626 objfile_relocate (objfile
, new_offsets
);
629 /* Add symbols for an objfile. */
632 objfile_symbol_add (void *arg
)
634 struct objfile
*obj
= (struct objfile
*) arg
;
636 syms_from_objfile (obj
, NULL
, 0, 0);
637 new_symfile_objfile (obj
, 0, 0);
641 /* Add symbols for a vmap. Return zero upon error. */
644 vmap_add_symbols (struct vmap
*vp
)
646 if (catch_errors (objfile_symbol_add
, vp
->objfile
,
647 "Error while reading shared library symbols:\n",
650 /* Note this is only done if symbol reading was successful. */
658 /* Add a new vmap entry based on ldinfo() information.
660 If ldi->ldinfo_fd is not valid (e.g. this struct ld_info is from a
661 core file), the caller should set it to -1, and we will open the file.
663 Return the vmap new entry. */
666 add_vmap (LdInfo
*ldi
)
669 register char *mem
, *objname
, *filename
;
673 ARCH64_DECL (arch64
);
675 /* This ldi structure was allocated using alloca() in
676 xcoff_relocate_symtab(). Now we need to have persistent object
677 and member names, so we should save them. */
679 filename
= LDI_FILENAME (ldi
, arch64
);
680 mem
= filename
+ strlen (filename
) + 1;
681 mem
= savestring (mem
, strlen (mem
));
682 objname
= savestring (filename
, strlen (filename
));
684 fd
= LDI_FD (ldi
, arch64
);
686 /* Note that this opens it once for every member; a possible
687 enhancement would be to only open it once for every object. */
688 abfd
= bfd_openr (objname
, gnutarget
);
690 abfd
= bfd_fdopenr (objname
, gnutarget
, fd
);
693 warning ("Could not open `%s' as an executable file: %s",
694 objname
, bfd_errmsg (bfd_get_error ()));
698 /* make sure we have an object file */
700 if (bfd_check_format (abfd
, bfd_object
))
701 vp
= map_vmap (abfd
, 0);
703 else if (bfd_check_format (abfd
, bfd_archive
))
706 /* FIXME??? am I tossing BFDs? bfd? */
707 while ((last
= bfd_openr_next_archived_file (abfd
, last
)))
708 if (STREQ (mem
, last
->filename
))
713 warning ("\"%s\": member \"%s\" missing.", objname
, mem
);
718 if (!bfd_check_format (last
, bfd_object
))
720 warning ("\"%s\": member \"%s\" not in executable format: %s.",
721 objname
, mem
, bfd_errmsg (bfd_get_error ()));
727 vp
= map_vmap (last
, abfd
);
731 warning ("\"%s\": not in executable format: %s.",
732 objname
, bfd_errmsg (bfd_get_error ()));
736 obj
= allocate_objfile (vp
->bfd
, 0);
739 /* Always add symbols for the main objfile. */
740 if (vp
== vmap
|| auto_solib_add
)
741 vmap_add_symbols (vp
);
745 /* update VMAP info with ldinfo() information
746 Input is ptr to ldinfo() results. */
749 vmap_ldinfo (LdInfo
*ldi
)
752 register struct vmap
*vp
;
753 int got_one
, retried
;
754 int got_exec_file
= 0;
756 int arch64
= ARCH64 ();
758 /* For each *ldi, see if we have a corresponding *vp.
759 If so, update the mapping, and symbol table.
760 If not, add an entry and symbol table. */
764 char *name
= LDI_FILENAME (ldi
, arch64
);
765 char *memb
= name
+ strlen (name
) + 1;
766 int fd
= LDI_FD (ldi
, arch64
);
770 if (fstat (fd
, &ii
) < 0)
772 /* The kernel sets ld_info to -1, if the process is still using the
773 object, and the object is removed. Keep the symbol info for the
774 removed object and issue a warning. */
775 warning ("%s (fd=%d) has disappeared, keeping its symbols",
780 for (got_one
= 0, vp
= vmap
; vp
; vp
= vp
->nxt
)
782 struct objfile
*objfile
;
784 /* First try to find a `vp', which is the same as in ldinfo.
785 If not the same, just continue and grep the next `vp'. If same,
786 relocate its tstart, tend, dstart, dend values. If no such `vp'
787 found, get out of this for loop, add this ldi entry as a new vmap
788 (add_vmap) and come back, find its `vp' and so on... */
790 /* The filenames are not always sufficient to match on. */
792 if ((name
[0] == '/' && !STREQ (name
, vp
->name
))
793 || (memb
[0] && !STREQ (memb
, vp
->member
)))
796 /* See if we are referring to the same file.
797 We have to check objfile->obfd, symfile.c:reread_symbols might
798 have updated the obfd after a change. */
799 objfile
= vp
->objfile
== NULL
? symfile_objfile
: vp
->objfile
;
801 || objfile
->obfd
== NULL
802 || bfd_stat (objfile
->obfd
, &vi
) < 0)
804 warning ("Unable to stat %s, keeping its symbols", name
);
808 if (ii
.st_dev
!= vi
.st_dev
|| ii
.st_ino
!= vi
.st_ino
)
816 /* Found a corresponding VMAP. Remap! */
818 vmap_secs (vp
, ldi
, arch64
);
820 /* The objfile is only NULL for the exec file. */
821 if (vp
->objfile
== NULL
)
824 /* relocate symbol table(s). */
827 /* There may be more, so we don't break out of the loop. */
830 /* if there was no matching *vp, we must perforce create the sucker(s) */
831 if (!got_one
&& !retried
)
838 while ((next
= LDI_NEXT (ldi
, arch64
))
839 && (ldi
= (void *) (next
+ (char *) ldi
)));
841 /* If we don't find the symfile_objfile anywhere in the ldinfo, it
842 is unlikely that the symbol file is relocated to the proper
843 address. And we might have attached to a process which is
844 running a different copy of the same executable. */
845 if (symfile_objfile
!= NULL
&& !got_exec_file
)
848 fputs_unfiltered ("Symbol file ", gdb_stderr
);
849 fputs_unfiltered (symfile_objfile
->name
, gdb_stderr
);
850 fputs_unfiltered ("\nis not mapped; discarding it.\n\
851 If in fact that file has symbols which the mapped files listed by\n\
852 \"info files\" lack, you can load symbols with the \"symbol-file\" or\n\
853 \"add-symbol-file\" commands (note that you must take care of relocating\n\
854 symbols to the proper address).\n", gdb_stderr
);
855 free_objfile (symfile_objfile
);
856 symfile_objfile
= NULL
;
858 breakpoint_re_set ();
861 /* As well as symbol tables, exec_sections need relocation. After
862 the inferior process' termination, there will be a relocated symbol
863 table exist with no corresponding inferior process. At that time, we
864 need to use `exec' bfd, rather than the inferior process's memory space
867 `exec_sections' need to be relocated only once, as long as the exec
868 file remains unchanged.
877 if (execbfd
== exec_bfd
)
882 if (!vmap
|| !exec_ops
.to_sections
)
883 error ("vmap_exec: vmap or exec_ops.to_sections == 0\n");
885 for (i
= 0; &exec_ops
.to_sections
[i
] < exec_ops
.to_sections_end
; i
++)
887 if (STREQ (".text", exec_ops
.to_sections
[i
].the_bfd_section
->name
))
889 exec_ops
.to_sections
[i
].addr
+= vmap
->tstart
- vmap
->tvma
;
890 exec_ops
.to_sections
[i
].endaddr
+= vmap
->tstart
- vmap
->tvma
;
892 else if (STREQ (".data", exec_ops
.to_sections
[i
].the_bfd_section
->name
))
894 exec_ops
.to_sections
[i
].addr
+= vmap
->dstart
- vmap
->dvma
;
895 exec_ops
.to_sections
[i
].endaddr
+= vmap
->dstart
- vmap
->dvma
;
897 else if (STREQ (".bss", exec_ops
.to_sections
[i
].the_bfd_section
->name
))
899 exec_ops
.to_sections
[i
].addr
+= vmap
->dstart
- vmap
->dvma
;
900 exec_ops
.to_sections
[i
].endaddr
+= vmap
->dstart
- vmap
->dvma
;
905 /* Set the current architecture from the host running GDB. Called when
906 starting a child process. */
909 set_host_arch (int pid
)
911 enum bfd_architecture arch
;
914 struct gdbarch_info info
;
918 arch
= bfd_arch_rs6000
;
919 mach
= bfd_mach_rs6k
;
923 arch
= bfd_arch_powerpc
;
926 bfd_default_set_arch_mach (&abfd
, arch
, mach
);
928 memset (&info
, 0, sizeof info
);
929 info
.bfd_arch_info
= bfd_get_arch_info (&abfd
);
931 if (!gdbarch_update_p (info
))
933 internal_error (__FILE__
, __LINE__
,
934 "set_host_arch: failed to select architecture");
939 /* xcoff_relocate_symtab - hook for symbol table relocation.
940 also reads shared libraries.. */
943 xcoff_relocate_symtab (unsigned int pid
)
945 int load_segs
= 64; /* number of load segments */
948 int arch64
= ARCH64 ();
949 int ldisize
= arch64
? sizeof (ldi
->l64
) : sizeof (ldi
->l32
);
954 size
= load_segs
* ldisize
;
955 ldi
= (void *) xrealloc (ldi
, size
);
958 /* According to my humble theory, AIX has some timing problems and
959 when the user stack grows, kernel doesn't update stack info in time
960 and ptrace calls step on user stack. That is why we sleep here a
961 little, and give kernel to update its internals. */
966 rc
= ptrace64 (PT_LDINFO
, pid
, (unsigned long) ldi
, size
, NULL
);
968 rc
= ptrace32 (PT_LDINFO
, pid
, (int *) ldi
, size
, NULL
);
975 perror_with_name ("ptrace ldinfo");
980 vmap_exec (); /* relocate the exec and core sections as well. */
987 /* Core file stuff. */
989 /* Relocate symtabs and read in shared library info, based on symbols
990 from the core file. */
993 xcoff_relocate_core (struct target_ops
*target
)
999 int arch64
= ARCH64 ();
1001 /* Size of a struct ld_info except for the variable-length filename. */
1002 int nonfilesz
= (int)LDI_FILENAME ((LdInfo
*)0, arch64
);
1004 /* Allocated size of buffer. */
1005 int buffer_size
= nonfilesz
;
1006 char *buffer
= xmalloc (buffer_size
);
1007 struct cleanup
*old
= make_cleanup (free_current_contents
, &buffer
);
1009 ldinfo_sec
= bfd_get_section_by_name (core_bfd
, ".ldinfo");
1010 if (ldinfo_sec
== NULL
)
1013 fprintf_filtered (gdb_stderr
, "Couldn't get ldinfo from core file: %s\n",
1014 bfd_errmsg (bfd_get_error ()));
1021 int names_found
= 0;
1023 /* Read in everything but the name. */
1024 if (bfd_get_section_contents (core_bfd
, ldinfo_sec
, buffer
,
1025 offset
, nonfilesz
) == 0)
1032 if (i
== buffer_size
)
1035 buffer
= xrealloc (buffer
, buffer_size
);
1037 if (bfd_get_section_contents (core_bfd
, ldinfo_sec
, &buffer
[i
],
1038 offset
+ i
, 1) == 0)
1040 if (buffer
[i
++] == '\0')
1043 while (names_found
< 2);
1045 ldi
= (LdInfo
*) buffer
;
1047 /* Can't use a file descriptor from the core file; need to open it. */
1049 ldi
->l64
.ldinfo_fd
= -1;
1051 ldi
->l32
.ldinfo_fd
= -1;
1053 /* The first ldinfo is for the exec file, allocated elsewhere. */
1054 if (offset
== 0 && vmap
!= NULL
)
1057 vp
= add_vmap (ldi
);
1059 /* Process next shared library upon error. */
1060 offset
+= LDI_NEXT (ldi
, arch64
);
1064 vmap_secs (vp
, ldi
, arch64
);
1066 /* Unless this is the exec file,
1067 add our sections to the section table for the core target. */
1070 struct section_table
*stp
;
1072 target_resize_to_sections (target
, 2);
1073 stp
= target
->to_sections_end
- 2;
1076 stp
->the_bfd_section
= bfd_get_section_by_name (stp
->bfd
, ".text");
1077 stp
->addr
= vp
->tstart
;
1078 stp
->endaddr
= vp
->tend
;
1082 stp
->the_bfd_section
= bfd_get_section_by_name (stp
->bfd
, ".data");
1083 stp
->addr
= vp
->dstart
;
1084 stp
->endaddr
= vp
->dend
;
1089 while (LDI_NEXT (ldi
, arch64
) != 0);
1091 breakpoint_re_set ();
1096 kernel_u_size (void)
1098 return (sizeof (struct user
));
1101 /* Under AIX, we have to pass the correct TOC pointer to a function
1102 when calling functions in the inferior.
1103 We try to find the relative toc offset of the objfile containing PC
1104 and add the current load address of the data segment from the vmap. */
1107 find_toc_address (CORE_ADDR pc
)
1110 extern CORE_ADDR
get_toc_offset (struct objfile
*); /* xcoffread.c */
1112 for (vp
= vmap
; vp
; vp
= vp
->nxt
)
1114 if (pc
>= vp
->tstart
&& pc
< vp
->tend
)
1116 /* vp->objfile is only NULL for the exec file. */
1117 return vp
->dstart
+ get_toc_offset (vp
->objfile
== NULL
1122 error ("Unable to find TOC entry for pc 0x%x\n", pc
);
1125 /* Register that we are able to handle rs6000 core file formats. */
1127 static struct core_fns rs6000_core_fns
=
1129 bfd_target_xcoff_flavour
, /* core_flavour */
1130 default_check_format
, /* check_format */
1131 default_core_sniffer
, /* core_sniffer */
1132 fetch_core_registers
, /* core_read_registers */
1137 _initialize_core_rs6000 (void)
1139 /* Initialize hook in rs6000-tdep.c for determining the TOC address when
1140 calling functions in the inferior. */
1141 rs6000_find_toc_address_hook
= find_toc_address
;
1143 /* Initialize hook in rs6000-tdep.c to set the current architecture when
1144 starting a child process. */
1145 rs6000_set_host_arch_hook
= set_host_arch
;
1147 add_core_fns (&rs6000_core_fns
);