a96d9b2e9a
* amd64-linux-tdep.c: Include xml-syscall.h header, define the XML syscall name for the architecture. (amd64_linux_get_syscall_number): New function. (amd64_linux_init_abi): Register the correct functions for syscall catchpoint; set the correct syscall file name. * breakpoint.c: New include: xml-syscall.h. (set_raw_breakpoint_without_location): Setting the parameters for the catch syscall feature. (insert_catch_syscall): New. (remove_catch_syscall): New. (breakpoint_hit_catch_syscall): New. (print_it_catch_syscall): New. (print_one_catch_syscall): New. (print_mention_catch_syscall): New. (catch_syscall_breakpoint_ops): New. (syscall_catchpoint_p): New. (create_catchpoint_without_mention): New. (create_catchpoint): Modified in order to use create_catchpoint_without_mention. (create_syscall_event_catchpoint): New. (clean_up_filters): New. (catch_syscall_split_args): New. (catch_syscall_command_1): New. (delete_breakpoint): Add cleanup for catch syscall. (is_syscall_catchpoint_enabled): New. (catch_syscall_enabled): New. (catching_syscall_number): New. (catch_syscall_completer): New completer function. (add_catch_command): Add the completer function for catchpoints. * breakpoint.h (syscalls_to_be_caught): New vector. (catch_syscall_enabled): New. (catching_syscall_number): New. * gdbarch.c: Regenerated. * gdbarch.h: Regenerated. * gdbarch.sh: Add syscall catchpoint functions and structures. (get_syscall_number): New. (UNKNOWN_SYSCALL): New definition. * i386-linux-nat.c (i386_linux_resume): Select the proper request to be made for ptrace() considering if we are catching syscalls or not. * i386-linux-tdep.c: Include xml-syscall.h header, define the XML syscall name for the architecture. (i386_linux_get_syscall_number): New. (i386_linux_init_abi): Register the correct functions for syscall catchpoint; set the correct syscall file name. * inf-child.c (inf_child_set_syscall_catchpoint): New. (inf_child_target): Assign default values to target_ops. * inf-ptrace.c (inf_ptrace_resume): Select the proper request to be made for ptrace() considering if we are catching syscalls or not. * inferior.h (struct inferior): Included new variables any_syscall_count, syscalls_counts and total_syscalls_count, used to keep track of requested syscall catchpoints. * infrun.c (resume): Add syscall catchpoint. (deal_with_syscall_event): New. (handle_inferior_event): Add syscall entry/return events. (inferior_has_called_syscall): New. * linux-nat.c: Define some helpful variables to track wether we have support for the needed ptrace option. (linux_test_for_tracesysgood): New. (linux_supports_tracesysgood): New. (linux_enable_tracesysgood): New. (linux_enable_event_reporting): Save the current used ptrace options. (linux_child_post_attach): Calling linux_enable_tracesysgood. (linux_child_post_startup_inferior): Likewise. (linux_child_set_syscall_catchpoint): New function. (linux_handle_extended_wait): Handle the case which the inferior stops because it has called or returned from a syscall. (linux_target_install_ops): Install the necessary functions to handle syscall catchpoints. * linux-nat.h (struct lwp_info): Include syscall_state into the structure, which indicates if we are in a syscall entry or return. * ppc-linux-tdep.c: Include xml-syscall.h header, define the XML syscall filename for the arch. (ppc_linux_get_syscall_number): New. (ppc_linux_init_abi): Register the correct functions for syscall catchpoint; setting the correct name for the XML syscall file. * target.c (update_current_target): Update/copy functions related to syscall catchpoint. (target_waitstatus_to_string): Add syscall catchpoint entry/return events. * target.h (struct target_waitstatus): Add syscall number. (struct syscall): New struct to hold information about syscalls in the system. (struct target_ops): Add ops for syscall catchpoint. (inferior_has_called_syscall): New. (target_set_syscall_catchpoint): New. * xml-support.c (xml_fetch_content_from_file): New function, transferred from xml-tdesc.c. * xml-support.h (xml_fetch_content_from_file): New. * xml-tdesc.c (fetch_xml_from_file): Function removed; transferred to xml-support.c. (file_read_description_xml): Updated to use the new xml_fetch_content_from_file function. * syscalls/gdb-syscalls.dtd: New definition file for syscall's XML support. * syscalls/amd64-linux.xml: New file containing information about syscalls for GNU/Linux systems that use amd64 architecture. * syscalls/i386-linux.xml: New file containing information about syscalls for GNU/Linux systems that use i386 architecture. * syscalls/ppc-linux.xml: New file containing information about syscalls for GNU/Linux systems that use PPC architecture. * syscalls/ppc64-linux.xml: New file containing information about syscalls for GNU/Linux systems that use PPC64 architecture. * xml-syscall.c: New file containing functions for manipulating syscall's XML files. * xml-syscall.h: New file, exporting the functions above mentioned. * Makefile.in: Support for relocatable GDB datadir and XML syscall. * NEWS: Added information about the catch syscall feature. * doc/gdb.texinfo (Set Catchpoints): Documentation about the new feature. * testsuite/Makefile.in: Inclusion of catch-syscall object. * testsuite/gdb.base/catch-syscall.c: New file. * testsuite/gdb.base/catch-syscall.exp: New file.
213 lines
6.2 KiB
C
213 lines
6.2 KiB
C
/* Default child (native) target interface, for GDB when running under
|
|
Unix.
|
|
|
|
Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1998,
|
|
1999, 2000, 2001, 2002, 2004, 2005, 2007, 2008, 2009
|
|
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/>. */
|
|
|
|
#include "defs.h"
|
|
#include "regcache.h"
|
|
#include "memattr.h"
|
|
#include "symtab.h"
|
|
#include "target.h"
|
|
#include "inferior.h"
|
|
#include "gdb_string.h"
|
|
#include "inf-child.h"
|
|
|
|
/* Fetch register REGNUM from the inferior. If REGNUM is -1, do this
|
|
for all registers. */
|
|
|
|
static void
|
|
inf_child_fetch_inferior_registers (struct target_ops *ops,
|
|
struct regcache *regcache, int regnum)
|
|
{
|
|
if (regnum == -1)
|
|
{
|
|
for (regnum = 0;
|
|
regnum < gdbarch_num_regs (get_regcache_arch (regcache));
|
|
regnum++)
|
|
regcache_raw_supply (regcache, regnum, NULL);
|
|
}
|
|
else
|
|
regcache_raw_supply (regcache, regnum, NULL);
|
|
}
|
|
|
|
/* Store register REGNUM back into the inferior. If REGNUM is -1, do
|
|
this for all registers (including the floating point registers). */
|
|
|
|
static void
|
|
inf_child_store_inferior_registers (struct target_ops *ops,
|
|
struct regcache *regcache, int regnum)
|
|
{
|
|
}
|
|
|
|
static void
|
|
inf_child_post_attach (int pid)
|
|
{
|
|
/* This version of Unix doesn't require a meaningful "post attach"
|
|
operation by a debugger. */
|
|
}
|
|
|
|
/* Get ready to modify the registers array. On machines which store
|
|
individual registers, this doesn't need to do anything. On
|
|
machines which store all the registers in one fell swoop, this
|
|
makes sure that registers contains all the registers from the
|
|
program being debugged. */
|
|
|
|
static void
|
|
inf_child_prepare_to_store (struct regcache *regcache)
|
|
{
|
|
}
|
|
|
|
static void
|
|
inf_child_open (char *arg, int from_tty)
|
|
{
|
|
error (_("Use the \"run\" command to start a Unix child process."));
|
|
}
|
|
|
|
static void
|
|
inf_child_post_startup_inferior (ptid_t ptid)
|
|
{
|
|
/* This version of Unix doesn't require a meaningful "post startup
|
|
inferior" operation by a debugger. */
|
|
}
|
|
|
|
static void
|
|
inf_child_acknowledge_created_inferior (int pid)
|
|
{
|
|
/* This version of Unix doesn't require a meaningful "acknowledge
|
|
created inferior" operation by a debugger. */
|
|
}
|
|
|
|
static void
|
|
inf_child_insert_fork_catchpoint (int pid)
|
|
{
|
|
/* This version of Unix doesn't support notification of fork
|
|
events. */
|
|
}
|
|
|
|
static int
|
|
inf_child_remove_fork_catchpoint (int pid)
|
|
{
|
|
/* This version of Unix doesn't support notification of fork
|
|
events. */
|
|
return 0;
|
|
}
|
|
|
|
static void
|
|
inf_child_insert_vfork_catchpoint (int pid)
|
|
{
|
|
/* This version of Unix doesn't support notification of vfork
|
|
events. */
|
|
}
|
|
|
|
static int
|
|
inf_child_remove_vfork_catchpoint (int pid)
|
|
{
|
|
/* This version of Unix doesn't support notification of vfork
|
|
events. */
|
|
return 0;
|
|
}
|
|
|
|
static int
|
|
inf_child_follow_fork (struct target_ops *ops, int follow_child)
|
|
{
|
|
/* This version of Unix doesn't support following fork or vfork
|
|
events. */
|
|
return 0;
|
|
}
|
|
|
|
static void
|
|
inf_child_insert_exec_catchpoint (int pid)
|
|
{
|
|
/* This version of Unix doesn't support notification of exec
|
|
events. */
|
|
}
|
|
|
|
static int
|
|
inf_child_remove_exec_catchpoint (int pid)
|
|
{
|
|
/* This version of Unix doesn't support notification of exec
|
|
events. */
|
|
return 0;
|
|
}
|
|
|
|
static int
|
|
inf_child_set_syscall_catchpoint (int pid, int needed, int any_count,
|
|
int table_size, int *table)
|
|
{
|
|
/* This version of Unix doesn't support notification of syscall
|
|
events. */
|
|
return 0;
|
|
}
|
|
|
|
static int
|
|
inf_child_can_run (void)
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
static char *
|
|
inf_child_pid_to_exec_file (int pid)
|
|
{
|
|
/* This version of Unix doesn't support translation of a process ID
|
|
to the filename of the executable file. */
|
|
return NULL;
|
|
}
|
|
|
|
struct target_ops *
|
|
inf_child_target (void)
|
|
{
|
|
struct target_ops *t = XZALLOC (struct target_ops);
|
|
t->to_shortname = "child";
|
|
t->to_longname = "Unix child process";
|
|
t->to_doc = "Unix child process (started by the \"run\" command).";
|
|
t->to_open = inf_child_open;
|
|
t->to_post_attach = inf_child_post_attach;
|
|
t->to_fetch_registers = inf_child_fetch_inferior_registers;
|
|
t->to_store_registers = inf_child_store_inferior_registers;
|
|
t->to_prepare_to_store = inf_child_prepare_to_store;
|
|
t->to_insert_breakpoint = memory_insert_breakpoint;
|
|
t->to_remove_breakpoint = memory_remove_breakpoint;
|
|
t->to_terminal_init = terminal_init_inferior;
|
|
t->to_terminal_inferior = terminal_inferior;
|
|
t->to_terminal_ours_for_output = terminal_ours_for_output;
|
|
t->to_terminal_save_ours = terminal_save_ours;
|
|
t->to_terminal_ours = terminal_ours;
|
|
t->to_terminal_info = child_terminal_info;
|
|
t->to_post_startup_inferior = inf_child_post_startup_inferior;
|
|
t->to_acknowledge_created_inferior = inf_child_acknowledge_created_inferior;
|
|
t->to_insert_fork_catchpoint = inf_child_insert_fork_catchpoint;
|
|
t->to_remove_fork_catchpoint = inf_child_remove_fork_catchpoint;
|
|
t->to_insert_vfork_catchpoint = inf_child_insert_vfork_catchpoint;
|
|
t->to_remove_vfork_catchpoint = inf_child_remove_vfork_catchpoint;
|
|
t->to_follow_fork = inf_child_follow_fork;
|
|
t->to_insert_exec_catchpoint = inf_child_insert_exec_catchpoint;
|
|
t->to_remove_exec_catchpoint = inf_child_remove_exec_catchpoint;
|
|
t->to_set_syscall_catchpoint = inf_child_set_syscall_catchpoint;
|
|
t->to_can_run = inf_child_can_run;
|
|
t->to_pid_to_exec_file = inf_child_pid_to_exec_file;
|
|
t->to_stratum = process_stratum;
|
|
t->to_has_all_memory = default_child_has_all_memory;
|
|
t->to_has_memory = default_child_has_memory;
|
|
t->to_has_stack = default_child_has_stack;
|
|
t->to_has_registers = default_child_has_registers;
|
|
t->to_has_execution = default_child_has_execution;
|
|
t->to_magic = OPS_MAGIC;
|
|
return t;
|
|
}
|