4 * Copyright (c) 2022 Linaro Ltd
6 * SPDX-License-Identifier: GPL-2.0-or-later
9 #ifndef GDBSTUB_INTERNALS_H
10 #define GDBSTUB_INTERNALS_H
12 #include "exec/cpu-common.h"
14 #define MAX_PACKET_LENGTH 4096
17 * Shared structures and definitions
30 GDB_SIGNAL_UNKNOWN
= 143
33 typedef struct GDBProcess
{
49 typedef struct GDBState
{
50 bool init
; /* have we been initialised? */
51 CPUState
*c_cpu
; /* current CPU for step/continue ops */
52 CPUState
*g_cpu
; /* current CPU for other ops */
53 CPUState
*query_cpu
; /* for q{f|s}ThreadInfo */
54 enum RSState state
; /* parsing state */
55 char line_buf
[MAX_PACKET_LENGTH
];
57 int line_sum
; /* running checksum */
58 int line_csum
; /* checksum at the end of the packet */
59 GByteArray
*last_packet
;
62 GDBProcess
*processes
;
67 int supported_sstep_flags
;
69 * Whether we are allowed to send a stop reply packet at this moment.
70 * Must be set off after sending the stop reply itself.
72 bool allow_stop_reply
;
75 /* lives in main gdbstub.c */
76 extern GDBState gdbserver_state
;
79 * Inline utility function, convert from int to hex and back
82 static inline int fromhex(int v
)
84 if (v
>= '0' && v
<= '9') {
86 } else if (v
>= 'A' && v
<= 'F') {
88 } else if (v
>= 'a' && v
<= 'f') {
95 static inline int tohex(int v
)
105 * Connection helpers for both system and user backends
108 void gdb_put_strbuf(void);
109 int gdb_put_packet(const char *buf
);
110 int gdb_put_packet_binary(const char *buf
, int len
, bool dump
);
111 void gdb_hextomem(GByteArray
*mem
, const char *buf
, int len
);
112 void gdb_memtohex(GString
*buf
, const uint8_t *mem
, int len
);
113 void gdb_memtox(GString
*buf
, const char *mem
, int len
);
114 void gdb_read_byte(uint8_t ch
);
117 * Packet acknowledgement - we handle this slightly differently
118 * between user and softmmu mode, mainly to deal with the differences
119 * between the flexible chardev and the direct fd approaches.
121 * We currently don't support a negotiated QStartNoAckMode
125 * gdb_got_immediate_ack() - check ok to continue
127 * Returns true to continue, false to re-transmit for user only, the
128 * softmmu stub always returns true.
130 bool gdb_got_immediate_ack(void);
131 /* utility helpers */
132 GDBProcess
*gdb_get_process(uint32_t pid
);
133 CPUState
*gdb_get_first_cpu_in_process(GDBProcess
*process
);
134 CPUState
*gdb_first_attached_cpu(void);
135 void gdb_append_thread_id(CPUState
*cpu
, GString
*buf
);
136 int gdb_get_cpu_index(CPUState
*cpu
);
137 unsigned int gdb_get_max_cpus(void); /* both */
138 bool gdb_can_reverse(void); /* softmmu, stub for user */
140 void gdb_create_default_process(GDBState
*s
);
142 /* signal mapping, common for softmmu, specialised for user-mode */
143 int gdb_signal_to_target(int sig
);
144 int gdb_target_signal_to_gdb(int sig
);
146 int gdb_get_char(void); /* user only */
149 * gdb_continue() - handle continue in mode specific way.
151 void gdb_continue(void);
154 * gdb_continue_partial() - handle partial continue in mode specific way.
156 int gdb_continue_partial(char *newstates
);
159 * Helpers with separate softmmu and user implementations
161 void gdb_put_buffer(const uint8_t *buf
, int len
);
164 * Command handlers - either specialised or softmmu or user only
166 void gdb_init_gdbserver_state(void);
168 typedef enum GDBThreadIdKind
{
170 GDB_ALL_THREADS
, /* One process, all threads */
175 typedef union GdbCmdVariant
{
178 unsigned long val_ul
;
179 unsigned long long val_ull
;
181 GDBThreadIdKind kind
;
187 #define get_param(p, i) (&g_array_index(p, GdbCmdVariant, i))
189 void gdb_handle_query_rcmd(GArray
*params
, void *user_ctx
); /* softmmu */
190 void gdb_handle_query_offsets(GArray
*params
, void *user_ctx
); /* user */
191 void gdb_handle_query_xfer_auxv(GArray
*params
, void *user_ctx
); /*user */
192 void gdb_handle_v_file_open(GArray
*params
, void *user_ctx
); /* user */
193 void gdb_handle_v_file_close(GArray
*params
, void *user_ctx
); /* user */
194 void gdb_handle_v_file_pread(GArray
*params
, void *user_ctx
); /* user */
195 void gdb_handle_v_file_readlink(GArray
*params
, void *user_ctx
); /* user */
196 void gdb_handle_query_xfer_exec_file(GArray
*params
, void *user_ctx
); /* user */
198 void gdb_handle_query_attached(GArray
*params
, void *user_ctx
); /* both */
201 void gdb_handle_query_qemu_phy_mem_mode(GArray
*params
, void *user_ctx
);
202 void gdb_handle_set_qemu_phy_mem_mode(GArray
*params
, void *user_ctx
);
204 /* sycall handling */
205 void gdb_handle_file_io(GArray
*params
, void *user_ctx
);
206 bool gdb_handled_syscall(void);
207 void gdb_disable_syscalls(void);
208 void gdb_syscall_reset(void);
210 /* user/softmmu specific syscall handling */
211 void gdb_syscall_handling(const char *syscall_packet
);
214 * Break/Watch point support - there is an implementation for softmmu
217 bool gdb_supports_guest_debug(void);
218 int gdb_breakpoint_insert(CPUState
*cs
, int type
, vaddr addr
, vaddr len
);
219 int gdb_breakpoint_remove(CPUState
*cs
, int type
, vaddr addr
, vaddr len
);
220 void gdb_breakpoint_remove_all(CPUState
*cs
);
223 * gdb_target_memory_rw_debug() - handle debug access to memory
225 * @addr: nominal address, could be an entire physical address
227 * @len: length of access
228 * @is_write: is it a write operation
230 * This function is specialised depending on the mode we are running
231 * in. For system guests we can switch the interpretation of the
232 * address to a physical address.
234 int gdb_target_memory_rw_debug(CPUState
*cs
, hwaddr addr
,
235 uint8_t *buf
, int len
, bool is_write
);
237 #endif /* GDBSTUB_INTERNALS_H */