Move C-related declarations to compile-c.h
This patch simply moves a bunch of C language-related declarations from the various compile header files into a new C-specific header, compile-c.h. gdb/ChangeLog: * Makefile.in (SUBDIR_GCC_COMPILE_SRCS): Move header files ... (HFILES_NO_SRCDIR): ... to here. Add compile-internal.h and compile-c.h. * compile/compile-c-support.c: Include compile-c.h. * compile/compile-c-symbols.c: Include compile-c.h. (generate_c_for_variable_locations): Update comment. * compile/compile-c-types.c: Include compile-c.h. * compile/compile-c.h: New file -- moved C language declarations from other files here. * compile/compile-internal.h: Do not include hashtab.h or common/enum-flags.h. (gcc_qualifiers_flags, struct compile_c_instance, C_CTX) (gcc_convert_symbol, gcc_symbol_address) (generate_c_for_variable_locations, c_get_mode_for_size) (c_get_range_decl_name): Definitions moved to compile-c.h. * compile/compile-loc2c.c: Include compile-c.h.
This commit is contained in:
parent
6f36b6d29f
commit
b7dc48b4a8
8 changed files with 110 additions and 64 deletions
|
@ -1,3 +1,22 @@
|
||||||
|
2018-08-10 Keith Seitz <keiths@redhat.com>
|
||||||
|
|
||||||
|
* Makefile.in (SUBDIR_GCC_COMPILE_SRCS): Move header files ...
|
||||||
|
(HFILES_NO_SRCDIR): ... to here.
|
||||||
|
Add compile-internal.h and compile-c.h.
|
||||||
|
* compile/compile-c-support.c: Include compile-c.h.
|
||||||
|
* compile/compile-c-symbols.c: Include compile-c.h.
|
||||||
|
(generate_c_for_variable_locations): Update comment.
|
||||||
|
* compile/compile-c-types.c: Include compile-c.h.
|
||||||
|
* compile/compile-c.h: New file -- moved C language declarations
|
||||||
|
from other files here.
|
||||||
|
* compile/compile-internal.h: Do not include hashtab.h or
|
||||||
|
common/enum-flags.h.
|
||||||
|
(gcc_qualifiers_flags, struct compile_c_instance, C_CTX)
|
||||||
|
(gcc_convert_symbol, gcc_symbol_address)
|
||||||
|
(generate_c_for_variable_locations, c_get_mode_for_size)
|
||||||
|
(c_get_range_decl_name): Definitions moved to compile-c.h.
|
||||||
|
* compile/compile-loc2c.c: Include compile-c.h.
|
||||||
|
|
||||||
2018-08-10 Keith Seitz <keiths@redhat.com>
|
2018-08-10 Keith Seitz <keiths@redhat.com>
|
||||||
|
|
||||||
* compile/compile-c-symbols.c (symbol_substitution_name): Rename to ...
|
* compile/compile-c-symbols.c (symbol_substitution_name): Rename to ...
|
||||||
|
|
|
@ -319,9 +319,7 @@ SUBDIR_GCC_COMPILE_SRCS = \
|
||||||
compile/compile-c-types.c \
|
compile/compile-c-types.c \
|
||||||
compile/compile-loc2c.c \
|
compile/compile-loc2c.c \
|
||||||
compile/compile-object-load.c \
|
compile/compile-object-load.c \
|
||||||
compile/compile-object-load.h \
|
compile/compile-object-run.c
|
||||||
compile/compile-object-run.c \
|
|
||||||
compile/compile-object-run.h
|
|
||||||
|
|
||||||
SUBDIR_GCC_COMPILE_OBS = $(patsubst %.c,%.o,$(filter %.c,$(SUBDIR_GCC_COMPILE_SRCS)))
|
SUBDIR_GCC_COMPILE_OBS = $(patsubst %.c,%.o,$(filter %.c,$(SUBDIR_GCC_COMPILE_SRCS)))
|
||||||
|
|
||||||
|
@ -1462,6 +1460,10 @@ HFILES_NO_SRCDIR = \
|
||||||
common/x86-xstate.h \
|
common/x86-xstate.h \
|
||||||
common/xml-utils.h \
|
common/xml-utils.h \
|
||||||
compile/compile.h \
|
compile/compile.h \
|
||||||
|
compile/compile-c.h \
|
||||||
|
compile/compile-internal.h \
|
||||||
|
compile/compile-object-load.h \
|
||||||
|
compile/compile-object-run.h \
|
||||||
config/nm-linux.h \
|
config/nm-linux.h \
|
||||||
config/nm-nto.h \
|
config/nm-nto.h \
|
||||||
config/djgpp/langinfo.h \
|
config/djgpp/langinfo.h \
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
#include "defs.h"
|
#include "defs.h"
|
||||||
#include "compile-internal.h"
|
#include "compile-internal.h"
|
||||||
|
#include "compile-c.h"
|
||||||
#include "compile.h"
|
#include "compile.h"
|
||||||
#include "gdb-dlfcn.h"
|
#include "gdb-dlfcn.h"
|
||||||
#include "c-lang.h"
|
#include "c-lang.h"
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
|
|
||||||
#include "defs.h"
|
#include "defs.h"
|
||||||
#include "compile-internal.h"
|
#include "compile-internal.h"
|
||||||
|
#include "compile-c.h"
|
||||||
#include "symtab.h"
|
#include "symtab.h"
|
||||||
#include "parser-defs.h"
|
#include "parser-defs.h"
|
||||||
#include "block.h"
|
#include "block.h"
|
||||||
|
@ -706,7 +707,7 @@ generate_c_for_for_one_variable (struct compile_c_instance *compiler,
|
||||||
END_CATCH
|
END_CATCH
|
||||||
}
|
}
|
||||||
|
|
||||||
/* See compile-internal.h. */
|
/* See compile-c.h. */
|
||||||
|
|
||||||
gdb::unique_xmalloc_ptr<unsigned char>
|
gdb::unique_xmalloc_ptr<unsigned char>
|
||||||
generate_c_for_variable_locations (struct compile_c_instance *compiler,
|
generate_c_for_variable_locations (struct compile_c_instance *compiler,
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#include "defs.h"
|
#include "defs.h"
|
||||||
#include "gdbtypes.h"
|
#include "gdbtypes.h"
|
||||||
#include "compile-internal.h"
|
#include "compile-internal.h"
|
||||||
|
#include "compile-c.h"
|
||||||
#include "objfiles.h"
|
#include "objfiles.h"
|
||||||
|
|
||||||
/* An object that maps a gdb type to a gcc type. */
|
/* An object that maps a gdb type to a gcc type. */
|
||||||
|
|
81
gdb/compile/compile-c.h
Normal file
81
gdb/compile/compile-c.h
Normal file
|
@ -0,0 +1,81 @@
|
||||||
|
/* Header file for GDB compile C-language support.
|
||||||
|
Copyright (C) 2014-2018 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#ifndef GDB_COMPILE_C_H
|
||||||
|
#define GDB_COMPILE_C_H
|
||||||
|
|
||||||
|
#include "common/enum-flags.h"
|
||||||
|
#include "hashtab.h"
|
||||||
|
|
||||||
|
/* enum-flags wrapper. */
|
||||||
|
|
||||||
|
DEF_ENUM_FLAGS_TYPE (enum gcc_qualifiers, gcc_qualifiers_flags);
|
||||||
|
|
||||||
|
/* A callback suitable for use as the GCC C symbol oracle. */
|
||||||
|
|
||||||
|
extern gcc_c_oracle_function gcc_convert_symbol;
|
||||||
|
|
||||||
|
/* A callback suitable for use as the GCC C address oracle. */
|
||||||
|
|
||||||
|
extern gcc_c_symbol_address_function gcc_symbol_address;
|
||||||
|
|
||||||
|
/* A subclass of compile_instance that is specific to the C front
|
||||||
|
end. */
|
||||||
|
|
||||||
|
struct compile_c_instance
|
||||||
|
{
|
||||||
|
/* Base class. Note that the base class vtable actually points to a
|
||||||
|
gcc_c_fe_vtable. */
|
||||||
|
struct compile_instance base;
|
||||||
|
|
||||||
|
/* Map from gdb types to gcc types. */
|
||||||
|
htab_t type_map;
|
||||||
|
|
||||||
|
/* Map from gdb symbols to gcc error messages to emit. */
|
||||||
|
htab_t symbol_err_map;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* A helper macro that takes a compile_c_instance and returns its
|
||||||
|
corresponding gcc_c_context. */
|
||||||
|
|
||||||
|
#define C_CTX(I) ((struct gcc_c_context *) ((I)->base.fe))
|
||||||
|
|
||||||
|
/* Emit code to compute the address for all the local variables in
|
||||||
|
scope at PC in BLOCK. Returns a malloc'd vector, indexed by gdb
|
||||||
|
register number, where each element indicates if the corresponding
|
||||||
|
register is needed to compute a local variable. */
|
||||||
|
|
||||||
|
extern gdb::unique_xmalloc_ptr<unsigned char>
|
||||||
|
generate_c_for_variable_locations
|
||||||
|
(struct compile_c_instance *compiler,
|
||||||
|
string_file &stream,
|
||||||
|
struct gdbarch *gdbarch,
|
||||||
|
const struct block *block,
|
||||||
|
CORE_ADDR pc);
|
||||||
|
|
||||||
|
/* Get the GCC mode attribute value for a given type size. */
|
||||||
|
|
||||||
|
extern const char *c_get_mode_for_size (int size);
|
||||||
|
|
||||||
|
/* Given a dynamic property, return an xmallocd name that is used to
|
||||||
|
represent its size. The result must be freed by the caller. The
|
||||||
|
contents of the resulting string will be the same each time for
|
||||||
|
each call with the same argument. */
|
||||||
|
|
||||||
|
struct dynamic_prop;
|
||||||
|
extern std::string c_get_range_decl_name (const struct dynamic_prop *prop);
|
||||||
|
|
||||||
|
#endif /* GDB_COMPILE_C_H */
|
|
@ -17,12 +17,7 @@
|
||||||
#ifndef GDB_COMPILE_INTERNAL_H
|
#ifndef GDB_COMPILE_INTERNAL_H
|
||||||
#define GDB_COMPILE_INTERNAL_H
|
#define GDB_COMPILE_INTERNAL_H
|
||||||
|
|
||||||
#include "hashtab.h"
|
|
||||||
#include "gcc-c-interface.h"
|
#include "gcc-c-interface.h"
|
||||||
#include "common/enum-flags.h"
|
|
||||||
|
|
||||||
/* enum-flags wrapper. */
|
|
||||||
DEF_ENUM_FLAGS_TYPE (enum gcc_qualifiers, gcc_qualifiers_flags);
|
|
||||||
|
|
||||||
/* Debugging flag for the "compile" family of commands. */
|
/* Debugging flag for the "compile" family of commands. */
|
||||||
|
|
||||||
|
@ -57,29 +52,6 @@ struct compile_instance
|
||||||
void (*destroy) (struct compile_instance *);
|
void (*destroy) (struct compile_instance *);
|
||||||
};
|
};
|
||||||
|
|
||||||
/* A subclass of compile_instance that is specific to the C front
|
|
||||||
end. */
|
|
||||||
struct compile_c_instance
|
|
||||||
{
|
|
||||||
/* Base class. Note that the base class vtable actually points to a
|
|
||||||
gcc_c_fe_vtable. */
|
|
||||||
|
|
||||||
struct compile_instance base;
|
|
||||||
|
|
||||||
/* Map from gdb types to gcc types. */
|
|
||||||
|
|
||||||
htab_t type_map;
|
|
||||||
|
|
||||||
/* Map from gdb symbols to gcc error messages to emit. */
|
|
||||||
|
|
||||||
htab_t symbol_err_map;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* A helper macro that takes a compile_c_instance and returns its
|
|
||||||
corresponding gcc_c_context. */
|
|
||||||
|
|
||||||
#define C_CTX(I) ((struct gcc_c_context *) ((I)->base.fe))
|
|
||||||
|
|
||||||
/* Define header and footers for different scopes. */
|
/* Define header and footers for different scopes. */
|
||||||
|
|
||||||
/* A simple scope just declares a function named "_gdb_expr", takes no
|
/* A simple scope just declares a function named "_gdb_expr", takes no
|
||||||
|
@ -114,43 +86,11 @@ struct type;
|
||||||
extern gcc_type convert_type (struct compile_c_instance *context,
|
extern gcc_type convert_type (struct compile_c_instance *context,
|
||||||
struct type *type);
|
struct type *type);
|
||||||
|
|
||||||
/* A callback suitable for use as the GCC C symbol oracle. */
|
|
||||||
|
|
||||||
extern gcc_c_oracle_function gcc_convert_symbol;
|
|
||||||
|
|
||||||
/* A callback suitable for use as the GCC C address oracle. */
|
|
||||||
|
|
||||||
extern gcc_c_symbol_address_function gcc_symbol_address;
|
|
||||||
|
|
||||||
/* Instantiate a GDB object holding state for the GCC context FE. The
|
/* Instantiate a GDB object holding state for the GCC context FE. The
|
||||||
new object is returned. */
|
new object is returned. */
|
||||||
|
|
||||||
extern struct compile_instance *new_compile_instance (struct gcc_c_context *fe);
|
extern struct compile_instance *new_compile_instance (struct gcc_c_context *fe);
|
||||||
|
|
||||||
/* Emit code to compute the address for all the local variables in
|
|
||||||
scope at PC in BLOCK. Returns a vector, indexed by gdb register
|
|
||||||
number, where each element indicates if the corresponding register
|
|
||||||
is needed to compute a local variable. */
|
|
||||||
|
|
||||||
extern gdb::unique_xmalloc_ptr<unsigned char>
|
|
||||||
generate_c_for_variable_locations
|
|
||||||
(struct compile_c_instance *compiler,
|
|
||||||
string_file &stream,
|
|
||||||
struct gdbarch *gdbarch,
|
|
||||||
const struct block *block,
|
|
||||||
CORE_ADDR pc);
|
|
||||||
|
|
||||||
/* Get the GCC mode attribute value for a given type size. */
|
|
||||||
|
|
||||||
extern const char *c_get_mode_for_size (int size);
|
|
||||||
|
|
||||||
/* Given a dynamic property, return a name that is used to represent
|
|
||||||
its size. The contents of the resulting string will be the same
|
|
||||||
each time for each call with the same argument. */
|
|
||||||
|
|
||||||
struct dynamic_prop;
|
|
||||||
extern std::string c_get_range_decl_name (const struct dynamic_prop *prop);
|
|
||||||
|
|
||||||
/* Type used to hold and pass around the source and object file names
|
/* Type used to hold and pass around the source and object file names
|
||||||
to use for compilation. */
|
to use for compilation. */
|
||||||
class compile_file_names
|
class compile_file_names
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include "ui-file.h"
|
#include "ui-file.h"
|
||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
#include "compile-internal.h"
|
#include "compile-internal.h"
|
||||||
|
#include "compile-c.h"
|
||||||
#include "compile.h"
|
#include "compile.h"
|
||||||
#include "block.h"
|
#include "block.h"
|
||||||
#include "dwarf2-frame.h"
|
#include "dwarf2-frame.h"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue