1 /* Main code for remote server for GDB.
2 Copyright (C) 1989, 1993, 1994, 1995, 1997, 1998, 1999, 2000, 2002, 2003,
3 2004, 2005, 2006, 2011
4 Free Software Foundation, Inc.
5
6 This file is part of GDB.
7 It has been modified to integrate it in valgrind
8
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2 of the License, or
12 (at your option) any later version.
13
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 51 Franklin Street, Fifth Floor,
22 Boston, MA 02110-1301, USA. */
23
24 #include "server.h"
25 #include "regdef.h"
26 #include "pub_core_options.h"
27 #include "pub_core_translate.h"
28 #include "pub_core_mallocfree.h"
29 #include "pub_core_initimg.h"
30 #include "pub_core_execontext.h"
31 #include "pub_core_syswrap.h" // VG_(show_open_fds)
32 #include "pub_core_scheduler.h"
33 #include "pub_core_transtab.h"
34 #include "pub_core_debuginfo.h"
35 #include "pub_core_addrinfo.h"
36 #include "pub_core_aspacemgr.h"
37
38 unsigned long cont_thread;
39 unsigned long general_thread;
40 unsigned long step_thread;
41 unsigned long thread_from_wait;
42 unsigned long old_thread_from_wait;
43
44 int pass_signals[TARGET_SIGNAL_LAST]; /* indexed by gdb signal nr */
45
46 /* for a gdbserver integrated in valgrind, resuming the process consists
47 in returning the control to valgrind.
48 The guess process resumes its execution.
49 Then at the next error or break or ..., valgrind calls gdbserver again.
50 A resume reply packet must then be built to inform GDB that the
51 resume request is finished.
52 resume_reply_packet_needed records the fact that the next call to gdbserver
53 must send a resume packet to gdb. */
54 static Bool resume_reply_packet_needed = False;
55
56 VG_MINIMAL_JMP_BUF(toplevel);
57
58 /* Decode a qXfer read request. Return 0 if everything looks OK,
59 or -1 otherwise. */
60
61 static
decode_xfer_read(char * buf,const char ** annex,CORE_ADDR * ofs,unsigned int * len)62 int decode_xfer_read (char *buf, const char **annex, CORE_ADDR *ofs, unsigned int *len)
63 {
64 /* Extract and NUL-terminate the annex. */
65 *annex = buf;
66 while (*buf && *buf != ':')
67 buf++;
68 if (*buf == '\0')
69 return -1;
70 *buf++ = 0;
71
72 /* After the read/write marker and annex, qXfer looks like a
73 traditional 'm' packet. */
74 decode_m_packet (buf, ofs, len);
75
76 return 0;
77 }
78
79 /* Write the response to a successful qXfer read. Returns the
80 length of the (binary) data stored in BUF, corresponding
81 to as much of DATA/LEN as we could fit. IS_MORE controls
82 the first character of the response. */
83 static
write_qxfer_response(char * buf,unsigned char * data,int len,int is_more)84 int write_qxfer_response (char *buf, unsigned char *data, int len, int is_more)
85 {
86 int out_len;
87
88 if (is_more)
89 buf[0] = 'm';
90 else
91 buf[0] = 'l';
92
93 return remote_escape_output (data, len, (unsigned char *) buf + 1, &out_len,
94 PBUFSIZ - POVERHSIZ - 1) + 1;
95 }
96
97 static Bool initial_valgrind_sink_saved = False;
98 /* True <=> valgrind log sink saved in initial_valgrind_sink */
99 static OutputSink initial_valgrind_sink;
100
101 static Bool command_output_to_log = False;
102 /* True <=> command output goes to log instead of gdb */
103
reset_valgrind_sink(const char * info)104 void reset_valgrind_sink(const char *info)
105 {
106 if (VG_(log_output_sink).fd != initial_valgrind_sink.fd
107 && initial_valgrind_sink_saved) {
108 VG_(log_output_sink).fd = initial_valgrind_sink.fd;
109 VG_(umsg) ("Reset valgrind output to log (%s)\n",
110 (info = NULL ? "" : info));
111 }
112 }
113
print_to_initial_valgrind_sink(const char * msg)114 void print_to_initial_valgrind_sink (const char *msg)
115 {
116 vg_assert (initial_valgrind_sink_saved);
117 VG_(write) (initial_valgrind_sink.fd, msg, strlen(msg));
118 }
119
120
121 static
kill_request(const char * msg)122 void kill_request (const char *msg)
123 {
124 VG_(umsg) ("%s", msg);
125 VG_(exit) (0);
126 }
127
128 // s is a NULL terminated string made of O or more words (separated by spaces).
129 // Returns a pointer to the Nth word in s.
130 // If Nth word does not exist, return a pointer to the last (0) byte of s.
131 static
wordn(const char * s,int n)132 const char *wordn (const char *s, int n)
133 {
134 int word_seen = 0;
135 Bool searching_word = True;
136
137 while (*s) {
138 if (*s == ' ')
139 searching_word = True;
140 else {
141 if (searching_word) {
142 searching_word = False;
143 word_seen++;
144 if (word_seen == n)
145 return s;
146 }
147 }
148 s++;
149 }
150 return s;
151 }
152
VG_(print_all_stats)153 void VG_(print_all_stats) (Bool memory_stats, Bool tool_stats)
154 {
155 if (memory_stats) {
156 VG_(message)(Vg_DebugMsg, "\n");
157 VG_(message)(Vg_DebugMsg,
158 "------ Valgrind's internal memory use stats follow ------\n" );
159 VG_(sanity_check_malloc_all)();
160 VG_(message)
161 (Vg_DebugMsg,
162 "------ %'13llu bytes have already been mmap-ed ANONYMOUS.\n",
163 VG_(am_get_anonsize_total)());
164 VG_(print_all_arena_stats)();
165 if (VG_(clo_profile_heap))
166 VG_(print_arena_cc_analysis) ();
167 VG_(message)(Vg_DebugMsg, "\n");
168 }
169
170 VG_(print_translation_stats)();
171 VG_(print_tt_tc_stats)();
172 VG_(print_scheduler_stats)();
173 VG_(print_ExeContext_stats)( False /* with_stacktraces */ );
174 VG_(print_errormgr_stats)();
175 if (tool_stats && VG_(needs).print_stats) {
176 VG_TDICT_CALL(tool_print_stats);
177 }
178 }
179
180 /* handle_gdb_valgrind_command handles the provided mon string command.
181 If command is recognised, return 1 else return 0.
182 Note that in case of ambiguous command, 1 is returned.
183
184 *sink_wanted_at_return is modified if one of the commands
185 'v.set *_output' is handled.
186 */
187 static
handle_gdb_valgrind_command(char * mon,OutputSink * sink_wanted_at_return)188 int handle_gdb_valgrind_command (char *mon, OutputSink *sink_wanted_at_return)
189 {
190 UWord ret = 0;
191 char s[strlen(mon)+1]; /* copy for strtok_r */
192 char *wcmd;
193 HChar *ssaveptr;
194 const char *endptr;
195 int kwdid;
196 int int_value;
197
198 vg_assert (initial_valgrind_sink_saved);
199
200 strcpy (s, mon);
201 wcmd = strtok_r (s, " ", &ssaveptr);
202 /* NB: if possible, avoid introducing a new command below which
203 starts with the same 3 first letters as an already existing
204 command. This ensures a shorter abbreviation for the user. */
205 switch (VG_(keyword_id) ("help v.set v.info v.wait v.kill v.translate"
206 " v.do",
207 wcmd, kwd_report_duplicated_matches)) {
208 case -2:
209 ret = 1;
210 break;
211 case -1:
212 break;
213 case 0: /* help */
214 ret = 1;
215 wcmd = strtok_r (NULL, " ", &ssaveptr);
216 if (wcmd == NULL) {
217 int_value = 0;
218 } else {
219 switch (VG_(keyword_id) ("debug", wcmd, kwd_report_all)) {
220 case -2: int_value = 0; break;
221 case -1: int_value = 0; break;
222 case 0: int_value = 1; break;
223 default: vg_assert (0);
224 }
225 }
226
227 VG_(gdb_printf) (
228 "general valgrind monitor commands:\n"
229 " help [debug] : monitor command help. With debug: + debugging commands\n"
230 " v.wait [<ms>] : sleep <ms> (default 0) then continue\n"
231 " v.info all_errors : show all errors found so far\n"
232 " v.info last_error : show last error found\n"
233 " v.info location <addr> : show information about location <addr>\n"
234 " v.info n_errs_found [msg] : show the nr of errors found so far and the given msg\n"
235 " v.info open_fds : show open file descriptors (only if --track-fds=yes)\n"
236 " v.kill : kill the Valgrind process\n"
237 " v.set gdb_output : set valgrind output to gdb\n"
238 " v.set log_output : set valgrind output to log\n"
239 " v.set mixed_output : set valgrind output to log, interactive output to gdb\n"
240 " v.set merge-recursive-frames <num> : merge recursive calls in max <num> frames\n"
241 " v.set vgdb-error <errornr> : debug me at error >= <errornr> \n");
242 if (int_value) { VG_(gdb_printf) (
243 "debugging valgrind internals monitor commands:\n"
244 " v.do expensive_sanity_check_general : do an expensive sanity check now\n"
245 " v.info gdbserver_status : show gdbserver status\n"
246 " v.info memory [aspacemgr] : show valgrind heap memory stats\n"
247 " (with aspacemgr arg, also shows valgrind segments on log output)\n"
248 " v.info exectxt : show stacktraces and stats of all execontexts\n"
249 " v.info scheduler : show valgrind thread state and stacktrace\n"
250 " v.info stats : show various valgrind and tool stats\n"
251 " v.info unwind <addr> [<len>] : show unwind debug info for <addr> .. <addr+len>\n"
252 " v.set debuglog <level> : set valgrind debug log level to <level>\n"
253 " v.set hostvisibility [yes*|no] : (en/dis)ables access by gdb/gdbserver to\n"
254 " Valgrind internal host status/memory\n"
255 " v.translate <addr> [<traceflags>] : debug translation of <addr> with <traceflags>\n"
256 " (default traceflags 0b00100000 : show after instrumentation)\n"
257 " An additional flag 0b100000000 allows to show gdbserver instrumentation\n");
258 }
259 break;
260 case 1: /* v.set */
261 ret = 1;
262 wcmd = strtok_r (NULL, " ", &ssaveptr);
263 switch (kwdid = VG_(keyword_id)
264 ("vgdb-error debuglog merge-recursive-frames"
265 " gdb_output log_output mixed_output hostvisibility",
266 wcmd, kwd_report_all)) {
267 case -2:
268 case -1:
269 break;
270 case 0: /* vgdb-error */
271 case 1: /* debuglog */
272 case 2: /* merge-recursive-frames */
273 wcmd = strtok_r (NULL, " ", &ssaveptr);
274 if (wcmd == NULL) {
275 int_value = 0;
276 endptr = "empty"; /* to report an error below */
277 } else {
278 HChar *the_end;
279 int_value = strtol (wcmd, &the_end, 10);
280 endptr = the_end;
281 }
282 if (*endptr != '\0') {
283 VG_(gdb_printf) ("missing or malformed integer value\n");
284 } else if (kwdid == 0) {
285 VG_(printf) ("vgdb-error value changed from %d to %d\n",
286 VG_(dyn_vgdb_error), int_value);
287 VG_(dyn_vgdb_error) = int_value;
288 } else if (kwdid == 1) {
289 VG_(printf) ("debuglog value changed from %d to %d\n",
290 VG_(debugLog_getLevel)(), int_value);
291 VG_(debugLog_startup) (int_value, "gdbsrv");
292 } else if (kwdid == 2) {
293 VG_(printf)
294 ("merge-recursive-frames value changed from %d to %d\n",
295 VG_(clo_merge_recursive_frames), int_value);
296 VG_(clo_merge_recursive_frames) = int_value;
297 } else {
298 vg_assert (0);
299 }
300 break;
301 case 3: /* gdb_output */
302 (*sink_wanted_at_return).fd = -2;
303 command_output_to_log = False;
304 VG_(gdb_printf) ("valgrind output will go to gdb\n");
305 break;
306 case 4: /* log_output */
307 (*sink_wanted_at_return).fd = initial_valgrind_sink.fd;
308 command_output_to_log = True;
309 VG_(gdb_printf) ("valgrind output will go to log\n");
310 break;
311 case 5: /* mixed output */
312 (*sink_wanted_at_return).fd = initial_valgrind_sink.fd;
313 command_output_to_log = False;
314 VG_(gdb_printf)
315 ("valgrind output will go to log, "
316 "interactive output will go to gdb\n");
317 break;
318 case 6: /* hostvisibility */
319 wcmd = strtok_r (NULL, " ", &ssaveptr);
320 if (wcmd != NULL) {
321 switch (VG_(keyword_id) ("yes no", wcmd, kwd_report_all)) {
322 case -2:
323 case -1: break;
324 case 0:
325 hostvisibility = True;
326 break;
327 case 1:
328 hostvisibility = False;
329 break;
330 default: vg_assert (0);
331 }
332 } else {
333 hostvisibility = True;
334 }
335 if (hostvisibility) {
336 const DebugInfo *tooldi
337 = VG_(find_DebugInfo) ((Addr)handle_gdb_valgrind_command);
338 /* Normally, we should always find the tooldi. In case we
339 do not, suggest a 'likely somewhat working' address: */
340 const Addr tool_text_start
341 = tooldi ?
342 VG_(DebugInfo_get_text_avma) (tooldi) : 0x38000000;
343 const NSegment *toolseg
344 = tooldi ?
345 VG_(am_find_nsegment) (VG_(DebugInfo_get_text_avma) (tooldi))
346 : NULL;
347 VG_(gdb_printf)
348 ("Enabled access to Valgrind memory/status by GDB\n"
349 "If not yet done, tell GDB which valgrind file(s) to use, "
350 "typically:\n"
351 "add-symbol-file %s %p\n",
352 toolseg ? VG_(am_get_filename)(toolseg)
353 : "<toolfile> <address> e.g.",
354 (void*)tool_text_start);
355 } else
356 VG_(gdb_printf)
357 ("Disabled access to Valgrind memory/status by GDB\n");
358 break;
359 default:
360 vg_assert (0);
361 }
362 break;
363 case 2: /* v.info */ {
364 ret = 1;
365 wcmd = strtok_r (NULL, " ", &ssaveptr);
366 switch (kwdid = VG_(keyword_id)
367 ("all_errors n_errs_found last_error gdbserver_status memory"
368 " scheduler stats open_fds exectxt location unwind",
369 wcmd, kwd_report_all)) {
370 case -2:
371 case -1:
372 break;
373 case 0: // all_errors
374 // A verbosity of minimum 2 is needed to show the errors.
375 VG_(show_all_errors)(/* verbosity */ 2, /* xml */ False);
376 break;
377 case 1: // n_errs_found
378 VG_(printf) ("n_errs_found %u n_errs_shown %u (vgdb-error %d) %s\n",
379 VG_(get_n_errs_found) (),
380 VG_(get_n_errs_shown) (),
381 VG_(dyn_vgdb_error),
382 wordn (mon, 3));
383 break;
384 case 2: // last_error
385 VG_(show_last_error)();
386 break;
387 case 3: // gdbserver_status
388 VG_(gdbserver_status_output)();
389 break;
390 case 4: /* memory */
391 VG_(printf) ("%'13llu bytes have already been mmap-ed ANONYMOUS.\n",
392 VG_(am_get_anonsize_total)());
393 VG_(print_all_arena_stats) ();
394 if (VG_(clo_profile_heap))
395 VG_(print_arena_cc_analysis) ();
396 wcmd = strtok_r (NULL, " ", &ssaveptr);
397 if (wcmd != NULL) {
398 switch (VG_(keyword_id) ("aspacemgr", wcmd, kwd_report_all)) {
399 case -2:
400 case -1: break;
401 case 0:
402 VG_(am_show_nsegments) (0, "gdbserver v.info memory aspacemgr");
403 break;
404 default: vg_assert (0);
405 }
406 }
407
408 ret = 1;
409 break;
410 case 5: /* scheduler */
411 VG_(show_sched_status) (True, // host_stacktrace
412 True, // stack_usage
413 True); // exited_threads
414 ret = 1;
415 break;
416 case 6: /* stats */
417 VG_(print_all_stats)(False, /* Memory stats */
418 True /* Tool stats */);
419 ret = 1;
420 break;
421 case 7: /* open_fds */
422 if (VG_(clo_track_fds))
423 VG_(show_open_fds) ("");
424 else
425 VG_(gdb_printf)
426 ("Valgrind must be started with --track-fds=yes"
427 " to show open fds\n");
428 ret = 1;
429 break;
430 case 8: /* exectxt */
431 VG_(print_ExeContext_stats) (True /* with_stacktraces */);
432 ret = 1;
433 break;
434 case 9: { /* location */
435 /* Note: we prefer 'v.info location' and not 'v.info address' as
436 v.info address is inconsistent with the GDB (native)
437 command 'info address' which gives the address for a symbol.
438 GDB equivalent command of 'v.info location' is 'info symbol'. */
439 Addr address;
440 SizeT dummy_sz = 0x1234;
441 if (VG_(strtok_get_address_and_size) (&address,
442 &dummy_sz, &ssaveptr)) {
443 // If tool provides location information, use that.
444 if (VG_(needs).info_location) {
445 VG_TDICT_CALL(tool_info_location, address);
446 }
447 // If tool does not provide location info, use the common one.
448 // Also use the common to compare with tool when debug log is set.
449 if (!VG_(needs).info_location || VG_(debugLog_getLevel)() > 0 ) {
450 AddrInfo ai;
451 ai.tag = Addr_Undescribed;
452 VG_(describe_addr) (address, &ai);
453 VG_(pp_addrinfo) (address, &ai);
454 VG_(clear_addrinfo) (&ai);
455 }
456 }
457 ret = 1;
458 break;
459 }
460 case 10: { /* unwind */
461 Addr address;
462 SizeT sz = 1;
463 if (VG_(strtok_get_address_and_size) (&address,
464 &sz, &ssaveptr)) {
465 VG_(ppUnwindInfo) (address, address + sz - 1);
466 }
467 ret = 1;
468 break;
469 }
470
471 default:
472 vg_assert(0);
473 }
474 break;
475 }
476 case 3: /* v.wait */
477 wcmd = strtok_r (NULL, " ", &ssaveptr);
478 if (wcmd != NULL) {
479 int_value = strtol (wcmd, NULL, 10);
480 VG_(printf) ("gdbserver: continuing in %d ms ...\n", int_value);
481 VG_(poll)(NULL, 0, int_value);
482 }
483 VG_(printf) ("gdbserver: continuing after wait ...\n");
484 ret = 1;
485 break;
486 case 4: /* v.kill */
487 kill_request ("monitor command request to kill this process\n");
488 break;
489 case 5: { /* v.translate */
490 Addr address;
491 SizeT verbosity = 0x20;
492
493 ret = 1;
494
495 if (VG_(strtok_get_address_and_size) (&address, &verbosity, &ssaveptr)) {
496 /* we need to force the output to log for the translation trace,
497 as low level VEX tracing cannot be redirected to gdb. */
498 int saved_command_output_to_log = command_output_to_log;
499 int saved_fd = VG_(log_output_sink).fd;
500 Bool single_stepping_on_entry = valgrind_single_stepping();
501 int vex_verbosity = verbosity & 0xff;
502 VG_(log_output_sink).fd = initial_valgrind_sink.fd;
503 if ((verbosity & 0x100) && !single_stepping_on_entry) {
504 valgrind_set_single_stepping(True);
505 // to force gdbserver instrumentation.
506 }
507 # if defined(VGA_arm)
508 // on arm, we need to (potentially) convert this address
509 // to the thumb form.
510 address = thumb_pc (address);
511 # endif
512
513 VG_(translate) ( 0 /* dummy ThreadId; irrelevant due to debugging*/,
514 address,
515 /*debugging*/True,
516 (Int) vex_verbosity,
517 /*bbs_done*/0,
518 /*allow redir?*/True);
519 if ((verbosity & 0x100) && !single_stepping_on_entry) {
520 valgrind_set_single_stepping(False);
521 // reset single stepping.
522 }
523 command_output_to_log = saved_command_output_to_log;
524 VG_(log_output_sink).fd = saved_fd;
525 }
526 break;
527 }
528
529 case 6: /* v.do */
530 ret = 1;
531 wcmd = strtok_r (NULL, " ", &ssaveptr);
532 switch (VG_(keyword_id) ("expensive_sanity_check_general",
533 wcmd, kwd_report_all)) {
534 case -2:
535 case -1: break;
536 case 0: { /* expensive_sanity_check_general */
537 // Temporarily bump up sanity level to check e.g. the malloc arenas.
538 const Int save_clo_sanity_level = VG_(clo_sanity_level);
539 if (VG_(clo_sanity_level) < 4) VG_(clo_sanity_level) = 4;
540 VG_(sanity_check_general) (/* force_expensive */ True);
541 VG_(clo_sanity_level) = save_clo_sanity_level;
542 break;
543 }
544 default: vg_assert (0);
545 }
546 break;
547
548 default:
549 vg_assert (0);
550 }
551 return ret;
552 }
553
554 /* handle_gdb_monitor_command handles the provided mon string command,
555 which can be either a "standard" valgrind monitor command
556 or a tool specific monitor command.
557 If command recognised, return 1 else return 0.
558 Note that in case of ambiguous command, 1 is returned.
559 */
560 static
handle_gdb_monitor_command(char * mon)561 int handle_gdb_monitor_command (char *mon)
562 {
563 UWord ret = 0;
564 UWord tool_ret = 0;
565 // initially, we assume that when returning, the desired sink is the
566 // one we have when entering. It can however be changed by the standard
567 // valgrind command handling.
568 OutputSink sink_wanted_at_return = VG_(log_output_sink);
569 // When using gdbserver, we temporarily disable xml output.
570 Bool save_clo_xml = VG_(clo_xml);
571 VG_(clo_xml) = False;
572
573 if (!initial_valgrind_sink_saved) {
574 /* first time we enter here, we save the valgrind default log sink */
575 initial_valgrind_sink = sink_wanted_at_return;
576 initial_valgrind_sink_saved = True;
577 }
578
579 if (!command_output_to_log)
580 VG_(log_output_sink).fd = -2; /* redirect to monitor_output */
581
582 ret = handle_gdb_valgrind_command (mon, &sink_wanted_at_return);
583
584 /* Even if command was recognised by valgrind core, we call the
585 tool command handler : this is needed to handle help command
586 and/or to let the tool do some additional processing of a
587 valgrind standard command. Note however that if valgrind
588 recognised the command, we will always return success. */
589 if (VG_(needs).client_requests) {
590 /* If the tool reports an error when handling a monitor command,
591 we need to avoid calling gdbserver during this command
592 handling. So, we temporarily set VG_(dyn_vgdb_error) to
593 a huge value to ensure m_errormgr.c does not call gdbserver. */
594 Int save_dyn_vgdb_error = VG_(dyn_vgdb_error);
595 UWord arg[2];
596 VG_(dyn_vgdb_error) = 999999999;
597 arg[0] = (UWord) VG_USERREQ__GDB_MONITOR_COMMAND;
598 arg[1] = (UWord) mon;
599 VG_TDICT_CALL(tool_handle_client_request, VG_(running_tid), arg,
600 &tool_ret);
601 VG_(dyn_vgdb_error) = save_dyn_vgdb_error;
602 }
603
604 VG_(message_flush) ();
605
606 /* restore or set the desired output */
607 VG_(log_output_sink).fd = sink_wanted_at_return.fd;
608 VG_(clo_xml) = save_clo_xml;
609
610 if (ret | tool_ret)
611 return 1;
612 else
613 return 0;
614 }
615
616
617 /* Handle all of the extended 'Q' packets. */
618 static
handle_set(char * arg_own_buf,int * new_packet_len_p)619 void handle_set (char *arg_own_buf, int *new_packet_len_p)
620 {
621 if (strcmp ("QStartNoAckMode", arg_own_buf) == 0) {
622 noack_mode = True;
623 write_ok (arg_own_buf);
624 return;
625 }
626
627 if (strncmp ("QPassSignals:", arg_own_buf, 13) == 0) {
628 int i;
629 char *from, *to;
630 char *end = arg_own_buf + strlen(arg_own_buf);
631 CORE_ADDR sig;
632 for (i = 0; i < TARGET_SIGNAL_LAST; i++)
633 pass_signals[i] = 0;
634
635 from = arg_own_buf + 13;
636 while (from < end) {
637 to = strchr(from, ';');
638 if (to == NULL) to = end;
639 decode_address (&sig, from, to - from);
640 pass_signals[(int)sig] = 1;
641 dlog(3, "pass_signal gdb_nr %d %s\n",
642 (int)sig, target_signal_to_name(sig));
643 from = to;
644 if (*from == ';') from++;
645 }
646 write_ok (arg_own_buf);
647 return;
648 }
649 /* Otherwise we didn't know what packet it was. Say we didn't
650 understand it. */
651 arg_own_buf[0] = 0;
652 }
653
VG_(client_monitor_command)654 Bool VG_(client_monitor_command) (HChar *cmd)
655 {
656 const Bool connected = remote_connected();
657 const int saved_command_output_to_log = command_output_to_log;
658 Bool handled;
659
660 if (!connected)
661 command_output_to_log = True;
662 handled = handle_gdb_monitor_command (cmd);
663 if (!connected) {
664 // reset the log output unless cmd changed it.
665 if (command_output_to_log)
666 command_output_to_log = saved_command_output_to_log;
667 }
668 if (handled)
669 return False; // recognised
670 else
671 return True; // not recognised
672 }
673
674 /* Handle all of the extended 'q' packets. */
675 static
handle_query(char * arg_own_buf,int * new_packet_len_p)676 void handle_query (char *arg_own_buf, int *new_packet_len_p)
677 {
678 static struct inferior_list_entry *thread_ptr;
679
680 /* thread local storage query */
681 if (strncmp ("qGetTLSAddr:", arg_own_buf, 12) == 0) {
682 char *from, *to;
683 char *end = arg_own_buf + strlen(arg_own_buf);
684 unsigned long gdb_id;
685 CORE_ADDR lm;
686 CORE_ADDR offset;
687 struct thread_info *ti;
688
689 from = arg_own_buf + 12;
690 to = strchr(from, ',');
691 *to = 0;
692 gdb_id = strtoul (from, NULL, 16);
693 from = to + 1;
694 to = strchr(from, ',');
695 decode_address (&offset, from, to - from);
696 from = to + 1;
697 to = end;
698 decode_address (&lm, from, to - from);
699 dlog(2, "qGetTLSAddr thread %lu offset %p lm %p\n",
700 gdb_id, (void*)offset, (void*)lm);
701
702 ti = gdb_id_to_thread (gdb_id);
703 if (ti != NULL) {
704 ThreadState *tst;
705 Addr tls_addr;
706
707 tst = (ThreadState *) inferior_target_data (ti);
708 if (valgrind_get_tls_addr(tst, offset, lm, &tls_addr)) {
709 VG_(sprintf) (arg_own_buf, "%lx", tls_addr);
710 return;
711 }
712 // else we will report we do not support qGetTLSAddr
713 } else {
714 write_enn (arg_own_buf);
715 return;
716 }
717 }
718
719 /* qRcmd, monitor command handling. */
720 if (strncmp ("qRcmd,", arg_own_buf, 6) == 0) {
721 char *p = arg_own_buf + 6;
722 int cmdlen = strlen(p)/2;
723 char cmd[cmdlen+1];
724
725 if (unhexify (cmd, p, cmdlen) != cmdlen) {
726 write_enn (arg_own_buf);
727 return;
728 }
729 cmd[cmdlen] = '\0';
730
731 if (handle_gdb_monitor_command (cmd)) {
732 write_ok (arg_own_buf);
733 return;
734 } else {
735 /* cmd not recognised */
736 VG_(gdb_printf)
737 ("command '%s' not recognised\n"
738 "In gdb, try 'monitor help'\n"
739 "In a shell, try 'vgdb help'\n",
740 cmd);
741 write_ok (arg_own_buf);
742 return;
743 }
744 }
745
746 /* provide some valgrind specific info in return to qThreadExtraInfo. */
747 if (strncmp ("qThreadExtraInfo,", arg_own_buf, 17) == 0) {
748 unsigned long gdb_id;
749 struct thread_info *ti;
750 ThreadState *tst;
751
752 gdb_id = strtoul (&arg_own_buf[17], NULL, 16);
753 ti = gdb_id_to_thread (gdb_id);
754 if (ti != NULL) {
755 tst = (ThreadState *) inferior_target_data (ti);
756 /* Additional info is the tid, the thread status and the thread's
757 name, if any. */
758 SizeT len = strlen(VG_(name_of_ThreadStatus)(tst->status)) + 20;
759 if (tst->thread_name) len += strlen(tst->thread_name);
760 /* As the string will be hexified and copied into own_buf we need
761 to limit the length to avoid buffer overflow. */
762 if (len * 2 > (PBUFSIZ + POVERHSIZ))
763 len = (PBUFSIZ + POVERHSIZ) / 2;
764 char status[len];
765 if (tst->thread_name) {
766 VG_(snprintf) (status, sizeof(status), "tid %u %s %s",
767 tst->tid,
768 VG_(name_of_ThreadStatus)(tst->status),
769 tst->thread_name);
770 } else {
771 VG_(snprintf) (status, sizeof(status), "tid %u %s",
772 tst->tid,
773 VG_(name_of_ThreadStatus)(tst->status));
774 }
775 hexify (arg_own_buf, status, strlen(status));
776 return;
777 } else {
778 write_enn (arg_own_buf);
779 return;
780 }
781 }
782
783 if (strcmp ("qAttached", arg_own_buf) == 0) {
784 /* tell gdb to always detach, never kill the process */
785 arg_own_buf[0] = '1';
786 arg_own_buf[1] = 0;
787 return;
788 }
789
790 if (strcmp ("qSymbol::", arg_own_buf) == 0) {
791 /* We have no symbol to read. */
792 write_ok (arg_own_buf);
793 return;
794 }
795
796 if (strcmp ("qfThreadInfo", arg_own_buf) == 0) {
797 thread_ptr = all_threads.head;
798 VG_(sprintf) (arg_own_buf, "m%x",
799 thread_to_gdb_id ((struct thread_info *)thread_ptr));
800 thread_ptr = thread_ptr->next;
801 return;
802 }
803
804 if (strcmp ("qsThreadInfo", arg_own_buf) == 0) {
805 if (thread_ptr != NULL) {
806 VG_(sprintf) (arg_own_buf, "m%x",
807 thread_to_gdb_id ((struct thread_info *)thread_ptr));
808 thread_ptr = thread_ptr->next;
809 return;
810 } else {
811 VG_(sprintf) (arg_own_buf, "l");
812 return;
813 }
814 }
815
816 if (valgrind_target_xml(VG_(clo_vgdb_shadow_registers)) != NULL
817 && strncmp ("qXfer:features:read:", arg_own_buf, 20) == 0) {
818 CORE_ADDR ofs;
819 unsigned int len, doc_len;
820 const char *annex = NULL;
821 // First, the annex is extracted from the packet received.
822 // Then, it is replaced by the corresponding file name.
823 int fd;
824
825 /* Grab the annex, offset, and length. */
826 if (decode_xfer_read (arg_own_buf + 20, &annex, &ofs, &len) < 0) {
827 strcpy (arg_own_buf, "E00");
828 return;
829 }
830
831 if (strcmp (annex, "target.xml") == 0) {
832 annex = valgrind_target_xml(VG_(clo_vgdb_shadow_registers));
833 if (annex != NULL && VG_(clo_vgdb_shadow_registers)) {
834 /* Ensure the shadow registers are initialized. */
835 initialize_shadow_low(True);
836 }
837 if (annex == NULL) {
838 strcpy (arg_own_buf, "E00");
839 return;
840 }
841 }
842
843 {
844 char doc[VG_(strlen)(VG_(libdir)) + 1 + VG_(strlen)(annex) + 1];
845 struct vg_stat stat_doc;
846 char toread[len];
847 int len_read;
848
849 VG_(sprintf)(doc, "%s/%s", VG_(libdir), annex);
850 fd = VG_(fd_open) (doc, VKI_O_RDONLY, 0);
851 if (fd == -1) {
852 strcpy (arg_own_buf, "E00");
853 return;
854 }
855 if (VG_(fstat) (fd, &stat_doc) != 0) {
856 VG_(close) (fd);
857 strcpy (arg_own_buf, "E00");
858 return;
859 }
860 doc_len = stat_doc.size;
861
862 if (len > PBUFSIZ - POVERHSIZ)
863 len = PBUFSIZ - POVERHSIZ;
864
865 if (ofs > doc_len) {
866 write_enn (arg_own_buf);
867 VG_(close) (fd);
868 return;
869 }
870 VG_(lseek) (fd, ofs, VKI_SEEK_SET);
871 len_read = VG_(read) (fd, toread, len);
872 *new_packet_len_p = write_qxfer_response (arg_own_buf,
873 (unsigned char *)toread,
874 len_read,
875 ofs + len_read < doc_len);
876 VG_(close) (fd);
877 return;
878 }
879 }
880
881 if (strncmp ("qXfer:auxv:read:", arg_own_buf, 16) == 0) {
882 unsigned char *data;
883 int n;
884 CORE_ADDR ofs;
885 unsigned int len;
886 const char *annex;
887
888 /* Reject any annex; grab the offset and length. */
889 if (decode_xfer_read (arg_own_buf + 16, &annex, &ofs, &len) < 0
890 || annex[0] != '\0') {
891 strcpy (arg_own_buf, "E00");
892 return;
893 }
894
895 if (len > PBUFSIZ - POVERHSIZ)
896 len = PBUFSIZ - POVERHSIZ;
897 data = malloc (len);
898
899 {
900 UWord *client_auxv = VG_(client_auxv);
901 unsigned int client_auxv_len = 0;
902 while (*client_auxv != 0) {
903 dlog(4, "auxv %llu %llx\n",
904 (ULong)*client_auxv,
905 (ULong)*(client_auxv+1));
906 client_auxv++;
907 client_auxv++;
908 client_auxv_len += 2 * sizeof(UWord);
909 }
910 client_auxv_len += 2 * sizeof(UWord);
911 dlog(4, "auxv len %u\n", client_auxv_len);
912
913 if (ofs >= client_auxv_len)
914 n = -1;
915 else {
916 n = client_auxv_len - ofs;
917 VG_(memcpy) (data, (unsigned char *) VG_(client_auxv), n);
918 }
919 }
920
921 if (n < 0)
922 write_enn (arg_own_buf);
923 else if (n > len)
924 *new_packet_len_p = write_qxfer_response (arg_own_buf, data, len, 1);
925 else
926 *new_packet_len_p = write_qxfer_response (arg_own_buf, data, n, 0);
927
928 free (data);
929
930 return;
931 }
932
933 if (strncmp ("qXfer:exec-file:read:", arg_own_buf, 21) == 0) {
934 unsigned char *data;
935 int n;
936 CORE_ADDR ofs;
937 unsigned int len;
938 const char *annex;
939 unsigned long pid;
940 const HChar *name;
941
942 /* grab the annex, offset and length. */
943 if (decode_xfer_read (arg_own_buf + 21, &annex, &ofs, &len) < 0) {
944 strcpy (arg_own_buf, "E00");
945 return;
946 }
947
948 /* Reject any annex with invalid/unexpected pid */
949 if (strlen(annex) > 0)
950 pid = strtoul (annex, NULL, 16);
951 else
952 pid = 0;
953 if ((int)pid != VG_(getpid)() && pid != 0) {
954 VG_(sprintf) (arg_own_buf,
955 "E.Valgrind gdbserver pid is %d."
956 " Cannot give info for pid %d",
957 VG_(getpid)(), (int) pid);
958 return;
959 }
960
961 if (len > PBUFSIZ - 2)
962 len = PBUFSIZ - 2;
963 data = malloc (len);
964
965 if (!VG_(resolve_filename)(VG_(cl_exec_fd), &name)) {
966 VG_(sprintf) (arg_own_buf,
967 "E.Valgrind gdbserver could not"
968 " resolve pid %d exec filename.",
969 VG_(getpid)());
970 return;
971 }
972
973 if (ofs >= strlen(name))
974 n = -1;
975 else {
976 n = strlen(name) - ofs;
977 VG_(memcpy) (data, name, n);
978 }
979
980 if (n < 0)
981 write_enn (arg_own_buf);
982 else if (n > len)
983 *new_packet_len_p = write_qxfer_response (arg_own_buf, data, len, 1);
984 else
985 *new_packet_len_p = write_qxfer_response (arg_own_buf, data, n, 0);
986
987 free (data);
988
989 return;
990 }
991
992 if (strncmp ("qXfer:siginfo:read:", arg_own_buf, 19) == 0) {
993 vki_siginfo_t info;
994 int n;
995 CORE_ADDR ofs;
996 unsigned int len;
997 const char *annex;
998
999 /* Reject any annex; grab the offset and length. */
1000 if (decode_xfer_read (arg_own_buf + 19, &annex, &ofs, &len) < 0
1001 || annex[0] != '\0') {
1002 strcpy (arg_own_buf, "E00");
1003 return;
1004 }
1005
1006 if (len > PBUFSIZ - POVERHSIZ)
1007 len = PBUFSIZ - POVERHSIZ;
1008
1009 gdbserver_pending_signal_to_report(&info);
1010
1011 if (ofs >= sizeof(info))
1012 n = -1;
1013 else
1014 n = sizeof(info) - ofs;
1015
1016 if (n < 0)
1017 write_enn (arg_own_buf);
1018 else if (n > len)
1019 *new_packet_len_p = write_qxfer_response (arg_own_buf,
1020 (unsigned char *)&info,
1021 len, 1);
1022 else
1023 *new_packet_len_p = write_qxfer_response (arg_own_buf,
1024 (unsigned char *)&info,
1025 n, 0);
1026
1027 return;
1028 }
1029
1030 /* Protocol features query. */
1031 if (strncmp ("qSupported", arg_own_buf, 10) == 0
1032 && (arg_own_buf[10] == ':' || arg_own_buf[10] == '\0')) {
1033 VG_(sprintf) (arg_own_buf, "PacketSize=%x", (UInt)PBUFSIZ - 1);
1034 /* Note: max packet size including frame and checksum, but without
1035 trailing null byte, which is not sent/received. */
1036
1037 strcat (arg_own_buf, ";QStartNoAckMode+");
1038 strcat (arg_own_buf, ";QPassSignals+");
1039 if (VG_(client_auxv))
1040 strcat (arg_own_buf, ";qXfer:auxv:read+");
1041
1042 if (valgrind_target_xml(VG_(clo_vgdb_shadow_registers)) != NULL) {
1043 strcat (arg_own_buf, ";qXfer:features:read+");
1044 /* if a new gdb connects to us, we have to reset the register
1045 set to the normal register sets to allow this new gdb to
1046 decide to use or not the shadow registers.
1047
1048 Note that the reset is only done for gdb that are sending
1049 qSupported packets. If a user first connected with a recent
1050 gdb using shadow registers and then with a very old gdb
1051 that does not use qSupported packet, then the old gdb will
1052 not properly connect. */
1053 initialize_shadow_low(False);
1054 }
1055 strcat (arg_own_buf, ";qXfer:exec-file:read+");
1056 strcat (arg_own_buf, ";qXfer:siginfo:read+");
1057 return;
1058 }
1059
1060 /* Otherwise we didn't know what packet it was. Say we didn't
1061 understand it. */
1062 arg_own_buf[0] = 0;
1063 }
1064
1065 /* Handle all of the extended 'v' packets. */
1066 static
handle_v_requests(char * arg_own_buf,char * status,int * zignal)1067 void handle_v_requests (char *arg_own_buf, char *status, int *zignal)
1068 {
1069 /* vcont packet code from gdb 6.6 removed */
1070
1071 /* Otherwise we didn't know what packet it was. Say we didn't
1072 understand it. */
1073 arg_own_buf[0] = 0;
1074 return;
1075 }
1076
1077 static
myresume(int step,int sig)1078 void myresume (int step, int sig)
1079 {
1080 struct thread_resume resume_info[2];
1081 int n = 0;
1082
1083 if (step || sig) {
1084 resume_info[0].step = step;
1085 resume_info[0].sig = sig;
1086 n++;
1087 }
1088 resume_info[n].step = 0;
1089 resume_info[n].sig = 0;
1090
1091 resume_reply_packet_needed = True;
1092 valgrind_resume (resume_info);
1093 }
1094
1095 /* server_main global variables */
1096 static char *own_buf;
1097 static unsigned char *mem_buf;
1098
gdbserver_init(void)1099 void gdbserver_init (void)
1100 {
1101 dlog(1, "gdbserver_init gdbserver embedded in valgrind: %s\n", version);
1102 noack_mode = False;
1103 valgrind_initialize_target ();
1104 // After a fork, gdbserver_init can be called again.
1105 // We do not have to re-malloc the buffers in such a case.
1106 if (own_buf == NULL)
1107 own_buf = malloc (PBUFSIZ+POVERHSIZ);
1108 if (mem_buf == NULL)
1109 mem_buf = malloc (PBUFSIZ+POVERHSIZ);
1110 // Note: normally, we should only malloc PBUFSIZ. However,
1111 // GDB has a bug, and in some cases, sends e.g. 'm' packets
1112 // asking for slightly more than the PacketSize given at
1113 // connection initialisation. So, we bypass the GDB bug
1114 // by allocating slightly more.
1115 }
1116
gdbserver_terminate(void)1117 void gdbserver_terminate (void)
1118 {
1119 /* last call to gdbserver is cleanup call */
1120 if (VG_MINIMAL_SETJMP(toplevel)) {
1121 dlog(0, "error caused VG_MINIMAL_LONGJMP to gdbserver_terminate\n");
1122 return;
1123 }
1124 remote_close();
1125 }
1126
server_main(void)1127 void server_main (void)
1128 {
1129 static char status;
1130 static int zignal;
1131
1132 char ch;
1133 int i = 0;
1134 unsigned int len;
1135 CORE_ADDR mem_addr;
1136
1137 zignal = valgrind_wait (&status);
1138 if (VG_MINIMAL_SETJMP(toplevel)) {
1139 dlog(0, "error caused VG_MINIMAL_LONGJMP to server_main\n");
1140 }
1141 while (1) {
1142 unsigned char sig;
1143 int packet_len;
1144 int new_packet_len = -1;
1145
1146 if (resume_reply_packet_needed) {
1147 /* Send the resume reply to reply to last GDB resume
1148 request. */
1149 resume_reply_packet_needed = False;
1150 prepare_resume_reply (own_buf, status, zignal);
1151 putpkt (own_buf);
1152 }
1153
1154 /* If our status is terminal (exit or fatal signal) get out
1155 as quickly as we can. We won't be able to handle any request
1156 anymore. */
1157 if (status == 'W' || status == 'X') {
1158 return;
1159 }
1160
1161 packet_len = getpkt (own_buf);
1162 if (packet_len <= 0)
1163 break;
1164
1165 i = 0;
1166 ch = own_buf[i++];
1167 switch (ch) {
1168 case 'Q':
1169 handle_set (own_buf, &new_packet_len);
1170 break;
1171 case 'q':
1172 handle_query (own_buf, &new_packet_len);
1173 break;
1174 case 'd':
1175 /* set/unset debugging is done through valgrind debug level. */
1176 own_buf[0] = '\0';
1177 break;
1178 case 'D':
1179 reset_valgrind_sink("gdb detaching from process");
1180
1181 /* When detaching or kill the process, gdb expects to get
1182 an packet OK back. Any other output will make gdb
1183 believes detach did not work. */
1184 write_ok (own_buf);
1185 putpkt (own_buf);
1186 remote_finish (reset_after_error);
1187 remote_open (VG_(clo_vgdb_prefix));
1188 myresume (0, 0);
1189 resume_reply_packet_needed = False;
1190 return;
1191 case '!':
1192 /* We can not use the extended protocol with valgrind,
1193 because we can not restart the running
1194 program. So return unrecognized. */
1195 own_buf[0] = '\0';
1196 break;
1197 case '?':
1198 prepare_resume_reply (own_buf, status, zignal);
1199 break;
1200 case 'H':
1201 if (own_buf[1] == 'c' || own_buf[1] == 'g' || own_buf[1] == 's') {
1202 unsigned long gdb_id, thread_id;
1203
1204 gdb_id = strtoul (&own_buf[2], NULL, 16);
1205 thread_id = gdb_id_to_thread_id (gdb_id);
1206 if (thread_id == 0) {
1207 write_enn (own_buf);
1208 break;
1209 }
1210
1211 if (own_buf[1] == 'g') {
1212 general_thread = thread_id;
1213 set_desired_inferior (1);
1214 } else if (own_buf[1] == 'c') {
1215 cont_thread = thread_id;
1216 } else if (own_buf[1] == 's') {
1217 step_thread = thread_id;
1218 }
1219
1220 write_ok (own_buf);
1221 } else {
1222 /* Silently ignore it so that gdb can extend the protocol
1223 without compatibility headaches. */
1224 own_buf[0] = '\0';
1225 }
1226 break;
1227 case 'g':
1228 set_desired_inferior (1);
1229 registers_to_string (own_buf);
1230 break;
1231 case 'G':
1232 set_desired_inferior (1);
1233 registers_from_string (&own_buf[1]);
1234 write_ok (own_buf);
1235 break;
1236 case 'P': {
1237 int regno;
1238 char *regbytes;
1239 Bool mod;
1240 ThreadState *tst;
1241 regno = strtol(&own_buf[1], NULL, 16);
1242 regbytes = strchr(&own_buf[0], '=') + 1;
1243 set_desired_inferior (1);
1244 tst = (ThreadState *) inferior_target_data (current_inferior);
1245 /* Only accept changing registers in "runnable state3.
1246 In fact, it would be ok to change most of the registers
1247 except a few "sensitive" registers such as the PC, SP, BP.
1248 We assume we do not need to very specific here, and that we
1249 can just refuse all of these. */
1250 if (tst->status == VgTs_Runnable || tst->status == VgTs_Yielding) {
1251 supply_register_from_string (regno, regbytes, &mod);
1252 write_ok (own_buf);
1253 } else {
1254 /* at least from gdb 6.6 onwards, an E. error
1255 reply is shown to the user. So, we do an error
1256 msg which both is accepted by gdb as an error msg
1257 and is readable by the user. */
1258 VG_(sprintf)
1259 (own_buf,
1260 "E.\n"
1261 "ERROR changing register %s regno %d\n"
1262 "gdb commands changing registers (pc, sp, ...) (e.g. 'jump',\n"
1263 "set pc, calling from gdb a function in the debugged process, ...)\n"
1264 "can only be accepted if the thread is VgTs_Runnable or VgTs_Yielding state\n"
1265 "Thread status is %s\n",
1266 find_register_by_number (regno)->name, regno,
1267 VG_(name_of_ThreadStatus)(tst->status));
1268 if (VG_(clo_verbosity) > 1)
1269 VG_(umsg) ("%s\n", own_buf);
1270 }
1271 break;
1272 }
1273 case 'm':
1274 decode_m_packet (&own_buf[1], &mem_addr, &len);
1275 if (valgrind_read_memory (mem_addr, mem_buf, len) == 0)
1276 convert_int_to_ascii (mem_buf, own_buf, len);
1277 else
1278 write_enn (own_buf);
1279 break;
1280 case 'M':
1281 decode_M_packet (&own_buf[1], &mem_addr, &len, mem_buf);
1282 if (valgrind_write_memory (mem_addr, mem_buf, len) == 0)
1283 write_ok (own_buf);
1284 else
1285 write_enn (own_buf);
1286 break;
1287 case 'X':
1288 if (decode_X_packet (&own_buf[1], packet_len - 1,
1289 &mem_addr, &len, mem_buf) < 0
1290 || valgrind_write_memory (mem_addr, mem_buf, len) != 0)
1291 write_enn (own_buf);
1292 else
1293 write_ok (own_buf);
1294 break;
1295 case 'C':
1296 convert_ascii_to_int (own_buf + 1, &sig, 1);
1297 if (target_signal_to_host_p (sig))
1298 zignal = target_signal_to_host (sig);
1299 else
1300 zignal = 0;
1301 set_desired_inferior (0);
1302 myresume (0, zignal);
1303 return; // return control to valgrind
1304 case 'S':
1305 convert_ascii_to_int (own_buf + 1, &sig, 1);
1306 if (target_signal_to_host_p (sig))
1307 zignal = target_signal_to_host (sig);
1308 else
1309 zignal = 0;
1310 set_desired_inferior (0);
1311 myresume (1, zignal);
1312 return; // return control to valgrind
1313 case 'c':
1314 set_desired_inferior (0);
1315 myresume (0, 0);
1316 return; // return control to valgrind
1317 case 's':
1318 set_desired_inferior (0);
1319 myresume (1, 0);
1320 return; // return control to valgrind
1321 case 'Z': {
1322 char *lenptr;
1323 char *dataptr;
1324 CORE_ADDR addr = strtoul (&own_buf[3], &lenptr, 16);
1325 int zlen = strtol (lenptr + 1, &dataptr, 16);
1326 char type = own_buf[1];
1327
1328 if (type < '0' || type > '4') {
1329 /* Watchpoint command type unrecognized. */
1330 own_buf[0] = '\0';
1331 } else {
1332 int res;
1333
1334 res = valgrind_insert_watchpoint (type, addr, zlen);
1335 if (res == 0)
1336 write_ok (own_buf);
1337 else if (res == 1)
1338 /* Unsupported. */
1339 own_buf[0] = '\0';
1340 else
1341 write_enn (own_buf);
1342 }
1343 break;
1344 }
1345 case 'z': {
1346 char *lenptr;
1347 char *dataptr;
1348 CORE_ADDR addr = strtoul (&own_buf[3], &lenptr, 16);
1349 int zlen = strtol (lenptr + 1, &dataptr, 16);
1350 char type = own_buf[1];
1351
1352 if (type < '0' || type > '4') {
1353 /* Watchpoint command type unrecognized. */
1354 own_buf[0] = '\0';
1355 } else {
1356 int res;
1357
1358 res = valgrind_remove_watchpoint (type, addr, zlen);
1359 if (res == 0)
1360 write_ok (own_buf);
1361 else if (res == 1)
1362 /* Unsupported. */
1363 own_buf[0] = '\0';
1364 else
1365 write_enn (own_buf);
1366 }
1367 break;
1368 }
1369 case 'k':
1370 kill_request("Gdb request to kill this process\n");
1371 break;
1372 case 'T': {
1373 unsigned long gdb_id, thread_id;
1374
1375 gdb_id = strtoul (&own_buf[1], NULL, 16);
1376 thread_id = gdb_id_to_thread_id (gdb_id);
1377 if (thread_id == 0) {
1378 write_enn (own_buf);
1379 break;
1380 }
1381
1382 if (valgrind_thread_alive (thread_id))
1383 write_ok (own_buf);
1384 else
1385 write_enn (own_buf);
1386 break;
1387 }
1388 case 'R':
1389 /* Restarting the inferior is only supported in the
1390 extended protocol.
1391 => It is a request we don't understand. Respond with an
1392 empty packet so that gdb knows that we don't support this
1393 request. */
1394 own_buf[0] = '\0';
1395 break;
1396 case 'v':
1397 /* Extended (long) request. */
1398 handle_v_requests (own_buf, &status, &zignal);
1399 break;
1400 default:
1401 /* It is a request we don't understand. Respond with an
1402 empty packet so that gdb knows that we don't support this
1403 request. */
1404 own_buf[0] = '\0';
1405 break;
1406 }
1407
1408 if (new_packet_len != -1)
1409 putpkt_binary (own_buf, new_packet_len);
1410 else
1411 putpkt (own_buf);
1412
1413 if (status == 'W')
1414 VG_(umsg) ("\nChild exited with status %d\n", zignal);
1415 if (status == 'X')
1416 VG_(umsg) ("\nChild terminated with signal = 0x%x (%s)\n",
1417 (UInt)target_signal_to_host (zignal),
1418 target_signal_to_name (zignal));
1419 if (status == 'W' || status == 'X') {
1420 VG_(umsg) ("Process exiting\n");
1421 VG_(exit) (0);
1422 }
1423 }
1424
1425 /* We come here when getpkt fails => close the connection,
1426 and re-open. Then return control to valgrind.
1427 We return the control to valgrind as we assume that
1428 the connection was closed due to vgdb having finished
1429 to execute a command. */
1430 if (VG_(clo_verbosity) > 1)
1431 VG_(umsg) ("Remote side has terminated connection. "
1432 "GDBserver will reopen the connection.\n");
1433 remote_finish (reset_after_error);
1434 remote_open (VG_(clo_vgdb_prefix));
1435 myresume (0, 0);
1436 resume_reply_packet_needed = False;
1437 return;
1438 }
1439