|  | /* JIT declarations for GDB, the GNU Debugger. | 
|  |  | 
|  | Copyright (C) 2009-2023 Free Software Foundation, Inc. | 
|  |  | 
|  | This file is part of GDB. | 
|  |  | 
|  | 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 JIT_H | 
|  | #define JIT_H | 
|  |  | 
|  | struct inferior; | 
|  | struct objfile; | 
|  | struct minimal_symbol; | 
|  |  | 
|  | /* When the JIT breakpoint fires, the inferior wants us to take one of | 
|  | these actions.  These values are used by the inferior, so the | 
|  | values of these enums cannot be changed.  */ | 
|  |  | 
|  | enum jit_actions_t | 
|  | { | 
|  | JIT_NOACTION = 0, | 
|  | JIT_REGISTER, | 
|  | JIT_UNREGISTER | 
|  | }; | 
|  |  | 
|  | /* This struct describes a single symbol file in a linked list of | 
|  | symbol files describing generated code.  As the inferior generates | 
|  | code, it adds these entries to the list, and when we attach to the | 
|  | inferior, we read them all.  For the first element prev_entry | 
|  | should be NULL, and for the last element next_entry should be | 
|  | NULL.  */ | 
|  |  | 
|  | struct jit_code_entry | 
|  | { | 
|  | CORE_ADDR next_entry; | 
|  | CORE_ADDR prev_entry; | 
|  | CORE_ADDR symfile_addr; | 
|  | ULONGEST symfile_size; | 
|  | }; | 
|  |  | 
|  | /* This is the global descriptor that the inferior uses to communicate | 
|  | information to the debugger.  To alert the debugger to take an | 
|  | action, the inferior sets the action_flag to the appropriate enum | 
|  | value, updates relevant_entry to point to the relevant code entry, | 
|  | and calls the function at the well-known symbol with our | 
|  | breakpoint.  We then read this descriptor from another global | 
|  | well-known symbol.  */ | 
|  |  | 
|  | struct jit_descriptor | 
|  | { | 
|  | uint32_t version; | 
|  | /* This should be jit_actions_t, but we want to be specific about the | 
|  | bit-width.  */ | 
|  | uint32_t action_flag; | 
|  | CORE_ADDR relevant_entry; | 
|  | CORE_ADDR first_entry; | 
|  | }; | 
|  |  | 
|  | /* An objfile that defines the required symbols of the JIT interface has an | 
|  | instance of this type attached to it.  */ | 
|  |  | 
|  | struct jiter_objfile_data | 
|  | { | 
|  | ~jiter_objfile_data (); | 
|  |  | 
|  | /* Symbol for __jit_debug_register_code.  */ | 
|  | minimal_symbol *register_code = nullptr; | 
|  |  | 
|  | /* Symbol for __jit_debug_descriptor.  */ | 
|  | minimal_symbol *descriptor = nullptr; | 
|  |  | 
|  | /* This is the relocated address of the __jit_debug_register_code function | 
|  | provided by this objfile.  This is used to detect relocations changes | 
|  | requiring the breakpoint to be re-created.  */ | 
|  | CORE_ADDR cached_code_address = 0; | 
|  |  | 
|  | /* This is the JIT event breakpoint, or nullptr if it has been deleted.  */ | 
|  | breakpoint *jit_breakpoint = nullptr; | 
|  | }; | 
|  |  | 
|  | /* An objfile that is the product of JIT compilation and was registered | 
|  | using the JIT interface has an instance of this type attached to it.  */ | 
|  |  | 
|  | struct jited_objfile_data | 
|  | { | 
|  | jited_objfile_data (CORE_ADDR addr, CORE_ADDR symfile_addr, | 
|  | ULONGEST symfile_size) | 
|  | : addr (addr), | 
|  | symfile_addr (symfile_addr), | 
|  | symfile_size (symfile_size) | 
|  | {} | 
|  |  | 
|  | /* Address of struct jit_code_entry for this objfile.  */ | 
|  | CORE_ADDR addr; | 
|  |  | 
|  | /* Value of jit_code_entry->symfile_addr for this objfile.  */ | 
|  | CORE_ADDR symfile_addr; | 
|  |  | 
|  | /* Value of jit_code_entry->symfile_size for this objfile.  */ | 
|  | ULONGEST symfile_size; | 
|  | }; | 
|  |  | 
|  | /* Re-establish the jit breakpoint(s).  */ | 
|  |  | 
|  | extern void jit_breakpoint_re_set (void); | 
|  |  | 
|  | /* This function is called by handle_inferior_event when it decides | 
|  | that the JIT event breakpoint has fired.  JITER is the objfile | 
|  | whose JIT event breakpoint has been hit.  */ | 
|  |  | 
|  | extern void jit_event_handler (gdbarch *gdbarch, objfile *jiter); | 
|  |  | 
|  | #endif /* JIT_H */ |