Fix solib-display.exp remote check
[deliverable/binutils-gdb.git] / gdb / corefile.c
CommitLineData
c906108c 1/* Core dump and executable file functions above target vector, for GDB.
1bac305b 2
618f726f 3 Copyright (C) 1986-2016 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
c04ea773 147 if (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
173/* Return the name of the executable file as a string.
174 ERR nonzero means get error if there is none specified;
175 otherwise return 0 in that case. */
176
177char *
fba45db2 178get_exec_file (int err)
c906108c 179{
1f0c4988
JK
180 if (exec_filename)
181 return exec_filename;
c5aa993b
JM
182 if (!err)
183 return NULL;
c906108c 184
8a3fe4f8
AC
185 error (_("No executable file specified.\n\
186Use the \"file\" or \"exec-file\" command."));
c906108c
SS
187 return NULL;
188}
c906108c 189\f
c5aa993b 190
578d3588 191char *
9b409511 192memory_error_message (enum target_xfer_status err,
578d3588 193 struct gdbarch *gdbarch, CORE_ADDR memaddr)
6be7b56e
PA
194{
195 switch (err)
196 {
197 case TARGET_XFER_E_IO:
198 /* Actually, address between memaddr and memaddr + len was out of
199 bounds. */
578d3588
PA
200 return xstrprintf (_("Cannot access memory at address %s"),
201 paddress (gdbarch, memaddr));
bc113b4e 202 case TARGET_XFER_UNAVAILABLE:
578d3588
PA
203 return xstrprintf (_("Memory at address %s unavailable."),
204 paddress (gdbarch, memaddr));
6be7b56e
PA
205 default:
206 internal_error (__FILE__, __LINE__,
9b409511
YQ
207 "unhandled target_xfer_status: %s (%s)",
208 target_xfer_status_to_string (err),
6be7b56e
PA
209 plongest (err));
210 }
211}
212
578d3588 213/* Report a memory error by throwing a suitable exception. */
c906108c
SS
214
215void
9b409511 216memory_error (enum target_xfer_status err, CORE_ADDR memaddr)
c906108c 217{
578d3588 218 char *str;
8635b3bf 219 enum errors exception = GDB_NO_ERROR;
578d3588
PA
220
221 /* Build error string. */
222 str = memory_error_message (err, target_gdbarch (), memaddr);
223 make_cleanup (xfree, str);
224
225 /* Choose the right error to throw. */
226 switch (err)
227 {
228 case TARGET_XFER_E_IO:
8635b3bf 229 exception = MEMORY_ERROR;
578d3588 230 break;
bc113b4e 231 case TARGET_XFER_UNAVAILABLE:
8635b3bf 232 exception = NOT_AVAILABLE_ERROR;
578d3588
PA
233 break;
234 }
235
236 /* Throw it. */
8635b3bf 237 throw_error (exception, ("%s"), str);
c906108c
SS
238}
239
240/* Same as target_read_memory, but report an error if can't read. */
4e5d721f 241
c906108c 242void
45aa4659 243read_memory (CORE_ADDR memaddr, gdb_byte *myaddr, ssize_t len)
c906108c 244{
9b409511 245 ULONGEST xfered = 0;
c5504eaf 246
6be7b56e
PA
247 while (xfered < len)
248 {
9b409511
YQ
249 enum target_xfer_status status;
250 ULONGEST xfered_len;
6be7b56e 251
9b409511
YQ
252 status = target_xfer_partial (current_target.beneath,
253 TARGET_OBJECT_MEMORY, NULL,
254 myaddr + xfered, NULL,
255 memaddr + xfered, len - xfered,
256 &xfered_len);
257
5c328c05
YQ
258 if (status != TARGET_XFER_OK)
259 memory_error (status == TARGET_XFER_EOF ? TARGET_XFER_E_IO : status,
260 memaddr + xfered);
9b409511 261
9b409511 262 xfered += xfered_len;
6be7b56e
PA
263 QUIT;
264 }
c906108c
SS
265}
266
4e5d721f
DE
267/* Same as target_read_stack, but report an error if can't read. */
268
269void
45aa4659 270read_stack (CORE_ADDR memaddr, gdb_byte *myaddr, ssize_t len)
4e5d721f
DE
271{
272 int status;
c5504eaf 273
4e5d721f
DE
274 status = target_read_stack (memaddr, myaddr, len);
275 if (status != 0)
d09f2c3f 276 memory_error (TARGET_XFER_E_IO, memaddr);
4e5d721f
DE
277}
278
0865b04a
YQ
279/* Same as target_read_code, but report an error if can't read. */
280
281void
282read_code (CORE_ADDR memaddr, gdb_byte *myaddr, ssize_t len)
283{
284 int status;
285
286 status = target_read_code (memaddr, myaddr, len);
287 if (status != 0)
d09f2c3f 288 memory_error (TARGET_XFER_E_IO, memaddr);
0865b04a
YQ
289}
290
ee8ff470
KB
291/* Read memory at MEMADDR of length LEN and put the contents in
292 RETURN_VALUE. Return 0 if MEMADDR couldn't be read and non-zero
293 if successful. */
294
16a0f3e7 295int
c5504eaf
MS
296safe_read_memory_integer (CORE_ADDR memaddr, int len,
297 enum bfd_endian byte_order,
e17a4113 298 LONGEST *return_value)
16a0f3e7 299{
5e43d467 300 gdb_byte buf[sizeof (LONGEST)];
16a0f3e7 301
5e43d467
UW
302 if (target_read_memory (memaddr, buf, len))
303 return 0;
16a0f3e7 304
5e43d467
UW
305 *return_value = extract_signed_integer (buf, len, byte_order);
306 return 1;
16a0f3e7
EZ
307}
308
cc2c4da8
MK
309/* Read memory at MEMADDR of length LEN and put the contents in
310 RETURN_VALUE. Return 0 if MEMADDR couldn't be read and non-zero
311 if successful. */
312
313int
314safe_read_memory_unsigned_integer (CORE_ADDR memaddr, int len,
315 enum bfd_endian byte_order,
316 ULONGEST *return_value)
317{
318 gdb_byte buf[sizeof (ULONGEST)];
319
320 if (target_read_memory (memaddr, buf, len))
321 return 0;
322
323 *return_value = extract_unsigned_integer (buf, len, byte_order);
324 return 1;
325}
326
c906108c 327LONGEST
aff410f1
MS
328read_memory_integer (CORE_ADDR memaddr, int len,
329 enum bfd_endian byte_order)
c906108c 330{
dfb65433 331 gdb_byte buf[sizeof (LONGEST)];
c906108c
SS
332
333 read_memory (memaddr, buf, len);
e17a4113 334 return extract_signed_integer (buf, len, byte_order);
c906108c
SS
335}
336
337ULONGEST
aff410f1
MS
338read_memory_unsigned_integer (CORE_ADDR memaddr, int len,
339 enum bfd_endian byte_order)
c906108c 340{
dfb65433 341 gdb_byte buf[sizeof (ULONGEST)];
c906108c
SS
342
343 read_memory (memaddr, buf, len);
e17a4113 344 return extract_unsigned_integer (buf, len, byte_order);
c906108c
SS
345}
346
0865b04a
YQ
347LONGEST
348read_code_integer (CORE_ADDR memaddr, int len,
349 enum bfd_endian byte_order)
350{
351 gdb_byte buf[sizeof (LONGEST)];
352
353 read_code (memaddr, buf, len);
354 return extract_signed_integer (buf, len, byte_order);
355}
356
357ULONGEST
358read_code_unsigned_integer (CORE_ADDR memaddr, int len,
359 enum bfd_endian byte_order)
360{
361 gdb_byte buf[sizeof (ULONGEST)];
362
363 read_code (memaddr, buf, len);
364 return extract_unsigned_integer (buf, len, byte_order);
365}
366
c906108c 367void
fba45db2 368read_memory_string (CORE_ADDR memaddr, char *buffer, int max_len)
c906108c 369{
52f0bd74
AC
370 char *cp;
371 int i;
c906108c
SS
372 int cnt;
373
374 cp = buffer;
375 while (1)
376 {
377 if (cp - buffer >= max_len)
c5aa993b
JM
378 {
379 buffer[max_len - 1] = '\0';
380 break;
381 }
c906108c
SS
382 cnt = max_len - (cp - buffer);
383 if (cnt > 8)
384 cnt = 8;
c8af03a2 385 read_memory (memaddr + (int) (cp - buffer), (gdb_byte *) cp, cnt);
c906108c 386 for (i = 0; i < cnt && *cp; i++, cp++)
c5aa993b 387 ; /* null body */
c906108c
SS
388
389 if (i < cnt && !*cp)
c5aa993b 390 break;
c906108c
SS
391 }
392}
c26e4683 393
0d540cdf
KD
394CORE_ADDR
395read_memory_typed_address (CORE_ADDR addr, struct type *type)
396{
224c3ddb 397 gdb_byte *buf = (gdb_byte *) alloca (TYPE_LENGTH (type));
c5504eaf 398
0d540cdf
KD
399 read_memory (addr, buf, TYPE_LENGTH (type));
400 return extract_typed_address (buf, type);
401}
402
cb6f16cf
SM
403/* See gdbcore.h. */
404
c26e4683 405void
aff410f1 406write_memory (CORE_ADDR memaddr,
45aa4659 407 const bfd_byte *myaddr, ssize_t len)
c26e4683
JB
408{
409 int status;
c5504eaf 410
00630ca8 411 status = target_write_memory (memaddr, myaddr, len);
c26e4683 412 if (status != 0)
d09f2c3f 413 memory_error (TARGET_XFER_E_IO, memaddr);
c26e4683
JB
414}
415
972daa01
YQ
416/* Same as write_memory, but notify 'memory_changed' observers. */
417
418void
419write_memory_with_notification (CORE_ADDR memaddr, const bfd_byte *myaddr,
420 ssize_t len)
421{
422 write_memory (memaddr, myaddr, len);
8de0566d 423 observer_notify_memory_changed (current_inferior (), memaddr, len, myaddr);
972daa01
YQ
424}
425
aff410f1
MS
426/* Store VALUE at ADDR in the inferior as a LEN-byte unsigned
427 integer. */
c26e4683 428void
c5504eaf
MS
429write_memory_unsigned_integer (CORE_ADDR addr, int len,
430 enum bfd_endian byte_order,
e17a4113 431 ULONGEST value)
c26e4683 432{
224c3ddb 433 gdb_byte *buf = (gdb_byte *) alloca (len);
c5504eaf 434
e17a4113 435 store_unsigned_integer (buf, len, byte_order, value);
c26e4683
JB
436 write_memory (addr, buf, len);
437}
438
aff410f1
MS
439/* Store VALUE at ADDR in the inferior as a LEN-byte signed
440 integer. */
c26e4683 441void
c5504eaf
MS
442write_memory_signed_integer (CORE_ADDR addr, int len,
443 enum bfd_endian byte_order,
e17a4113 444 LONGEST value)
c26e4683 445{
224c3ddb 446 gdb_byte *buf = (gdb_byte *) alloca (len);
c5504eaf 447
e17a4113 448 store_signed_integer (buf, len, byte_order, value);
c26e4683
JB
449 write_memory (addr, buf, len);
450}
c906108c
SS
451\f
452/* The current default bfd target. Points to storage allocated for
453 gnutarget_string. */
454char *gnutarget;
455
456/* Same thing, except it is "auto" not NULL for the default case. */
457static char *gnutarget_string;
920d2a44
AC
458static void
459show_gnutarget_string (struct ui_file *file, int from_tty,
aff410f1
MS
460 struct cmd_list_element *c,
461 const char *value)
920d2a44 462{
aff410f1
MS
463 fprintf_filtered (file,
464 _("The current BFD target is \"%s\".\n"), value);
920d2a44 465}
c906108c 466
aff410f1
MS
467static void set_gnutarget_command (char *, int,
468 struct cmd_list_element *);
c906108c
SS
469
470static void
aff410f1
MS
471set_gnutarget_command (char *ignore, int from_tty,
472 struct cmd_list_element *c)
c906108c 473{
44478ab3
TT
474 char *gend = gnutarget_string + strlen (gnutarget_string);
475
476 gend = remove_trailing_whitespace (gnutarget_string, gend);
477 *gend = '\0';
478
bde58177 479 if (strcmp (gnutarget_string, "auto") == 0)
c906108c
SS
480 gnutarget = NULL;
481 else
482 gnutarget = gnutarget_string;
483}
484
44478ab3
TT
485/* A completion function for "set gnutarget". */
486
487static VEC (char_ptr) *
6f937416
PA
488complete_set_gnutarget (struct cmd_list_element *cmd,
489 const char *text, const char *word)
44478ab3
TT
490{
491 static const char **bfd_targets;
492
493 if (bfd_targets == NULL)
494 {
495 int last;
496
497 bfd_targets = bfd_target_list ();
498 for (last = 0; bfd_targets[last] != NULL; ++last)
499 ;
500
224c3ddb 501 bfd_targets = XRESIZEVEC (const char *, bfd_targets, last + 2);
44478ab3
TT
502 bfd_targets[last] = "auto";
503 bfd_targets[last + 1] = NULL;
504 }
505
506 return complete_on_enum (bfd_targets, text, word);
507}
508
c906108c
SS
509/* Set the gnutarget. */
510void
fba45db2 511set_gnutarget (char *newtarget)
c906108c
SS
512{
513 if (gnutarget_string != NULL)
b8c9b27d 514 xfree (gnutarget_string);
1b36a34b 515 gnutarget_string = xstrdup (newtarget);
c906108c
SS
516 set_gnutarget_command (NULL, 0, NULL);
517}
518
519void
fba45db2 520_initialize_core (void)
c906108c
SS
521{
522 struct cmd_list_element *c;
c5504eaf 523
1a966eab
AC
524 c = add_cmd ("core-file", class_files, core_file_command, _("\
525Use FILE as core dump for examining memory and registers.\n\
c906108c 526No arg means have no core file. This command has been superseded by the\n\
1a966eab 527`target core' and `detach' commands."), &cmdlist);
5ba2abeb 528 set_cmd_completer (c, filename_completer);
c906108c 529
26c41df3 530
44478ab3
TT
531 c = add_setshow_string_noescape_cmd ("gnutarget", class_files,
532 &gnutarget_string, _("\
26c41df3
AC
533Set the current BFD target."), _("\
534Show the current BFD target."), _("\
535Use `set gnutarget auto' to specify automatic detection."),
44478ab3
TT
536 set_gnutarget_command,
537 show_gnutarget_string,
538 &setlist, &showlist);
539 set_cmd_completer (c, complete_set_gnutarget);
540
7e20dfcd 541 add_alias_cmd ("g", "gnutarget", class_files, 1, &setlist);
c906108c
SS
542
543 if (getenv ("GNUTARGET"))
544 set_gnutarget (getenv ("GNUTARGET"));
545 else
546 set_gnutarget ("auto");
547}
This page took 1.193328 seconds and 4 git commands to generate.