]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gdb/corefile.c
Share fork_inferior et al with gdbserver
[thirdparty/binutils-gdb.git] / gdb / corefile.c
CommitLineData
c906108c 1/* Core dump and executable file functions above target vector, for GDB.
1bac305b 2
61baf725 3 Copyright (C) 1986-2017 Free Software Foundation, Inc.
c906108c 4
c5aa993b 5 This file is part of GDB.
c906108c 6
c5aa993b
JM
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
a9762ec7 9 the Free Software Foundation; either version 3 of the License, or
c5aa993b 10 (at your option) any later version.
c906108c 11
c5aa993b
JM
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
c906108c 16
c5aa993b 17 You should have received a copy of the GNU General Public License
a9762ec7 18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
c906108c
SS
19
20#include "defs.h"
c906108c
SS
21#include <signal.h>
22#include <fcntl.h>
c906108c
SS
23#include "inferior.h"
24#include "symtab.h"
25#include "command.h"
26#include "gdbcmd.h"
27#include "bfd.h"
28#include "target.h"
29#include "gdbcore.h"
30#include "dis-asm.h"
53ce3c39 31#include <sys/stat.h>
d75b5104 32#include "completer.h"
972daa01 33#include "observer.h"
44478ab3 34#include "cli/cli-utils.h"
c906108c 35
c906108c
SS
36/* Local function declarations. */
37
a14ed312 38extern void _initialize_core (void);
c906108c 39
9a4105ab
AC
40/* You can have any number of hooks for `exec_file_command' command to
41 call. If there's only one hook, it is set in exec_file_display
42 hook. If there are two or more hooks, they are set in
43 exec_file_extra_hooks[], and deprecated_exec_file_display_hook is
44 set to a function that calls all of them. This extra complexity is
45 needed to preserve compatibility with old code that assumed that
46 only one hook could be set, and which called
47 deprecated_exec_file_display_hook directly. */
c906108c 48
5f08566b 49typedef void (*hook_type) (const char *);
c906108c 50
aff410f1
MS
51hook_type deprecated_exec_file_display_hook; /* The original hook. */
52static hook_type *exec_file_extra_hooks; /* Array of additional
53 hooks. */
54static int exec_file_hook_count = 0; /* Size of array. */
c906108c
SS
55
56/* Binary file diddling handle for the core file. */
57
58bfd *core_bfd = NULL;
c0edd9ed 59
06b9f45f 60/* corelow.c target. It is never NULL after GDB initialization. */
c0edd9ed
JK
61
62struct target_ops *core_target;
c906108c 63\f
c5aa993b 64
c906108c
SS
65/* Backward compatability with old way of specifying core files. */
66
67void
fba45db2 68core_file_command (char *filename, int from_tty)
c906108c 69{
aff410f1 70 dont_repeat (); /* Either way, seems bogus. */
c906108c 71
06b9f45f 72 gdb_assert (core_target != NULL);
46c6cdcf
C
73
74 if (!filename)
c0edd9ed 75 (core_target->to_detach) (core_target, filename, from_tty);
46c6cdcf 76 else
c0edd9ed 77 (core_target->to_open) (filename, from_tty);
c906108c 78}
c906108c 79\f
c5aa993b 80
de6854b5
MS
81/* If there are two or more functions that wish to hook into
82 exec_file_command, this function will call all of the hook
83 functions. */
c906108c
SS
84
85static void
5f08566b 86call_extra_exec_file_hooks (const char *filename)
c906108c
SS
87{
88 int i;
89
90 for (i = 0; i < exec_file_hook_count; i++)
c5aa993b 91 (*exec_file_extra_hooks[i]) (filename);
c906108c
SS
92}
93
94/* Call this to specify the hook for exec_file_command to call back.
95 This is called from the x-window display code. */
96
97void
5f08566b 98specify_exec_file_hook (void (*hook) (const char *))
c906108c
SS
99{
100 hook_type *new_array;
101
9a4105ab 102 if (deprecated_exec_file_display_hook != NULL)
c906108c
SS
103 {
104 /* There's already a hook installed. Arrange to have both it
aff410f1 105 and the subsequent hooks called. */
c906108c
SS
106 if (exec_file_hook_count == 0)
107 {
aff410f1
MS
108 /* If this is the first extra hook, initialize the hook
109 array. */
8d749320 110 exec_file_extra_hooks = XNEW (hook_type);
9a4105ab
AC
111 exec_file_extra_hooks[0] = deprecated_exec_file_display_hook;
112 deprecated_exec_file_display_hook = call_extra_exec_file_hooks;
c906108c
SS
113 exec_file_hook_count = 1;
114 }
115
116 /* Grow the hook array by one and add the new hook to the end.
117 Yes, it's inefficient to grow it by one each time but since
118 this is hardly ever called it's not a big deal. */
119 exec_file_hook_count++;
aff410f1
MS
120 new_array = (hook_type *)
121 xrealloc (exec_file_extra_hooks,
122 exec_file_hook_count * sizeof (hook_type));
c906108c
SS
123 exec_file_extra_hooks = new_array;
124 exec_file_extra_hooks[exec_file_hook_count - 1] = hook;
125 }
126 else
9a4105ab 127 deprecated_exec_file_display_hook = hook;
c906108c
SS
128}
129
c906108c 130void
fba45db2 131reopen_exec_file (void)
c906108c 132{
c906108c
SS
133 char *filename;
134 int res;
135 struct stat st;
f7545552 136 struct cleanup *cleanups;
c906108c 137
aff410f1 138 /* Don't do anything if there isn't an exec file. */
4c42eaff 139 if (exec_bfd == NULL)
c906108c 140 return;
c5aa993b 141
aff410f1 142 /* If the timestamp of the exec file has changed, reopen it. */
c2d11a7d 143 filename = xstrdup (bfd_get_filename (exec_bfd));
f7545552 144 cleanups = make_cleanup (xfree, filename);
c906108c
SS
145 res = stat (filename, &st);
146
537d9b85 147 if (res == 0 && exec_bfd_mtime && exec_bfd_mtime != st.st_mtime)
4c42eaff 148 exec_file_attach (filename, 0);
939643d7
DJ
149 else
150 /* If we accessed the file since last opening it, close it now;
151 this stops GDB from holding the executable open after it
152 exits. */
153 bfd_cache_close_all ();
f7545552
TT
154
155 do_cleanups (cleanups);
c906108c
SS
156}
157\f
158/* If we have both a core file and an exec file,
159 print a warning if they don't go together. */
160
161void
fba45db2 162validate_files (void)
c906108c
SS
163{
164 if (exec_bfd && core_bfd)
165 {
166 if (!core_file_matches_executable_p (core_bfd, exec_bfd))
8a3fe4f8 167 warning (_("core file may not match specified executable file."));
c5aa993b 168 else if (bfd_get_mtime (exec_bfd) > bfd_get_mtime (core_bfd))
8a3fe4f8 169 warning (_("exec file is newer than core file."));
c906108c
SS
170 }
171}
172
2090129c 173/* See common/common-inferior.h. */
c906108c
SS
174
175char *
fba45db2 176get_exec_file (int err)
c906108c 177{
1f0c4988
JK
178 if (exec_filename)
179 return exec_filename;
c5aa993b
JM
180 if (!err)
181 return NULL;
c906108c 182
8a3fe4f8
AC
183 error (_("No executable file specified.\n\
184Use the \"file\" or \"exec-file\" command."));
c906108c
SS
185 return NULL;
186}
c906108c 187\f
c5aa993b 188
578d3588 189char *
9b409511 190memory_error_message (enum target_xfer_status err,
578d3588 191 struct gdbarch *gdbarch, CORE_ADDR memaddr)
6be7b56e
PA
192{
193 switch (err)
194 {
195 case TARGET_XFER_E_IO:
196 /* Actually, address between memaddr and memaddr + len was out of
197 bounds. */
578d3588
PA
198 return xstrprintf (_("Cannot access memory at address %s"),
199 paddress (gdbarch, memaddr));
bc113b4e 200 case TARGET_XFER_UNAVAILABLE:
578d3588
PA
201 return xstrprintf (_("Memory at address %s unavailable."),
202 paddress (gdbarch, memaddr));
6be7b56e
PA
203 default:
204 internal_error (__FILE__, __LINE__,
9b409511
YQ
205 "unhandled target_xfer_status: %s (%s)",
206 target_xfer_status_to_string (err),
6be7b56e
PA
207 plongest (err));
208 }
209}
210
578d3588 211/* Report a memory error by throwing a suitable exception. */
c906108c
SS
212
213void
9b409511 214memory_error (enum target_xfer_status err, CORE_ADDR memaddr)
c906108c 215{
578d3588 216 char *str;
8635b3bf 217 enum errors exception = GDB_NO_ERROR;
578d3588
PA
218
219 /* Build error string. */
220 str = memory_error_message (err, target_gdbarch (), memaddr);
221 make_cleanup (xfree, str);
222
223 /* Choose the right error to throw. */
224 switch (err)
225 {
226 case TARGET_XFER_E_IO:
8635b3bf 227 exception = MEMORY_ERROR;
578d3588 228 break;
bc113b4e 229 case TARGET_XFER_UNAVAILABLE:
8635b3bf 230 exception = NOT_AVAILABLE_ERROR;
578d3588
PA
231 break;
232 }
233
234 /* Throw it. */
8635b3bf 235 throw_error (exception, ("%s"), str);
c906108c
SS
236}
237
edf689f0 238/* Helper function. */
4e5d721f 239
edf689f0
YQ
240static void
241read_memory_object (enum target_object object, CORE_ADDR memaddr,
242 gdb_byte *myaddr, ssize_t len)
c906108c 243{
9b409511 244 ULONGEST xfered = 0;
c5504eaf 245
6be7b56e
PA
246 while (xfered < len)
247 {
9b409511
YQ
248 enum target_xfer_status status;
249 ULONGEST xfered_len;
6be7b56e 250
9b409511 251 status = target_xfer_partial (current_target.beneath,
edf689f0 252 object, NULL,
9b409511
YQ
253 myaddr + xfered, NULL,
254 memaddr + xfered, len - xfered,
255 &xfered_len);
256
5c328c05
YQ
257 if (status != TARGET_XFER_OK)
258 memory_error (status == TARGET_XFER_EOF ? TARGET_XFER_E_IO : status,
259 memaddr + xfered);
9b409511 260
9b409511 261 xfered += xfered_len;
6be7b56e
PA
262 QUIT;
263 }
c906108c
SS
264}
265
edf689f0
YQ
266/* Same as target_read_memory, but report an error if can't read. */
267
268void
269read_memory (CORE_ADDR memaddr, gdb_byte *myaddr, ssize_t len)
270{
271 read_memory_object (TARGET_OBJECT_MEMORY, memaddr, myaddr, len);
272}
273
4e5d721f
DE
274/* Same as target_read_stack, but report an error if can't read. */
275
276void
45aa4659 277read_stack (CORE_ADDR memaddr, gdb_byte *myaddr, ssize_t len)
4e5d721f 278{
edf689f0 279 read_memory_object (TARGET_OBJECT_STACK_MEMORY, memaddr, myaddr, len);
4e5d721f
DE
280}
281
0865b04a
YQ
282/* Same as target_read_code, but report an error if can't read. */
283
284void
285read_code (CORE_ADDR memaddr, gdb_byte *myaddr, ssize_t len)
286{
edf689f0 287 read_memory_object (TARGET_OBJECT_CODE_MEMORY, memaddr, myaddr, len);
0865b04a
YQ
288}
289
ee8ff470
KB
290/* Read memory at MEMADDR of length LEN and put the contents in
291 RETURN_VALUE. Return 0 if MEMADDR couldn't be read and non-zero
292 if successful. */
293
16a0f3e7 294int
c5504eaf
MS
295safe_read_memory_integer (CORE_ADDR memaddr, int len,
296 enum bfd_endian byte_order,
e17a4113 297 LONGEST *return_value)
16a0f3e7 298{
5e43d467 299 gdb_byte buf[sizeof (LONGEST)];
16a0f3e7 300
5e43d467
UW
301 if (target_read_memory (memaddr, buf, len))
302 return 0;
16a0f3e7 303
5e43d467
UW
304 *return_value = extract_signed_integer (buf, len, byte_order);
305 return 1;
16a0f3e7
EZ
306}
307
cc2c4da8
MK
308/* Read memory at MEMADDR of length LEN and put the contents in
309 RETURN_VALUE. Return 0 if MEMADDR couldn't be read and non-zero
310 if successful. */
311
312int
313safe_read_memory_unsigned_integer (CORE_ADDR memaddr, int len,
314 enum bfd_endian byte_order,
315 ULONGEST *return_value)
316{
317 gdb_byte buf[sizeof (ULONGEST)];
318
319 if (target_read_memory (memaddr, buf, len))
320 return 0;
321
322 *return_value = extract_unsigned_integer (buf, len, byte_order);
323 return 1;
324}
325
c906108c 326LONGEST
aff410f1
MS
327read_memory_integer (CORE_ADDR memaddr, int len,
328 enum bfd_endian byte_order)
c906108c 329{
dfb65433 330 gdb_byte buf[sizeof (LONGEST)];
c906108c
SS
331
332 read_memory (memaddr, buf, len);
e17a4113 333 return extract_signed_integer (buf, len, byte_order);
c906108c
SS
334}
335
336ULONGEST
aff410f1
MS
337read_memory_unsigned_integer (CORE_ADDR memaddr, int len,
338 enum bfd_endian byte_order)
c906108c 339{
dfb65433 340 gdb_byte buf[sizeof (ULONGEST)];
c906108c
SS
341
342 read_memory (memaddr, buf, len);
e17a4113 343 return extract_unsigned_integer (buf, len, byte_order);
c906108c
SS
344}
345
0865b04a
YQ
346LONGEST
347read_code_integer (CORE_ADDR memaddr, int len,
348 enum bfd_endian byte_order)
349{
350 gdb_byte buf[sizeof (LONGEST)];
351
352 read_code (memaddr, buf, len);
353 return extract_signed_integer (buf, len, byte_order);
354}
355
356ULONGEST
357read_code_unsigned_integer (CORE_ADDR memaddr, int len,
358 enum bfd_endian byte_order)
359{
360 gdb_byte buf[sizeof (ULONGEST)];
361
362 read_code (memaddr, buf, len);
363 return extract_unsigned_integer (buf, len, byte_order);
364}
365
c906108c 366void
fba45db2 367read_memory_string (CORE_ADDR memaddr, char *buffer, int max_len)
c906108c 368{
52f0bd74
AC
369 char *cp;
370 int i;
c906108c
SS
371 int cnt;
372
373 cp = buffer;
374 while (1)
375 {
376 if (cp - buffer >= max_len)
c5aa993b
JM
377 {
378 buffer[max_len - 1] = '\0';
379 break;
380 }
c906108c
SS
381 cnt = max_len - (cp - buffer);
382 if (cnt > 8)
383 cnt = 8;
c8af03a2 384 read_memory (memaddr + (int) (cp - buffer), (gdb_byte *) cp, cnt);
c906108c 385 for (i = 0; i < cnt && *cp; i++, cp++)
c5aa993b 386 ; /* null body */
c906108c
SS
387
388 if (i < cnt && !*cp)
c5aa993b 389 break;
c906108c
SS
390 }
391}
c26e4683 392
0d540cdf
KD
393CORE_ADDR
394read_memory_typed_address (CORE_ADDR addr, struct type *type)
395{
224c3ddb 396 gdb_byte *buf = (gdb_byte *) alloca (TYPE_LENGTH (type));
c5504eaf 397
0d540cdf
KD
398 read_memory (addr, buf, TYPE_LENGTH (type));
399 return extract_typed_address (buf, type);
400}
401
cb6f16cf
SM
402/* See gdbcore.h. */
403
c26e4683 404void
aff410f1 405write_memory (CORE_ADDR memaddr,
45aa4659 406 const bfd_byte *myaddr, ssize_t len)
c26e4683
JB
407{
408 int status;
c5504eaf 409
00630ca8 410 status = target_write_memory (memaddr, myaddr, len);
c26e4683 411 if (status != 0)
d09f2c3f 412 memory_error (TARGET_XFER_E_IO, memaddr);
c26e4683
JB
413}
414
972daa01
YQ
415/* Same as write_memory, but notify 'memory_changed' observers. */
416
417void
418write_memory_with_notification (CORE_ADDR memaddr, const bfd_byte *myaddr,
419 ssize_t len)
420{
421 write_memory (memaddr, myaddr, len);
8de0566d 422 observer_notify_memory_changed (current_inferior (), memaddr, len, myaddr);
972daa01
YQ
423}
424
aff410f1
MS
425/* Store VALUE at ADDR in the inferior as a LEN-byte unsigned
426 integer. */
c26e4683 427void
c5504eaf
MS
428write_memory_unsigned_integer (CORE_ADDR addr, int len,
429 enum bfd_endian byte_order,
e17a4113 430 ULONGEST value)
c26e4683 431{
224c3ddb 432 gdb_byte *buf = (gdb_byte *) alloca (len);
c5504eaf 433
e17a4113 434 store_unsigned_integer (buf, len, byte_order, value);
c26e4683
JB
435 write_memory (addr, buf, len);
436}
437
aff410f1
MS
438/* Store VALUE at ADDR in the inferior as a LEN-byte signed
439 integer. */
c26e4683 440void
c5504eaf
MS
441write_memory_signed_integer (CORE_ADDR addr, int len,
442 enum bfd_endian byte_order,
e17a4113 443 LONGEST value)
c26e4683 444{
224c3ddb 445 gdb_byte *buf = (gdb_byte *) alloca (len);
c5504eaf 446
e17a4113 447 store_signed_integer (buf, len, byte_order, value);
c26e4683
JB
448 write_memory (addr, buf, len);
449}
c906108c
SS
450\f
451/* The current default bfd target. Points to storage allocated for
452 gnutarget_string. */
453char *gnutarget;
454
455/* Same thing, except it is "auto" not NULL for the default case. */
456static char *gnutarget_string;
920d2a44
AC
457static void
458show_gnutarget_string (struct ui_file *file, int from_tty,
aff410f1
MS
459 struct cmd_list_element *c,
460 const char *value)
920d2a44 461{
aff410f1
MS
462 fprintf_filtered (file,
463 _("The current BFD target is \"%s\".\n"), value);
920d2a44 464}
c906108c 465
aff410f1
MS
466static void set_gnutarget_command (char *, int,
467 struct cmd_list_element *);
c906108c
SS
468
469static void
aff410f1
MS
470set_gnutarget_command (char *ignore, int from_tty,
471 struct cmd_list_element *c)
c906108c 472{
44478ab3
TT
473 char *gend = gnutarget_string + strlen (gnutarget_string);
474
475 gend = remove_trailing_whitespace (gnutarget_string, gend);
476 *gend = '\0';
477
bde58177 478 if (strcmp (gnutarget_string, "auto") == 0)
c906108c
SS
479 gnutarget = NULL;
480 else
481 gnutarget = gnutarget_string;
482}
483
44478ab3
TT
484/* A completion function for "set gnutarget". */
485
486static VEC (char_ptr) *
6f937416
PA
487complete_set_gnutarget (struct cmd_list_element *cmd,
488 const char *text, const char *word)
44478ab3
TT
489{
490 static const char **bfd_targets;
491
492 if (bfd_targets == NULL)
493 {
494 int last;
495
496 bfd_targets = bfd_target_list ();
497 for (last = 0; bfd_targets[last] != NULL; ++last)
498 ;
499
224c3ddb 500 bfd_targets = XRESIZEVEC (const char *, bfd_targets, last + 2);
44478ab3
TT
501 bfd_targets[last] = "auto";
502 bfd_targets[last + 1] = NULL;
503 }
504
505 return complete_on_enum (bfd_targets, text, word);
506}
507
c906108c
SS
508/* Set the gnutarget. */
509void
a121b7c1 510set_gnutarget (const char *newtarget)
c906108c
SS
511{
512 if (gnutarget_string != NULL)
b8c9b27d 513 xfree (gnutarget_string);
1b36a34b 514 gnutarget_string = xstrdup (newtarget);
c906108c
SS
515 set_gnutarget_command (NULL, 0, NULL);
516}
517
518void
fba45db2 519_initialize_core (void)
c906108c
SS
520{
521 struct cmd_list_element *c;
c5504eaf 522
1a966eab
AC
523 c = add_cmd ("core-file", class_files, core_file_command, _("\
524Use FILE as core dump for examining memory and registers.\n\
c906108c 525No arg means have no core file. This command has been superseded by the\n\
1a966eab 526`target core' and `detach' commands."), &cmdlist);
5ba2abeb 527 set_cmd_completer (c, filename_completer);
c906108c 528
26c41df3 529
44478ab3
TT
530 c = add_setshow_string_noescape_cmd ("gnutarget", class_files,
531 &gnutarget_string, _("\
26c41df3
AC
532Set the current BFD target."), _("\
533Show the current BFD target."), _("\
534Use `set gnutarget auto' to specify automatic detection."),
44478ab3
TT
535 set_gnutarget_command,
536 show_gnutarget_string,
537 &setlist, &showlist);
538 set_cmd_completer (c, complete_set_gnutarget);
539
7e20dfcd 540 add_alias_cmd ("g", "gnutarget", class_files, 1, &setlist);
c906108c
SS
541
542 if (getenv ("GNUTARGET"))
543 set_gnutarget (getenv ("GNUTARGET"));
544 else
545 set_gnutarget ("auto");
546}