|  | /* Header file for Compile and inject module. | 
|  |  | 
|  | Copyright (C) 2014-2024 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 COMPILE_COMPILE_H | 
|  | #define COMPILE_COMPILE_H | 
|  |  | 
|  | #include "gcc-c-interface.h" | 
|  | #include "gdbsupport/gdb-hashtab.h" | 
|  |  | 
|  | struct ui_file; | 
|  | struct gdbarch; | 
|  | struct dwarf2_per_cu_data; | 
|  | struct dwarf2_per_objfile; | 
|  | struct symbol; | 
|  | struct dynamic_prop; | 
|  |  | 
|  | /* Scope types enumerator.  List the types of scopes the compiler will | 
|  | accept.  */ | 
|  |  | 
|  | enum compile_i_scope_types | 
|  | { | 
|  | COMPILE_I_INVALID_SCOPE, | 
|  |  | 
|  | /* A simple scope.  Wrap an expression into a simple scope that | 
|  | takes no arguments, returns no value, and uses the generic | 
|  | function name "_gdb_expr". */ | 
|  |  | 
|  | COMPILE_I_SIMPLE_SCOPE, | 
|  |  | 
|  | /* Do not wrap the expression, | 
|  | it has to provide function "_gdb_expr" on its own.  */ | 
|  | COMPILE_I_RAW_SCOPE, | 
|  |  | 
|  | /* A printable expression scope.  Wrap an expression into a scope | 
|  | suitable for the "compile print" command.  It uses the generic | 
|  | function name "_gdb_expr".  COMPILE_I_PRINT_ADDRESS_SCOPE variant | 
|  | is the usual one, taking address of the object. | 
|  | COMPILE_I_PRINT_VALUE_SCOPE is needed for arrays where the array | 
|  | name already specifies its address.  See get_out_value_type.  */ | 
|  | COMPILE_I_PRINT_ADDRESS_SCOPE, | 
|  | COMPILE_I_PRINT_VALUE_SCOPE, | 
|  | }; | 
|  |  | 
|  | /* An object of this type holds state associated with a given | 
|  | compilation job.  */ | 
|  |  | 
|  | class compile_instance | 
|  | { | 
|  | public: | 
|  | compile_instance (struct gcc_base_context *gcc_fe, const char *options); | 
|  |  | 
|  | virtual ~compile_instance () | 
|  | { | 
|  | m_gcc_fe->ops->destroy (m_gcc_fe); | 
|  | } | 
|  |  | 
|  | /* Returns the GCC options to be passed during compilation.  */ | 
|  | const std::string &gcc_target_options () const | 
|  | { | 
|  | return m_gcc_target_options; | 
|  | } | 
|  |  | 
|  | /* Query the type cache for TYPE, returning the compiler's | 
|  | type for it in RET.  */ | 
|  | bool get_cached_type (struct type *type, gcc_type *ret) const; | 
|  |  | 
|  | /* Insert GCC_TYPE into the type cache for TYPE. | 
|  |  | 
|  | It is ok for a given type to be inserted more than once, provided that | 
|  | the exact same association is made each time.  */ | 
|  | void insert_type (struct type *type, gcc_type gcc_type); | 
|  |  | 
|  | /* Associate SYMBOL with some error text.  */ | 
|  | void insert_symbol_error (const struct symbol *sym, const char *text); | 
|  |  | 
|  | /* Emit the error message corresponding to SYM, if one exists, and | 
|  | arrange for it not to be emitted again.  */ | 
|  | void error_symbol_once (const struct symbol *sym); | 
|  |  | 
|  | /* These currently just forward to the underlying ops | 
|  | vtable.  */ | 
|  |  | 
|  | /* Set the plug-in print callback.  */ | 
|  | void set_print_callback (void (*print_function) (void *, const char *), | 
|  | void *datum); | 
|  |  | 
|  | /* Return the plug-in's front-end version.  */ | 
|  | unsigned int version () const; | 
|  |  | 
|  | /* Set the plug-in's verbosity level.  Nop for GCC_FE_VERSION_0.  */ | 
|  | void set_verbose (int level); | 
|  |  | 
|  | /* Set the plug-in driver program.  Nop for GCC_FE_VERSION_0.  */ | 
|  | void set_driver_filename (const char *filename); | 
|  |  | 
|  | /* Set the regular expression used to match the configury triplet | 
|  | prefix to the compiler.  Nop for GCC_FE_VERSION_0.  */ | 
|  | void set_triplet_regexp (const char *regexp); | 
|  |  | 
|  | /* Set compilation arguments.  REGEXP is only used for protocol | 
|  | version GCC_FE_VERSION_0.  */ | 
|  | gdb::unique_xmalloc_ptr<char> set_arguments (int argc, char **argv, | 
|  | const char *regexp = NULL); | 
|  |  | 
|  | /* Set the filename of the program to compile.  Nop for GCC_FE_VERSION_0.  */ | 
|  | void set_source_file (const char *filename); | 
|  |  | 
|  | /* Compile the previously specified source file to FILENAME. | 
|  | VERBOSE_LEVEL is only used for protocol version GCC_FE_VERSION_0.  */ | 
|  | bool compile (const char *filename, int verbose_level = -1); | 
|  |  | 
|  | /* Set the scope type for this compile.  */ | 
|  | void set_scope (enum compile_i_scope_types scope) | 
|  | { | 
|  | m_scope = scope; | 
|  | } | 
|  |  | 
|  | /* Return the scope type.  */ | 
|  | enum compile_i_scope_types scope () const | 
|  | { | 
|  | return m_scope; | 
|  | } | 
|  |  | 
|  | /* Set the block to be used for symbol searches.  */ | 
|  | void set_block (const struct block *block) | 
|  | { | 
|  | m_block = block; | 
|  | } | 
|  |  | 
|  | /* Return the search block.  */ | 
|  | const struct block *block () const | 
|  | { | 
|  | return m_block; | 
|  | } | 
|  |  | 
|  | protected: | 
|  |  | 
|  | /* The GCC front end.  */ | 
|  | struct gcc_base_context *m_gcc_fe; | 
|  |  | 
|  | /* The "scope" of this compilation.  */ | 
|  | enum compile_i_scope_types m_scope; | 
|  |  | 
|  | /* The block in which an expression is being parsed.  */ | 
|  | const struct block *m_block; | 
|  |  | 
|  | /* Specify "-std=gnu11", "-std=gnu++11" or similar.  These options are put | 
|  | after CU's DW_AT_producer compilation options to override them.  */ | 
|  | std::string m_gcc_target_options; | 
|  |  | 
|  | /* Map from gdb types to gcc types.  */ | 
|  | htab_up m_type_map; | 
|  |  | 
|  | /* Map from gdb symbols to gcc error messages to emit.  */ | 
|  | htab_up m_symbol_err_map; | 
|  | }; | 
|  |  | 
|  | /* Public function that is called from compile_control case in the | 
|  | expression command.  GDB returns either a CMD, or a CMD_STRING, but | 
|  | never both.  */ | 
|  |  | 
|  | extern void eval_compile_command (struct command_line *cmd, | 
|  | const char *cmd_string, | 
|  | enum compile_i_scope_types scope, | 
|  | void *scope_data); | 
|  |  | 
|  | /* Compile a DWARF location expression to C, suitable for use by the | 
|  | compiler. | 
|  |  | 
|  | STREAM is the stream where the code should be written. | 
|  |  | 
|  | RESULT_NAME is the name of a variable in the resulting C code.  The | 
|  | result of the expression will be assigned to this variable. | 
|  |  | 
|  | SYM is the symbol corresponding to this expression. | 
|  | PC is the location at which the expression is being evaluated. | 
|  | ARCH is the architecture to use. | 
|  |  | 
|  | REGISTERS_USED is an out parameter which is updated to note which | 
|  | registers were needed by this expression. | 
|  |  | 
|  | ADDR_SIZE is the DWARF address size to use. | 
|  |  | 
|  | OPT_PTR and OP_END are the bounds of the DWARF expression. | 
|  |  | 
|  | PER_CU is the per-CU object used for looking up various other | 
|  | things. | 
|  |  | 
|  | PER_OBJFILE is the per-objfile object also used for looking up various other | 
|  | things.  */ | 
|  |  | 
|  | extern void compile_dwarf_expr_to_c (string_file *stream, | 
|  | const char *result_name, | 
|  | struct symbol *sym, | 
|  | CORE_ADDR pc, | 
|  | struct gdbarch *arch, | 
|  | std::vector<bool> ®isters_used, | 
|  | unsigned int addr_size, | 
|  | const gdb_byte *op_ptr, | 
|  | const gdb_byte *op_end, | 
|  | dwarf2_per_cu_data *per_cu, | 
|  | dwarf2_per_objfile *per_objfile); | 
|  |  | 
|  | /* Compile a DWARF bounds expression to C, suitable for use by the | 
|  | compiler. | 
|  |  | 
|  | STREAM is the stream where the code should be written. | 
|  |  | 
|  | RESULT_NAME is the name of a variable in the resulting C code.  The | 
|  | result of the expression will be assigned to this variable. | 
|  |  | 
|  | PROP is the dynamic property for which we're compiling. | 
|  |  | 
|  | SYM is the symbol corresponding to this expression. | 
|  | PC is the location at which the expression is being evaluated. | 
|  | ARCH is the architecture to use. | 
|  |  | 
|  | REGISTERS_USED is an out parameter which is updated to note which | 
|  | registers were needed by this expression. | 
|  |  | 
|  | ADDR_SIZE is the DWARF address size to use. | 
|  |  | 
|  | OPT_PTR and OP_END are the bounds of the DWARF expression. | 
|  |  | 
|  | PER_CU is the per-CU object used for looking up various other | 
|  | things. | 
|  |  | 
|  | PER_OBJFILE is the per-objfile object also used for looking up various other | 
|  | things.  */ | 
|  |  | 
|  | extern void compile_dwarf_bounds_to_c (string_file *stream, | 
|  | const char *result_name, | 
|  | const struct dynamic_prop *prop, | 
|  | struct symbol *sym, CORE_ADDR pc, | 
|  | struct gdbarch *arch, | 
|  | std::vector<bool> ®isters_used, | 
|  | unsigned int addr_size, | 
|  | const gdb_byte *op_ptr, | 
|  | const gdb_byte *op_end, | 
|  | dwarf2_per_cu_data *per_cu, | 
|  | dwarf2_per_objfile *per_objfile); | 
|  |  | 
|  | extern void compile_print_value (struct value *val, void *data_voidp); | 
|  |  | 
|  | /* Command element for the 'compile' command.  */ | 
|  | extern cmd_list_element *compile_cmd_element; | 
|  |  | 
|  | #endif /* COMPILE_COMPILE_H */ |