]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gdb/defs.h
Update copyright year range in all GDB files
[thirdparty/binutils-gdb.git] / gdb / defs.h
CommitLineData
a0b31db1
JK
1/* *INDENT-OFF* */ /* ATTRIBUTE_PRINTF confuses indent, avoid running it
2 for now. */
c906108c 3/* Basic, host-specific, and target-specific definitions for GDB.
e2882c85 4 Copyright (C) 1986-2018 Free Software Foundation, Inc.
c906108c 5
c5aa993b 6 This file is part of GDB.
c906108c 7
c5aa993b
JM
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
a9762ec7 10 the Free Software Foundation; either version 3 of the License, or
c5aa993b 11 (at your option) any later version.
c906108c 12
c5aa993b
JM
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.
c906108c 17
c5aa993b 18 You should have received a copy of the GNU General Public License
a9762ec7 19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
c906108c
SS
20
21#ifndef DEFS_H
22#define DEFS_H
23
d26e3629
KY
24#ifdef GDBSERVER
25# error gdbserver should not include gdb/defs.h
26#endif
27
976411d6 28#include "common-defs.h"
975ac915 29
8b04f8b6 30#include <sys/types.h>
c906108c
SS
31#include <limits.h>
32
06e476f5
JB
33/* The libdecnumber library, on which GDB depends, includes a header file
34 called gstdint.h instead of relying directly on stdint.h. GDB, on the
35 other hand, includes stdint.h directly, relying on the fact that gnulib
36 generates a copy if the system doesn't provide one or if it is missing
37 some features. Unfortunately, gstdint.h and stdint.h cannot be included
38 at the same time, which may happen when we include a file from
39 libdecnumber.
40
41 The following macro definition effectively prevents the inclusion of
42 gstdint.h, as all the definitions it provides are guarded against
43 the GCC_GENERATED_STDINT_H macro. We already have gnulib/stdint.h
44 included, so it's ok to blank out gstdint.h. */
45#define GCC_GENERATED_STDINT_H 1
46
104c1213 47#include <unistd.h>
d8d2a3ee 48
637d6690
CW
49#include <fcntl.h>
50
6c7a06a3
TT
51#include "gdb_wchar.h"
52
48faced0
DE
53#include "ui-file.h"
54
55#include "host-defs.h"
4034d0ff 56#include "common/enum-flags.h"
48faced0 57
bb2ec1b3
TT
58/* Scope types enumerator. List the types of scopes the compiler will
59 accept. */
60
61enum compile_i_scope_types
62 {
63 COMPILE_I_INVALID_SCOPE,
64
65 /* A simple scope. Wrap an expression into a simple scope that
66 takes no arguments, returns no value, and uses the generic
67 function name "_gdb_expr". */
68
69 COMPILE_I_SIMPLE_SCOPE,
70
71 /* Do not wrap the expression,
72 it has to provide function "_gdb_expr" on its own. */
73 COMPILE_I_RAW_SCOPE,
36de76f9
JK
74
75 /* A printable expression scope. Wrap an expression into a scope
76 suitable for the "compile print" command. It uses the generic
77 function name "_gdb_expr". COMPILE_I_PRINT_ADDRESS_SCOPE variant
78 is the usual one, taking address of the object.
79 COMPILE_I_PRINT_VALUE_SCOPE is needed for arrays where the array
80 name already specifies its address. See get_out_value_type. */
81 COMPILE_I_PRINT_ADDRESS_SCOPE,
82 COMPILE_I_PRINT_VALUE_SCOPE,
bb2ec1b3
TT
83 };
84
6f98355c
YQ
85
86template<typename T>
87using RequireLongest = gdb::Requires<gdb::Or<std::is_same<T, LONGEST>,
88 std::is_same<T, ULONGEST>>>;
89
975ac915 90/* Just in case they're not defined in stdio.h. */
c906108c
SS
91
92#ifndef SEEK_SET
93#define SEEK_SET 0
94#endif
95#ifndef SEEK_CUR
96#define SEEK_CUR 1
97#endif
98
637d6690
CW
99/* The O_BINARY flag is defined in fcntl.h on some non-Posix platforms.
100 It is used as an access modifier in calls to open(), where it acts
0963b4bd
MS
101 similarly to the "b" character in fopen()'s MODE argument. On Posix
102 platforms it should be a no-op, so it is defined as 0 here. This
103 ensures that the symbol may be used freely elsewhere in gdb. */
637d6690
CW
104
105#ifndef O_BINARY
106#define O_BINARY 0
107#endif
108
8e3b41a9 109#include "hashtab.h"
c906108c 110
a8b16220 111/* * Enable dbx commands if set. */
c906108c
SS
112extern int dbx_commands;
113
a8b16220 114/* * System root path, used to find libraries etc. */
030292b7
DJ
115extern char *gdb_sysroot;
116
a8b16220 117/* * GDB datadir, used to store data files. */
b14b1491
TT
118extern char *gdb_datadir;
119
a8b16220 120/* * If non-NULL, the possibly relocated path to python's "lib" directory
0c4a4063
DE
121 specified with --with-python. */
122extern char *python_libdir;
123
a8b16220 124/* * Search path for separate debug files. */
aa28a74e
DJ
125extern char *debug_file_directory;
126
585a46a2
PA
127/* GDB's SIGINT handler basically sets a flag; code that might take a
128 long time before it gets back to the event loop, and which ought to
129 be interruptible, checks this flag using the QUIT macro, which, if
130 GDB has the terminal, throws a quit exception.
522002f9 131
f0881b37
PA
132 In addition to setting a flag, the SIGINT handler also marks a
133 select/poll-able file descriptor as read-ready. That is used by
134 interruptible_select in order to support interrupting blocking I/O
135 in a race-free manner.
136
6dddc817
DE
137 These functions use the extension_language_ops API to allow extension
138 language(s) and GDB SIGINT handling to coexist seamlessly. */
522002f9 139
a8b16220 140/* * Evaluate to non-zero if the quit flag is set, zero otherwise. This
522002f9
TT
141 will clear the quit flag as a side effect. */
142extern int check_quit_flag (void);
a8b16220 143/* * Set the quit flag. */
522002f9
TT
144extern void set_quit_flag (void);
145
048094ac
PA
146/* The current quit handler (and its type). This is called from the
147 QUIT macro. See default_quit_handler below for default behavior.
148 Parts of GDB temporarily override this to e.g., completely suppress
149 Ctrl-C because it would not be safe to throw. E.g., normally, you
150 wouldn't want to quit between a RSP command and its response, as
151 that would break the communication with the target, but you may
152 still want to intercept the Ctrl-C and offer to disconnect if the
153 user presses Ctrl-C multiple times while the target is stuck
154 waiting for the wedged remote stub. */
155typedef void (quit_handler_ftype) (void);
156extern quit_handler_ftype *quit_handler;
157
048094ac
PA
158/* The default quit handler. Checks whether Ctrl-C was pressed, and
159 if so:
160
161 - If GDB owns the terminal, throws a quit exception.
162
163 - If GDB does not own the terminal, forwards the Ctrl-C to the
164 target.
165*/
166extern void default_quit_handler (void);
167
06c868a8
JK
168/* Flag that function quit should call quit_force. */
169extern volatile int sync_quit_force_run;
170
917317f4 171extern void quit (void);
c906108c 172
abc56d60
PA
173/* Helper for the QUIT macro. */
174
175extern void maybe_quit (void);
176
048094ac
PA
177/* Check whether a Ctrl-C was typed, and if so, call the current quit
178 handler. */
abc56d60 179#define QUIT maybe_quit ()
c906108c 180
f0881b37
PA
181/* Set the serial event associated with the quit flag. */
182extern void quit_serial_event_set (void);
183
184/* Clear the serial event associated with the quit flag. */
185extern void quit_serial_event_clear (void);
186
a8b16220 187/* * Languages represented in the symbol table and elsewhere.
c906108c
SS
188 This should probably be in language.h, but since enum's can't
189 be forward declared to satisfy opaque references before their
8b302db8
TT
190 actual definition, needs to be here.
191
192 The constants here are in priority order. In particular,
193 demangling is attempted according to this order.
194
195 Note that there's ambiguity between the mangling schemes of some of
196 these languages, so some symbols could be successfully demangled by
197 several languages. For that reason, the constants here are sorted
9c37b5ae
TT
198 in the order we'll attempt demangling them. For example: Rust uses
199 C++ mangling, so must come after C++; Ada must come last (see
47e77640
PA
200 ada_sniff_from_mangled_name). (Keep this order in sync with the
201 'languages' array in language.c.) */
c906108c 202
917317f4
JM
203enum language
204 {
205 language_unknown, /* Language not known */
206 language_auto, /* Placeholder for automatic setting */
207 language_c, /* C */
8b302db8 208 language_objc, /* Objective-C */
917317f4 209 language_cplus, /* C++ */
6aecb9c2 210 language_d, /* D */
a766d390 211 language_go, /* Go */
917317f4
JM
212 language_fortran, /* Fortran */
213 language_m2, /* Modula-2 */
214 language_asm, /* Assembly language */
20a0e81d 215 language_pascal, /* Pascal */
f4b8a18d 216 language_opencl, /* OpenCL */
c44af4eb 217 language_rust, /* Rust */
f290d38e 218 language_minimal, /* All other languages, minimal support only */
8b302db8 219 language_ada, /* Ada */
f290d38e 220 nr_languages
917317f4 221 };
c906108c 222
51cdc993
DE
223/* The number of bits needed to represent all languages, with enough
224 padding to allow for reasonable growth. */
225#define LANGUAGE_BITS 5
226gdb_static_assert (nr_languages <= (1 << LANGUAGE_BITS));
227
c906108c 228enum precision_type
917317f4
JM
229 {
230 single_precision,
231 double_precision,
232 unspecified_precision
233 };
234
a8b16220
SS
235/* * A generic, not quite boolean, enumeration. This is used for
236 set/show commands in which the options are on/off/automatic. */
7f19b9a2
AC
237enum auto_boolean
238{
239 AUTO_BOOLEAN_TRUE,
240 AUTO_BOOLEAN_FALSE,
241 AUTO_BOOLEAN_AUTO
242};
243
a8b16220
SS
244/* * Potential ways that a function can return a value of a given
245 type. */
246
92ad9cd9
AC
247enum return_value_convention
248{
a8b16220 249 /* * Where the return value has been squeezed into one or more
92ad9cd9
AC
250 registers. */
251 RETURN_VALUE_REGISTER_CONVENTION,
a8b16220 252 /* * Commonly known as the "struct return convention". The caller
92ad9cd9
AC
253 passes an additional hidden first parameter to the caller. That
254 parameter contains the address at which the value being returned
255 should be stored. While typically, and historically, used for
256 large structs, this is convention is applied to values of many
257 different types. */
31db7b6c 258 RETURN_VALUE_STRUCT_CONVENTION,
a8b16220 259 /* * Like the "struct return convention" above, but where the ABI
31db7b6c
MK
260 guarantees that the called function stores the address at which
261 the value being returned is stored in a well-defined location,
262 such as a register or memory slot in the stack frame. Don't use
263 this if the ABI doesn't explicitly guarantees this. */
264 RETURN_VALUE_ABI_RETURNS_ADDRESS,
a8b16220 265 /* * Like the "struct return convention" above, but where the ABI
31db7b6c
MK
266 guarantees that the address at which the value being returned is
267 stored will be available in a well-defined location, such as a
268 register or memory slot in the stack frame. Don't use this if
269 the ABI doesn't explicitly guarantees this. */
270 RETURN_VALUE_ABI_PRESERVES_ADDRESS,
92ad9cd9
AC
271};
272
c906108c
SS
273/* Needed for various prototypes */
274
c906108c
SS
275struct symtab;
276struct breakpoint;
6e4c6c91 277struct frame_info;
8b9b9e1a 278struct gdbarch;
028d0ed5 279struct value;
c906108c 280
478aac75
DE
281/* From main.c. */
282
283/* This really belong in utils.c (path-utils.c?), but it references some
284 globals that are currently only available to main.c. */
285extern char *relocate_gdb_directory (const char *initial, int flag);
286
c906108c
SS
287\f
288/* Annotation stuff. */
289
917317f4 290extern int annotation_level; /* in stack.c */
c906108c 291\f
c906108c
SS
292
293/* From regex.c or libc. BSD 4.4 declares this with the argument type as
294 "const char *" in unistd.h, so we can't declare the argument
295 as "char *". */
296
56000a98 297EXTERN_C char *re_comp (const char *);
c906108c
SS
298
299/* From symfile.c */
300
1d8b34a7 301extern void symbol_file_command (const char *, int);
917317f4 302
a8b16220 303/* * Remote targets may wish to use this as their load function. */
9cbe5fff 304extern void generic_load (const char *name, int from_tty);
917317f4 305
c906108c
SS
306/* From top.c */
307
6426a772
JM
308typedef void initialize_file_ftype (void);
309
38bcc89d 310extern char *gdb_readline_wrapper (const char *);
b4f5539f 311
a121b7c1 312extern char *command_line_input (const char *, int, const char *);
c906108c 313
917317f4 314extern void print_prompt (void);
c906108c 315
268a799a
PA
316struct ui;
317
318extern int input_interactive_p (struct ui *);
c906108c
SS
319
320extern int info_verbose;
321
322/* From printcmd.c */
323
8b9b9e1a 324extern void set_next_address (struct gdbarch *, CORE_ADDR);
c906108c 325
9cb709b6 326extern int print_address_symbolic (struct gdbarch *, CORE_ADDR,
a121b7c1
PA
327 struct ui_file *, int,
328 const char *);
c906108c 329
22e722e1
DJ
330extern int build_address_symbolic (struct gdbarch *,
331 CORE_ADDR addr,
7b83ea04
AC
332 int do_demangle,
333 char **name,
334 int *offset,
335 char **filename,
336 int *line,
dfcd3bfb
JM
337 int *unmapped);
338
5af949e3 339extern void print_address (struct gdbarch *, CORE_ADDR, struct ui_file *);
2b28d209 340extern const char *pc_prefix (CORE_ADDR);
c906108c
SS
341
342/* From source.c */
343
1f0c4988 344/* See openp function definition for their description. */
014d698b
EZ
345#define OPF_TRY_CWD_FIRST 0x01
346#define OPF_SEARCH_IN_PATH 0x02
492c0ab7 347#define OPF_RETURN_REALPATH 0x04
014d698b 348
fbdebf46 349extern int openp (const char *, int, const char *, int, char **);
c906108c 350
24f81874 351extern int source_full_path_of (const char *, char **);
c906108c 352
5614fb77 353extern void mod_path (const char *, char **);
c906108c 354
5614fb77 355extern void add_path (const char *, char **, int);
c04e0a08 356
5614fb77 357extern void directory_switch (const char *, int);
13d35ae5 358
c04e0a08
JJ
359extern char *source_path;
360
917317f4 361extern void init_source_path (void);
c906108c 362
104c1213
JM
363/* From exec.c */
364
a8b16220
SS
365/* * Process memory area starting at ADDR with length SIZE. Area is
366 readable iff READ is non-zero, writable if WRITE is non-zero,
367 executable if EXEC is non-zero. Area is possibly changed against
368 its original file based copy if MODIFIED is non-zero. DATA is
369 passed without changes from a caller. */
4f69f4c2 370
b8edc417
JK
371typedef int (*find_memory_region_ftype) (CORE_ADDR addr, unsigned long size,
372 int read, int write, int exec,
4f69f4c2 373 int modified, void *data);
b8edc417 374
a8b16220 375/* * Possible lvalue types. Like enum language, this should be in
0963b4bd 376 value.h, but needs to be here for the same reason. */
53a5351d
JM
377
378enum lval_type
379 {
a8b16220 380 /* * Not an lval. */
53a5351d 381 not_lval,
a8b16220 382 /* * In memory. */
53a5351d 383 lval_memory,
a8b16220 384 /* * In a register. Registers are relative to a frame. */
53a5351d 385 lval_register,
a8b16220 386 /* * In a gdb internal variable. */
53a5351d 387 lval_internalvar,
e81e7f5e
SC
388 /* * Value encapsulates a callable defined in an extension language. */
389 lval_xcallable,
a8b16220 390 /* * Part of a gdb internal variable (structure field). */
5f5233d4 391 lval_internalvar_component,
a8b16220
SS
392 /* * Value's bits are fetched and stored using functions provided
393 by its creator. */
5f5233d4 394 lval_computed
53a5351d
JM
395 };
396
a8b16220 397/* * Parameters of the "info proc" command. */
145b16a9
UW
398
399enum info_proc_what
400 {
a8b16220 401 /* * Display the default cmdline, cwd and exe outputs. */
145b16a9
UW
402 IP_MINIMAL,
403
a8b16220 404 /* * Display `info proc mappings'. */
145b16a9
UW
405 IP_MAPPINGS,
406
a8b16220 407 /* * Display `info proc status'. */
145b16a9
UW
408 IP_STATUS,
409
a8b16220 410 /* * Display `info proc stat'. */
145b16a9
UW
411 IP_STAT,
412
a8b16220 413 /* * Display `info proc cmdline'. */
145b16a9
UW
414 IP_CMDLINE,
415
a8b16220 416 /* * Display `info proc exe'. */
145b16a9
UW
417 IP_EXE,
418
a8b16220 419 /* * Display `info proc cwd'. */
145b16a9
UW
420 IP_CWD,
421
a8b16220 422 /* * Display all of the above. */
145b16a9
UW
423 IP_ALL
424 };
425
a8b16220 426/* * String containing the current directory (what getwd would return). */
c906108c
SS
427
428extern char *current_directory;
429
a8b16220 430/* * Default radixes for input and output. Only some values supported. */
c906108c
SS
431extern unsigned input_radix;
432extern unsigned output_radix;
433
a8b16220 434/* * Possibilities for prettyformat parameters to routines which print
c906108c
SS
435 things. Like enum language, this should be in value.h, but needs
436 to be here for the same reason. FIXME: If we can eliminate this
437 as an arg to LA_VAL_PRINT, then we can probably move it back to
0963b4bd 438 value.h. */
c906108c 439
2a998fc0 440enum val_prettyformat
917317f4 441 {
2a998fc0
DE
442 Val_no_prettyformat = 0,
443 Val_prettyformat,
a8b16220 444 /* * Use the default setting which the user has specified. */
2a998fc0 445 Val_prettyformat_default
917317f4 446 };
39f77062 447
a8b16220 448/* * Optional native machine support. Non-native (and possibly pure
5a2402b8
AC
449 multi-arch) targets do not need a "nm.h" file. This will be a
450 symlink to one of the nm-*.h files, built by the `configure'
451 script. */
c906108c 452
5a2402b8 453#ifdef GDB_NM_FILE
c906108c 454#include "nm.h"
5a2402b8 455#endif
c906108c 456
06c2338d 457/* Assume that fopen accepts the letter "b" in the mode string.
a880ad57
EZ
458 It is demanded by ISO C9X, and should be supported on all
459 platforms that claim to have a standard-conforming C library. On
06c2338d 460 true POSIX systems it will be ignored and have no effect. There
a880ad57
EZ
461 may still be systems without a standard-conforming C library where
462 an ISO C9X compiler (GCC) is available. Known examples are SunOS
06c2338d
MK
463 4.x and 4.3BSD. This assumption means these systems are no longer
464 supported. */
c906108c 465#ifndef FOPEN_RB
06c2338d 466# include "fopen-bin.h"
c906108c
SS
467#endif
468
c906108c 469/* Defaults for system-wide constants (if not defined by xm.h, we fake it).
0963b4bd 470 FIXME: Assumes 2's complement arithmetic. */
c906108c
SS
471
472#if !defined (UINT_MAX)
0963b4bd 473#define UINT_MAX ((unsigned int)(~0)) /* 0xFFFFFFFF for 32-bits */
c906108c
SS
474#endif
475
476#if !defined (INT_MAX)
0963b4bd 477#define INT_MAX ((int)(UINT_MAX >> 1)) /* 0x7FFFFFFF for 32-bits */
c906108c
SS
478#endif
479
480#if !defined (INT_MIN)
0963b4bd 481#define INT_MIN ((int)((int) ~0 ^ INT_MAX)) /* 0x80000000 for 32-bits */
c906108c
SS
482#endif
483
484#if !defined (ULONG_MAX)
0963b4bd 485#define ULONG_MAX ((unsigned long)(~0L)) /* 0xFFFFFFFF for 32-bits */
c906108c
SS
486#endif
487
488#if !defined (LONG_MAX)
0963b4bd 489#define LONG_MAX ((long)(ULONG_MAX >> 1)) /* 0x7FFFFFFF for 32-bits */
c906108c
SS
490#endif
491
4ce44c66 492#if !defined (ULONGEST_MAX)
658d99ff 493#define ULONGEST_MAX (~(ULONGEST)0) /* 0xFFFFFFFFFFFFFFFF for 64-bits */
4ce44c66
JM
494#endif
495
658d99ff 496#if !defined (LONGEST_MAX) /* 0x7FFFFFFFFFFFFFFF for 64-bits */
4ce44c66
JM
497#define LONGEST_MAX ((LONGEST)(ULONGEST_MAX >> 1))
498#endif
499
a8b16220 500/* * Convert a LONGEST to an int. This is used in contexts (e.g. number of
c906108c
SS
501 arguments to a function, number in a value history, register number, etc.)
502 where the value must not be larger than can fit in an int. */
503
917317f4 504extern int longest_to_int (LONGEST);
c906108c 505
a8b16220 506/* * List of known OS ABIs. If you change this, make sure to update the
4be87837
DJ
507 table in osabi.c. */
508enum gdb_osabi
509{
510 GDB_OSABI_UNINITIALIZED = -1, /* For struct gdbarch_info. */
511
512 GDB_OSABI_UNKNOWN = 0, /* keep this zero */
513
514 GDB_OSABI_SVR4,
515 GDB_OSABI_HURD,
516 GDB_OSABI_SOLARIS,
4be87837 517 GDB_OSABI_LINUX,
1736a7bd
PA
518 GDB_OSABI_FREEBSD,
519 GDB_OSABI_NETBSD,
520 GDB_OSABI_OPENBSD,
4be87837
DJ
521 GDB_OSABI_WINCE,
522 GDB_OSABI_GO32,
83461b86 523 GDB_OSABI_QNXNTO,
1762d96d 524 GDB_OSABI_CYGWIN,
1f82754b 525 GDB_OSABI_AIX,
a15c5c83 526 GDB_OSABI_DICOS,
a80b95ba 527 GDB_OSABI_DARWIN,
78664fa3 528 GDB_OSABI_SYMBIAN,
34864976 529 GDB_OSABI_OPENVMS,
d5367fe1 530 GDB_OSABI_LYNXOS178,
cf0dbd6f 531 GDB_OSABI_NEWLIB,
bb7e3f4d 532 GDB_OSABI_SDE,
1762d96d 533
4be87837
DJ
534 GDB_OSABI_INVALID /* keep this last */
535};
536
0b31a4bc
TT
537/* Enumerate the requirements a symbol has in order to be evaluated.
538 These are listed in order of "strength" -- a later entry subsumes
539 earlier ones. This fine-grained distinction is important because
540 it allows for the evaluation of a TLS symbol during unwinding --
541 when unwinding one has access to registers, but not the frame
542 itself, because that is being constructed. */
543
544enum symbol_needs_kind
545{
546 /* No special requirements -- just memory. */
547 SYMBOL_NEEDS_NONE,
548
549 /* The symbol needs registers. */
550 SYMBOL_NEEDS_REGISTERS,
551
552 /* The symbol needs a frame. */
553 SYMBOL_NEEDS_FRAME
554};
555
0963b4bd 556/* Dynamic target-system-dependent parameters for GDB. */
c906108c
SS
557#include "gdbarch.h"
558
a8b16220 559/* * Maximum size of a register. Something small, but large enough for
0c92afe8
AC
560 all known ISAs. If it turns out to be too small, make it bigger. */
561
a5916a62 562enum { MAX_REGISTER_SIZE = 64 };
0c92afe8 563
c906108c
SS
564/* In findvar.c. */
565
6f98355c
YQ
566template<typename T, typename = RequireLongest<T>>
567T extract_integer (const gdb_byte *addr, int len, enum bfd_endian byte_order);
c906108c 568
6f98355c
YQ
569static inline LONGEST
570extract_signed_integer (const gdb_byte *addr, int len,
571 enum bfd_endian byte_order)
572{
573 return extract_integer<LONGEST> (addr, len, byte_order);
574}
575
576static inline ULONGEST
577extract_unsigned_integer (const gdb_byte *addr, int len,
578 enum bfd_endian byte_order)
579{
580 return extract_integer<ULONGEST> (addr, len, byte_order);
581}
c906108c 582
e17a4113
UW
583extern int extract_long_unsigned_integer (const gdb_byte *, int,
584 enum bfd_endian, LONGEST *);
c906108c 585
0d509538
AC
586extern CORE_ADDR extract_typed_address (const gdb_byte *buf,
587 struct type *type);
4478b372 588
6f98355c
YQ
589/* All 'store' functions accept a host-format integer and store a
590 target-format integer at ADDR which is LEN bytes long. */
c906108c 591
6f98355c
YQ
592template<typename T, typename = RequireLongest<T>>
593extern void store_integer (gdb_byte *addr, int len, enum bfd_endian byte_order,
594 T val);
595
596static inline void
597store_signed_integer (gdb_byte *addr, int len,
598 enum bfd_endian byte_order, LONGEST val)
599{
600 return store_integer (addr, len, byte_order, val);
601}
602
603static inline void
604store_unsigned_integer (gdb_byte *addr, int len,
605 enum bfd_endian byte_order, ULONGEST val)
606{
607 return store_integer (addr, len, byte_order, val);
608}
c906108c 609
0d509538
AC
610extern void store_typed_address (gdb_byte *buf, struct type *type,
611 CORE_ADDR addr);
4478b372 612
b057297a
AH
613extern void copy_integer_to_size (gdb_byte *dest, int dest_size,
614 const gdb_byte *source, int source_size,
615 bool is_signed, enum bfd_endian byte_order);
616
c906108c
SS
617/* From valops.c */
618
c906108c 619extern int watchdog;
c906108c 620
43988095
JK
621/* From dwarf2read.c */
622
623ULONGEST read_unsigned_leb128 (bfd *, const gdb_byte *, unsigned int *);
624
c906108c 625/* Hooks for alternate command interfaces. */
8b93c638 626
a8b16220 627/* * The name of the interpreter if specified on the command line. */
fb40c209 628extern char *interpreter_p;
fb40c209 629
c906108c
SS
630struct target_waitstatus;
631struct cmd_list_element;
c906108c 632
769d7dc4
AC
633extern void (*deprecated_pre_add_symbol_hook) (const char *);
634extern void (*deprecated_post_add_symbol_hook) (void);
11c949aa 635extern void (*selected_frame_level_changed_hook) (int);
98bbd631 636extern int (*deprecated_ui_loop_hook) (int signo);
9a4105ab
AC
637extern void (*deprecated_show_load_progress) (const char *section,
638 unsigned long section_sent,
639 unsigned long section_size,
640 unsigned long total_sent,
641 unsigned long total_size);
642extern void (*deprecated_print_frame_info_listing_hook) (struct symtab * s,
3e43a32a
MS
643 int line,
644 int stopline,
9a4105ab 645 int noerror);
bee0189a
DJ
646extern int (*deprecated_query_hook) (const char *, va_list)
647 ATTRIBUTE_FPTR_PRINTF(1,0);
648extern void (*deprecated_warning_hook) (const char *, va_list)
649 ATTRIBUTE_FPTR_PRINTF(1,0);
9a4105ab 650extern void (*deprecated_interactive_hook) (void);
a121b7c1 651extern void (*deprecated_readline_begin_hook) (const char *, ...)
bee0189a 652 ATTRIBUTE_FPTR_PRINTF_1;
38bcc89d 653extern char *(*deprecated_readline_hook) (const char *);
9a4105ab 654extern void (*deprecated_readline_end_hook) (void);
9a4105ab
AC
655extern void (*deprecated_context_hook) (int);
656extern ptid_t (*deprecated_target_wait_hook) (ptid_t ptid,
47608cb1
PA
657 struct target_waitstatus *status,
658 int options);
917317f4 659
9a4105ab
AC
660extern void (*deprecated_attach_hook) (void);
661extern void (*deprecated_detach_hook) (void);
662extern void (*deprecated_call_command_hook) (struct cmd_list_element * c,
95a6b0a1 663 const char *cmd, int from_tty);
917317f4 664
9a4105ab
AC
665extern int (*deprecated_ui_load_progress_hook) (const char *section,
666 unsigned long num);
c906108c 667
104c1213
JM
668/* If this definition isn't overridden by the header files, assume
669 that isatty and fileno exist on this system. */
670#ifndef ISATTY
671#define ISATTY(FP) (isatty (fileno (FP)))
672#endif
673
a8b16220 674/* * A width that can achieve a better legibility for GDB MI mode. */
3347eb1a 675#define GDB_MI_MSG_WIDTH 80
676
6c95b8df
PA
677/* From progspace.c */
678
679extern void initialize_progspace (void);
680extern void initialize_inferiors (void);
681
a8b16220 682/* * Special block numbers */
8903c50d
TT
683
684enum block_enum
685{
686 GLOBAL_BLOCK = 0,
687 STATIC_BLOCK = 1,
688 FIRST_LOCAL_BLOCK = 2
689};
690
4034d0ff
AT
691/* User selection used in observer.h and multiple print functions. */
692
693enum user_selected_what_flag
694 {
695 /* Inferior selected. */
696 USER_SELECTED_INFERIOR = 1 << 1,
697
698 /* Thread selected. */
699 USER_SELECTED_THREAD = 1 << 2,
700
701 /* Frame selected. */
702 USER_SELECTED_FRAME = 1 << 3
703 };
704DEF_ENUM_FLAGS_TYPE (enum user_selected_what_flag, user_selected_what);
705
48faced0
DE
706#include "utils.h"
707
c906108c 708#endif /* #ifndef DEFS_H */