Delete Tru64 support
[deliverable/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.
ecd75fc8 4 Copyright (C) 1986-2014 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 31#include <limits.h>
d5af19ba 32#include <stdint.h>
c906108c 33
06e476f5
JB
34/* The libdecnumber library, on which GDB depends, includes a header file
35 called gstdint.h instead of relying directly on stdint.h. GDB, on the
36 other hand, includes stdint.h directly, relying on the fact that gnulib
37 generates a copy if the system doesn't provide one or if it is missing
38 some features. Unfortunately, gstdint.h and stdint.h cannot be included
39 at the same time, which may happen when we include a file from
40 libdecnumber.
41
42 The following macro definition effectively prevents the inclusion of
43 gstdint.h, as all the definitions it provides are guarded against
44 the GCC_GENERATED_STDINT_H macro. We already have gnulib/stdint.h
45 included, so it's ok to blank out gstdint.h. */
46#define GCC_GENERATED_STDINT_H 1
47
104c1213 48#include <unistd.h>
d8d2a3ee 49
637d6690
CW
50#include <fcntl.h>
51
6c7a06a3
TT
52#include "gdb_wchar.h"
53
48faced0
DE
54#include "ui-file.h"
55
56#include "host-defs.h"
57
975ac915 58/* Just in case they're not defined in stdio.h. */
c906108c
SS
59
60#ifndef SEEK_SET
61#define SEEK_SET 0
62#endif
63#ifndef SEEK_CUR
64#define SEEK_CUR 1
65#endif
66
637d6690
CW
67/* The O_BINARY flag is defined in fcntl.h on some non-Posix platforms.
68 It is used as an access modifier in calls to open(), where it acts
0963b4bd
MS
69 similarly to the "b" character in fopen()'s MODE argument. On Posix
70 platforms it should be a no-op, so it is defined as 0 here. This
71 ensures that the symbol may be used freely elsewhere in gdb. */
637d6690
CW
72
73#ifndef O_BINARY
74#define O_BINARY 0
75#endif
76
8e3b41a9 77#include "hashtab.h"
c906108c 78
c906108c
SS
79#ifndef min
80#define min(a, b) ((a) < (b) ? (a) : (b))
81#endif
82#ifndef max
83#define max(a, b) ((a) > (b) ? (a) : (b))
84#endif
85
a8b16220 86/* * Enable xdb commands if set. */
c906108c
SS
87extern int xdb_commands;
88
a8b16220 89/* * Enable dbx commands if set. */
c906108c
SS
90extern int dbx_commands;
91
a8b16220 92/* * System root path, used to find libraries etc. */
030292b7
DJ
93extern char *gdb_sysroot;
94
a8b16220 95/* * GDB datadir, used to store data files. */
b14b1491
TT
96extern char *gdb_datadir;
97
a8b16220 98/* * If non-NULL, the possibly relocated path to python's "lib" directory
0c4a4063
DE
99 specified with --with-python. */
100extern char *python_libdir;
101
a8b16220 102/* * Search path for separate debug files. */
aa28a74e
DJ
103extern char *debug_file_directory;
104
522002f9
TT
105/* GDB has two methods for handling SIGINT. When immediate_quit is
106 nonzero, a SIGINT results in an immediate longjmp out of the signal
107 handler. Otherwise, SIGINT simply sets a flag; code that might
108 take a long time, and which ought to be interruptible, checks this
109 flag using the QUIT macro.
522002f9 110
6dddc817
DE
111 These functions use the extension_language_ops API to allow extension
112 language(s) and GDB SIGINT handling to coexist seamlessly. */
522002f9 113
a8b16220 114/* * Clear the quit flag. */
522002f9 115extern void clear_quit_flag (void);
a8b16220 116/* * Evaluate to non-zero if the quit flag is set, zero otherwise. This
522002f9
TT
117 will clear the quit flag as a side effect. */
118extern int check_quit_flag (void);
a8b16220 119/* * Set the quit flag. */
522002f9
TT
120extern void set_quit_flag (void);
121
06c868a8
JK
122/* Flag that function quit should call quit_force. */
123extern volatile int sync_quit_force_run;
124
c906108c 125extern int immediate_quit;
c906108c 126
917317f4 127extern void quit (void);
c906108c 128
1a0559af
AC
129/* FIXME: cagney/2000-03-13: It has been suggested that the peformance
130 benefits of having a ``QUIT'' macro rather than a function are
131 marginal. If the overhead of a QUIT function call is proving
132 significant then its calling frequency should probably be reduced
133 [kingdon]. A profile analyzing the current situtation is
0963b4bd 134 needed. */
1a0559af 135
c906108c 136#define QUIT { \
06c868a8 137 if (check_quit_flag () || sync_quit_force_run) quit (); \
9a4105ab 138 if (deprecated_interactive_hook) deprecated_interactive_hook (); \
c906108c 139}
c906108c 140
a8b16220 141/* * Languages represented in the symbol table and elsewhere.
c906108c
SS
142 This should probably be in language.h, but since enum's can't
143 be forward declared to satisfy opaque references before their
0963b4bd 144 actual definition, needs to be here. */
c906108c 145
917317f4
JM
146enum language
147 {
148 language_unknown, /* Language not known */
149 language_auto, /* Placeholder for automatic setting */
150 language_c, /* C */
151 language_cplus, /* C++ */
6aecb9c2 152 language_d, /* D */
a766d390 153 language_go, /* Go */
50f85cdf 154 language_objc, /* Objective-C */
917317f4 155 language_java, /* Java */
917317f4
JM
156 language_fortran, /* Fortran */
157 language_m2, /* Modula-2 */
158 language_asm, /* Assembly language */
20a0e81d 159 language_pascal, /* Pascal */
963a6417 160 language_ada, /* Ada */
f4b8a18d 161 language_opencl, /* OpenCL */
f290d38e
AC
162 language_minimal, /* All other languages, minimal support only */
163 nr_languages
917317f4 164 };
c906108c
SS
165
166enum precision_type
917317f4
JM
167 {
168 single_precision,
169 double_precision,
170 unspecified_precision
171 };
172
a8b16220
SS
173/* * A generic, not quite boolean, enumeration. This is used for
174 set/show commands in which the options are on/off/automatic. */
7f19b9a2
AC
175enum auto_boolean
176{
177 AUTO_BOOLEAN_TRUE,
178 AUTO_BOOLEAN_FALSE,
179 AUTO_BOOLEAN_AUTO
180};
181
a8b16220
SS
182/* * Potential ways that a function can return a value of a given
183 type. */
184
92ad9cd9
AC
185enum return_value_convention
186{
a8b16220 187 /* * Where the return value has been squeezed into one or more
92ad9cd9
AC
188 registers. */
189 RETURN_VALUE_REGISTER_CONVENTION,
a8b16220 190 /* * Commonly known as the "struct return convention". The caller
92ad9cd9
AC
191 passes an additional hidden first parameter to the caller. That
192 parameter contains the address at which the value being returned
193 should be stored. While typically, and historically, used for
194 large structs, this is convention is applied to values of many
195 different types. */
31db7b6c 196 RETURN_VALUE_STRUCT_CONVENTION,
a8b16220 197 /* * Like the "struct return convention" above, but where the ABI
31db7b6c
MK
198 guarantees that the called function stores the address at which
199 the value being returned is stored in a well-defined location,
200 such as a register or memory slot in the stack frame. Don't use
201 this if the ABI doesn't explicitly guarantees this. */
202 RETURN_VALUE_ABI_RETURNS_ADDRESS,
a8b16220 203 /* * Like the "struct return convention" above, but where the ABI
31db7b6c
MK
204 guarantees that the address at which the value being returned is
205 stored will be available in a well-defined location, such as a
206 register or memory slot in the stack frame. Don't use this if
207 the ABI doesn't explicitly guarantees this. */
208 RETURN_VALUE_ABI_PRESERVES_ADDRESS,
92ad9cd9
AC
209};
210
c906108c
SS
211/* Needed for various prototypes */
212
c906108c
SS
213struct symtab;
214struct breakpoint;
6e4c6c91 215struct frame_info;
8b9b9e1a 216struct gdbarch;
028d0ed5 217struct value;
c906108c 218
478aac75
DE
219/* From main.c. */
220
221/* This really belong in utils.c (path-utils.c?), but it references some
222 globals that are currently only available to main.c. */
223extern char *relocate_gdb_directory (const char *initial, int flag);
224
c906108c
SS
225\f
226/* Annotation stuff. */
227
917317f4 228extern int annotation_level; /* in stack.c */
c906108c 229\f
c906108c
SS
230
231/* From regex.c or libc. BSD 4.4 declares this with the argument type as
232 "const char *" in unistd.h, so we can't declare the argument
233 as "char *". */
234
917317f4 235extern char *re_comp (const char *);
c906108c
SS
236
237/* From symfile.c */
238
917317f4
JM
239extern void symbol_file_command (char *, int);
240
a8b16220 241/* * Remote targets may wish to use this as their load function. */
9cbe5fff 242extern void generic_load (const char *name, int from_tty);
917317f4 243
a8b16220 244/* * Report on STREAM the performance of memory transfer operation,
0963b4bd 245 such as 'load'.
a8b16220
SS
246 @param DATA_COUNT is the number of bytes transferred.
247 @param WRITE_COUNT is the number of separate write operations, or 0,
0152ebd7 248 if that information is not available.
a8b16220
SS
249 @param START_TIME is the time at which an operation was started.
250 @param END_TIME is the time at which an operation ended. */
2b71414d 251struct timeval;
d9fcf2fb 252extern void print_transfer_performance (struct ui_file *stream,
917317f4
JM
253 unsigned long data_count,
254 unsigned long write_count,
2b71414d
DJ
255 const struct timeval *start_time,
256 const struct timeval *end_time);
c906108c
SS
257
258/* From top.c */
259
6426a772
JM
260typedef void initialize_file_ftype (void);
261
917317f4 262extern char *gdb_readline (char *);
c906108c 263
b4f5539f
TT
264extern char *gdb_readline_wrapper (char *);
265
917317f4 266extern char *command_line_input (char *, int, char *);
c906108c 267
917317f4 268extern void print_prompt (void);
c906108c 269
917317f4 270extern int input_from_terminal_p (void);
c906108c
SS
271
272extern int info_verbose;
273
274/* From printcmd.c */
275
8b9b9e1a 276extern void set_next_address (struct gdbarch *, CORE_ADDR);
c906108c 277
9cb709b6
TT
278extern int print_address_symbolic (struct gdbarch *, CORE_ADDR,
279 struct ui_file *, int, char *);
c906108c 280
22e722e1
DJ
281extern int build_address_symbolic (struct gdbarch *,
282 CORE_ADDR addr,
7b83ea04
AC
283 int do_demangle,
284 char **name,
285 int *offset,
286 char **filename,
287 int *line,
dfcd3bfb
JM
288 int *unmapped);
289
5af949e3 290extern void print_address (struct gdbarch *, CORE_ADDR, struct ui_file *);
2b28d209 291extern const char *pc_prefix (CORE_ADDR);
c906108c
SS
292
293/* From source.c */
294
1f0c4988 295/* See openp function definition for their description. */
014d698b
EZ
296#define OPF_TRY_CWD_FIRST 0x01
297#define OPF_SEARCH_IN_PATH 0x02
492c0ab7 298#define OPF_RETURN_REALPATH 0x04
014d698b 299
fbdebf46 300extern int openp (const char *, int, const char *, int, char **);
c906108c 301
24f81874 302extern int source_full_path_of (const char *, char **);
c906108c 303
917317f4 304extern void mod_path (char *, char **);
c906108c 305
c04e0a08
JJ
306extern void add_path (char *, char **, int);
307
13d35ae5
AS
308extern void directory_switch (char *, int);
309
c04e0a08
JJ
310extern char *source_path;
311
917317f4 312extern void init_source_path (void);
c906108c 313
104c1213
JM
314/* From exec.c */
315
a8b16220
SS
316/* * Process memory area starting at ADDR with length SIZE. Area is
317 readable iff READ is non-zero, writable if WRITE is non-zero,
318 executable if EXEC is non-zero. Area is possibly changed against
319 its original file based copy if MODIFIED is non-zero. DATA is
320 passed without changes from a caller. */
4f69f4c2 321
b8edc417
JK
322typedef int (*find_memory_region_ftype) (CORE_ADDR addr, unsigned long size,
323 int read, int write, int exec,
4f69f4c2 324 int modified, void *data);
b8edc417 325
a8b16220 326/* * Possible lvalue types. Like enum language, this should be in
0963b4bd 327 value.h, but needs to be here for the same reason. */
53a5351d
JM
328
329enum lval_type
330 {
a8b16220 331 /* * Not an lval. */
53a5351d 332 not_lval,
a8b16220 333 /* * In memory. */
53a5351d 334 lval_memory,
a8b16220 335 /* * In a register. Registers are relative to a frame. */
53a5351d 336 lval_register,
a8b16220 337 /* * In a gdb internal variable. */
53a5351d 338 lval_internalvar,
e81e7f5e
SC
339 /* * Value encapsulates a callable defined in an extension language. */
340 lval_xcallable,
a8b16220 341 /* * Part of a gdb internal variable (structure field). */
5f5233d4 342 lval_internalvar_component,
a8b16220
SS
343 /* * Value's bits are fetched and stored using functions provided
344 by its creator. */
5f5233d4 345 lval_computed
53a5351d
JM
346 };
347
a8b16220 348/* * Control types for commands. */
c906108c
SS
349
350enum misc_command_type
917317f4
JM
351 {
352 ok_command,
353 end_command,
354 else_command,
355 nop_command
356 };
c906108c
SS
357
358enum command_control_type
917317f4
JM
359 {
360 simple_control,
361 break_control,
362 continue_control,
363 while_control,
364 if_control,
40c03ae8 365 commands_control,
d57a3c85 366 python_control,
ed3ef339 367 guile_control,
a7bdde9e 368 while_stepping_control,
917317f4
JM
369 invalid_control
370 };
c906108c 371
a8b16220
SS
372/* * Structure for saved commands lines (for breakpoints, defined
373 commands, etc). */
c906108c
SS
374
375struct command_line
917317f4
JM
376 {
377 struct command_line *next;
378 char *line;
379 enum command_control_type control_type;
a8b16220 380 /* * The number of elements in body_list. */
917317f4 381 int body_count;
a8b16220 382 /* * For composite commands, the nested lists of commands. For
0963b4bd
MS
383 example, for "if" command this will contain the then branch and
384 the else branch, if that is available. */
917317f4
JM
385 struct command_line **body_list;
386 };
c906108c 387
a7bdde9e
VP
388extern struct command_line *read_command_lines (char *, int, int,
389 void (*)(char *, void *),
390 void *);
391extern struct command_line *read_command_lines_1 (char * (*) (void), int,
392 void (*)(char *, void *),
393 void *);
c906108c 394
917317f4 395extern void free_command_lines (struct command_line **);
c906108c 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
DJ
517 GDB_OSABI_LINUX,
518 GDB_OSABI_FREEBSD_AOUT,
519 GDB_OSABI_FREEBSD_ELF,
520 GDB_OSABI_NETBSD_AOUT,
521 GDB_OSABI_NETBSD_ELF,
d33b9831 522 GDB_OSABI_OPENBSD_ELF,
4be87837
DJ
523 GDB_OSABI_WINCE,
524 GDB_OSABI_GO32,
4be87837 525 GDB_OSABI_IRIX,
4be87837
DJ
526 GDB_OSABI_HPUX_ELF,
527 GDB_OSABI_HPUX_SOM,
83461b86 528 GDB_OSABI_QNXNTO,
1762d96d 529 GDB_OSABI_CYGWIN,
1f82754b 530 GDB_OSABI_AIX,
a15c5c83 531 GDB_OSABI_DICOS,
a80b95ba 532 GDB_OSABI_DARWIN,
78664fa3 533 GDB_OSABI_SYMBIAN,
34864976 534 GDB_OSABI_OPENVMS,
d5367fe1 535 GDB_OSABI_LYNXOS178,
cf0dbd6f 536 GDB_OSABI_NEWLIB,
1762d96d 537
4be87837
DJ
538 GDB_OSABI_INVALID /* keep this last */
539};
540
c906108c
SS
541/* Global functions from other, non-gdb GNU thingies.
542 Libiberty thingies are no longer declared here. We include libiberty.h
543 above, instead. */
544
c906108c
SS
545/* From other system libraries */
546
c906108c 547#ifndef atof
917317f4 548extern double atof (const char *); /* X3.159-1989 4.10.1.1 */
c906108c
SS
549#endif
550
c906108c
SS
551/* Various possibilities for alloca. */
552#ifndef alloca
917317f4
JM
553#ifdef __GNUC__
554#define alloca __builtin_alloca
555#else /* Not GNU C */
556#ifdef HAVE_ALLOCA_H
557#include <alloca.h>
558#else
559#ifdef _AIX
560#pragma alloca
561#else
c906108c
SS
562
563/* We need to be careful not to declare this in a way which conflicts with
564 bison. Bison never declares it as char *, but under various circumstances
565 (like __hpux) we need to use void *. */
917317f4 566extern void *alloca ();
917317f4
JM
567#endif /* Not _AIX */
568#endif /* Not HAVE_ALLOCA_H */
569#endif /* Not GNU C */
c906108c
SS
570#endif /* alloca not defined */
571
0963b4bd 572/* Dynamic target-system-dependent parameters for GDB. */
c906108c
SS
573#include "gdbarch.h"
574
a8b16220 575/* * Maximum size of a register. Something small, but large enough for
0c92afe8
AC
576 all known ISAs. If it turns out to be too small, make it bigger. */
577
a5916a62 578enum { MAX_REGISTER_SIZE = 64 };
0c92afe8 579
0963b4bd 580/* Static target-system-dependent parameters for GDB. */
c906108c 581
a8b16220 582/* * Number of bits in a char or unsigned char for the target machine.
c906108c
SS
583 Just like CHAR_BIT in <limits.h> but describes the target machine. */
584#if !defined (TARGET_CHAR_BIT)
585#define TARGET_CHAR_BIT 8
586#endif
587
a8b16220 588/* * If we picked up a copy of CHAR_BIT from a configuration file
c906108c
SS
589 (which may get it by including <limits.h>) then use it to set
590 the number of bits in a host char. If not, use the same size
0963b4bd 591 as the target. */
c906108c
SS
592
593#if defined (CHAR_BIT)
594#define HOST_CHAR_BIT CHAR_BIT
595#else
596#define HOST_CHAR_BIT TARGET_CHAR_BIT
597#endif
598
c906108c
SS
599/* In findvar.c. */
600
e17a4113
UW
601extern LONGEST extract_signed_integer (const gdb_byte *, int,
602 enum bfd_endian);
c906108c 603
e17a4113
UW
604extern ULONGEST extract_unsigned_integer (const gdb_byte *, int,
605 enum bfd_endian);
c906108c 606
e17a4113
UW
607extern int extract_long_unsigned_integer (const gdb_byte *, int,
608 enum bfd_endian, LONGEST *);
c906108c 609
0d509538
AC
610extern CORE_ADDR extract_typed_address (const gdb_byte *buf,
611 struct type *type);
4478b372 612
e17a4113
UW
613extern void store_signed_integer (gdb_byte *, int,
614 enum bfd_endian, LONGEST);
c906108c 615
e17a4113
UW
616extern void store_unsigned_integer (gdb_byte *, int,
617 enum bfd_endian, ULONGEST);
c906108c 618
0d509538
AC
619extern void store_typed_address (gdb_byte *buf, struct type *type,
620 CORE_ADDR addr);
4478b372 621
c906108c 622\f
c906108c
SS
623/* From valops.c */
624
c906108c 625extern int watchdog;
c906108c
SS
626
627/* Hooks for alternate command interfaces. */
8b93c638 628
a8b16220 629/* * The name of the interpreter if specified on the command line. */
fb40c209 630extern char *interpreter_p;
fb40c209
AC
631
632/* If a given interpreter matches INTERPRETER_P then it should update
257e6d53
AB
633 deprecated_init_ui_hook with the per-interpreter implementation. */
634/* FIXME: deprecated_init_ui_hook should be moved here. */
fb40c209 635
c906108c
SS
636struct target_waitstatus;
637struct cmd_list_element;
c906108c 638
769d7dc4
AC
639extern void (*deprecated_pre_add_symbol_hook) (const char *);
640extern void (*deprecated_post_add_symbol_hook) (void);
11c949aa 641extern void (*selected_frame_level_changed_hook) (int);
98bbd631 642extern int (*deprecated_ui_loop_hook) (int signo);
9a4105ab 643extern void (*deprecated_init_ui_hook) (char *argv0);
9a4105ab
AC
644extern void (*deprecated_show_load_progress) (const char *section,
645 unsigned long section_sent,
646 unsigned long section_size,
647 unsigned long total_sent,
648 unsigned long total_size);
649extern void (*deprecated_print_frame_info_listing_hook) (struct symtab * s,
3e43a32a
MS
650 int line,
651 int stopline,
9a4105ab 652 int noerror);
bee0189a
DJ
653extern int (*deprecated_query_hook) (const char *, va_list)
654 ATTRIBUTE_FPTR_PRINTF(1,0);
655extern void (*deprecated_warning_hook) (const char *, va_list)
656 ATTRIBUTE_FPTR_PRINTF(1,0);
9a4105ab 657extern void (*deprecated_interactive_hook) (void);
bee0189a
DJ
658extern void (*deprecated_readline_begin_hook) (char *, ...)
659 ATTRIBUTE_FPTR_PRINTF_1;
9a4105ab
AC
660extern char *(*deprecated_readline_hook) (char *);
661extern void (*deprecated_readline_end_hook) (void);
662extern void (*deprecated_register_changed_hook) (int regno);
9a4105ab
AC
663extern void (*deprecated_context_hook) (int);
664extern ptid_t (*deprecated_target_wait_hook) (ptid_t ptid,
47608cb1
PA
665 struct target_waitstatus *status,
666 int options);
917317f4 667
9a4105ab
AC
668extern void (*deprecated_attach_hook) (void);
669extern void (*deprecated_detach_hook) (void);
670extern void (*deprecated_call_command_hook) (struct cmd_list_element * c,
671 char *cmd, int from_tty);
917317f4 672
9a4105ab
AC
673extern int (*deprecated_ui_load_progress_hook) (const char *section,
674 unsigned long num);
c906108c 675
104c1213
JM
676/* If this definition isn't overridden by the header files, assume
677 that isatty and fileno exist on this system. */
678#ifndef ISATTY
679#define ISATTY(FP) (isatty (fileno (FP)))
680#endif
681
a8b16220 682/* * A width that can achieve a better legibility for GDB MI mode. */
3347eb1a 683#define GDB_MI_MSG_WIDTH 80
684
6c95b8df
PA
685/* From progspace.c */
686
687extern void initialize_progspace (void);
688extern void initialize_inferiors (void);
689
a8b16220 690/* * Special block numbers */
8903c50d
TT
691
692enum block_enum
693{
694 GLOBAL_BLOCK = 0,
695 STATIC_BLOCK = 1,
696 FIRST_LOCAL_BLOCK = 2
697};
698
48faced0
DE
699#include "utils.h"
700
c906108c 701#endif /* #ifndef DEFS_H */
This page took 1.04355 seconds and 4 git commands to generate.