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