268a13a5a3
This is the next patch in the ongoing series to move gdbsever to the top level. This patch just renames the "common" directory. The idea is to do this move in two parts: first rename the directory (this patch), then move the directory to the top. This approach makes the patches a bit more tractable. I chose the name "gdbsupport" for the directory. However, as this patch was largely written by sed, we could pick a new name without too much difficulty. Tested by the buildbot. gdb/ChangeLog 2019-07-09 Tom Tromey <tom@tromey.com> * contrib/ari/gdb_ari.sh: Change common to gdbsupport. * configure: Rebuild. * configure.ac: Change common to gdbsupport. * gdbsupport: Rename from common. * acinclude.m4: Change common to gdbsupport. * Makefile.in (CONFIG_SRC_SUBDIR, COMMON_SFILES) (HFILES_NO_SRCDIR, stamp-version, ALLDEPFILES): Change common to gdbsupport. * aarch64-tdep.c, ada-lang.c, ada-lang.h, agent.c, alloc.c, amd64-darwin-tdep.c, amd64-dicos-tdep.c, amd64-fbsd-nat.c, amd64-fbsd-tdep.c, amd64-linux-nat.c, amd64-linux-tdep.c, amd64-nbsd-tdep.c, amd64-obsd-tdep.c, amd64-sol2-tdep.c, amd64-tdep.c, amd64-windows-tdep.c, arch-utils.c, arch/aarch64-insn.c, arch/aarch64.c, arch/aarch64.h, arch/amd64.c, arch/amd64.h, arch/arm-get-next-pcs.c, arch/arm-linux.c, arch/arm.c, arch/i386.c, arch/i386.h, arch/ppc-linux-common.c, arch/riscv.c, arch/riscv.h, arch/tic6x.c, arm-tdep.c, auto-load.c, auxv.c, ax-gdb.c, ax-general.c, ax.h, breakpoint.c, breakpoint.h, btrace.c, btrace.h, build-id.c, build-id.h, c-lang.h, charset.c, charset.h, cli/cli-cmds.c, cli/cli-cmds.h, cli/cli-decode.c, cli/cli-dump.c, cli/cli-option.h, cli/cli-script.c, coff-pe-read.c, command.h, compile/compile-c-support.c, compile/compile-c.h, compile/compile-cplus-symbols.c, compile/compile-cplus-types.c, compile/compile-cplus.h, compile/compile-loc2c.c, compile/compile.c, completer.c, completer.h, contrib/ari/gdb_ari.sh, corefile.c, corelow.c, cp-support.c, cp-support.h, cp-valprint.c, csky-tdep.c, ctf.c, darwin-nat.c, debug.c, defs.h, disasm-selftests.c, disasm.c, disasm.h, dtrace-probe.c, dwarf-index-cache.c, dwarf-index-cache.h, dwarf-index-write.c, dwarf2-frame.c, dwarf2expr.c, dwarf2loc.c, dwarf2read.c, event-loop.c, event-top.c, exceptions.c, exec.c, extension.h, fbsd-nat.c, features/aarch64-core.c, features/aarch64-fpu.c, features/aarch64-pauth.c, features/aarch64-sve.c, features/i386/32bit-avx.c, features/i386/32bit-avx512.c, features/i386/32bit-core.c, features/i386/32bit-linux.c, features/i386/32bit-mpx.c, features/i386/32bit-pkeys.c, features/i386/32bit-segments.c, features/i386/32bit-sse.c, features/i386/64bit-avx.c, features/i386/64bit-avx512.c, features/i386/64bit-core.c, features/i386/64bit-linux.c, features/i386/64bit-mpx.c, features/i386/64bit-pkeys.c, features/i386/64bit-segments.c, features/i386/64bit-sse.c, features/i386/x32-core.c, features/riscv/32bit-cpu.c, features/riscv/32bit-csr.c, features/riscv/32bit-fpu.c, features/riscv/64bit-cpu.c, features/riscv/64bit-csr.c, features/riscv/64bit-fpu.c, features/tic6x-c6xp.c, features/tic6x-core.c, features/tic6x-gp.c, filename-seen-cache.h, findcmd.c, findvar.c, fork-child.c, gcore.c, gdb_bfd.c, gdb_bfd.h, gdb_proc_service.h, gdb_regex.c, gdb_select.h, gdb_usleep.c, gdbarch-selftests.c, gdbthread.h, gdbtypes.h, gnu-nat.c, go32-nat.c, guile/guile.c, guile/scm-ports.c, guile/scm-safe-call.c, guile/scm-type.c, i386-fbsd-nat.c, i386-fbsd-tdep.c, i386-go32-tdep.c, i386-linux-nat.c, i386-linux-tdep.c, i386-tdep.c, i387-tdep.c, ia64-libunwind-tdep.c, ia64-linux-nat.c, inf-child.c, inf-ptrace.c, infcall.c, infcall.h, infcmd.c, inferior-iter.h, inferior.c, inferior.h, inflow.c, inflow.h, infrun.c, infrun.h, inline-frame.c, language.h, linespec.c, linux-fork.c, linux-nat.c, linux-tdep.c, linux-thread-db.c, location.c, machoread.c, macrotab.h, main.c, maint.c, maint.h, memattr.c, memrange.h, mi/mi-cmd-break.h, mi/mi-cmd-env.c, mi/mi-cmd-stack.c, mi/mi-cmd-var.c, mi/mi-interp.c, mi/mi-main.c, mi/mi-parse.h, minsyms.c, mips-linux-tdep.c, namespace.h, nat/aarch64-linux-hw-point.c, nat/aarch64-linux-hw-point.h, nat/aarch64-linux.c, nat/aarch64-sve-linux-ptrace.c, nat/amd64-linux-siginfo.c, nat/fork-inferior.c, nat/linux-btrace.c, nat/linux-btrace.h, nat/linux-namespaces.c, nat/linux-nat.h, nat/linux-osdata.c, nat/linux-personality.c, nat/linux-procfs.c, nat/linux-ptrace.c, nat/linux-ptrace.h, nat/linux-waitpid.c, nat/mips-linux-watch.c, nat/mips-linux-watch.h, nat/ppc-linux.c, nat/x86-dregs.c, nat/x86-dregs.h, nat/x86-linux-dregs.c, nat/x86-linux.c, nto-procfs.c, nto-tdep.c, objfile-flags.h, objfiles.c, objfiles.h, obsd-nat.c, observable.h, osdata.c, p-valprint.c, parse.c, parser-defs.h, ppc-linux-nat.c, printcmd.c, probe.c, proc-api.c, procfs.c, producer.c, progspace.h, psymtab.h, python/py-framefilter.c, python/py-inferior.c, python/py-ref.h, python/py-type.c, python/python.c, record-btrace.c, record-full.c, record.c, record.h, regcache-dump.c, regcache.c, regcache.h, remote-fileio.c, remote-fileio.h, remote-sim.c, remote.c, riscv-tdep.c, rs6000-aix-tdep.c, rust-exp.y, s12z-tdep.c, selftest-arch.c, ser-base.c, ser-event.c, ser-pipe.c, ser-tcp.c, ser-unix.c, skip.c, solib-aix.c, solib-target.c, solib.c, source-cache.c, source.c, source.h, sparc-nat.c, spu-linux-nat.c, stack.c, stap-probe.c, symfile-add-flags.h, symfile.c, symfile.h, symtab.c, symtab.h, target-descriptions.c, target-descriptions.h, target-memory.c, target.c, target.h, target/waitstatus.c, target/waitstatus.h, thread-iter.h, thread.c, tilegx-tdep.c, top.c, top.h, tracefile-tfile.c, tracefile.c, tracepoint.c, tracepoint.h, tui/tui-io.c, ui-file.c, ui-out.h, unittests/array-view-selftests.c, unittests/child-path-selftests.c, unittests/cli-utils-selftests.c, unittests/common-utils-selftests.c, unittests/copy_bitwise-selftests.c, unittests/environ-selftests.c, unittests/format_pieces-selftests.c, unittests/function-view-selftests.c, unittests/lookup_name_info-selftests.c, unittests/memory-map-selftests.c, unittests/memrange-selftests.c, unittests/mkdir-recursive-selftests.c, unittests/observable-selftests.c, unittests/offset-type-selftests.c, unittests/optional-selftests.c, unittests/parse-connection-spec-selftests.c, unittests/ptid-selftests.c, unittests/rsp-low-selftests.c, unittests/scoped_fd-selftests.c, unittests/scoped_mmap-selftests.c, unittests/scoped_restore-selftests.c, unittests/string_view-selftests.c, unittests/style-selftests.c, unittests/tracepoint-selftests.c, unittests/unpack-selftests.c, unittests/utils-selftests.c, unittests/xml-utils-selftests.c, utils.c, utils.h, valarith.c, valops.c, valprint.c, value.c, value.h, varobj.c, varobj.h, windows-nat.c, x86-linux-nat.c, xml-support.c, xml-support.h, xml-tdesc.h, xstormy16-tdep.c, xtensa-linux-nat.c, dwarf2read.h: Change common to gdbsupport. gdb/gdbserver/ChangeLog 2019-07-09 Tom Tromey <tom@tromey.com> * configure: Rebuild. * configure.ac: Change common to gdbsupport. * acinclude.m4: Change common to gdbsupport. * Makefile.in (SFILES, OBS, GDBREPLAY_OBS, IPA_OBJS) (version-generated.c, gdbsupport/%-ipa.o, gdbsupport/%.o): Change common to gdbsupport. * ax.c, event-loop.c, fork-child.c, gdb_proc_service.h, gdbreplay.c, gdbthread.h, hostio-errno.c, hostio.c, i387-fp.c, inferiors.c, inferiors.h, linux-aarch64-tdesc-selftest.c, linux-amd64-ipa.c, linux-i386-ipa.c, linux-low.c, linux-tic6x-low.c, linux-x86-low.c, linux-x86-tdesc-selftest.c, linux-x86-tdesc.c, lynx-i386-low.c, lynx-low.c, mem-break.h, nto-x86-low.c, regcache.c, regcache.h, remote-utils.c, server.c, server.h, spu-low.c, symbol.c, target.h, tdesc.c, tdesc.h, thread-db.c, tracepoint.c, win32-i386-low.c, win32-low.c: Change common to gdbsupport.
211 lines
6.1 KiB
C
211 lines
6.1 KiB
C
/* Native-dependent code for FreeBSD/i386.
|
||
|
||
Copyright (C) 2001-2019 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 "inferior.h"
|
||
#include "regcache.h"
|
||
#include "target.h"
|
||
|
||
#include <sys/types.h>
|
||
#include <sys/ptrace.h>
|
||
#include <sys/sysctl.h>
|
||
#include <sys/user.h>
|
||
|
||
#include "fbsd-nat.h"
|
||
#include "i386-tdep.h"
|
||
#include "x86-nat.h"
|
||
#include "gdbsupport/x86-xstate.h"
|
||
#include "x86-bsd-nat.h"
|
||
#include "i386-bsd-nat.h"
|
||
|
||
class i386_fbsd_nat_target final
|
||
: public i386_bsd_nat_target<fbsd_nat_target>
|
||
{
|
||
public:
|
||
/* Add some extra features to the common *BSD/i386 target. */
|
||
#ifdef PT_GETXSTATE_INFO
|
||
const struct target_desc *read_description () override;
|
||
#endif
|
||
|
||
void resume (ptid_t, int, enum gdb_signal) override;
|
||
|
||
#if defined(HAVE_PT_GETDBREGS) && defined(USE_SIGTRAP_SIGINFO)
|
||
bool supports_stopped_by_hw_breakpoint () override;
|
||
#endif
|
||
};
|
||
|
||
static i386_fbsd_nat_target the_i386_fbsd_nat_target;
|
||
|
||
/* Resume execution of the inferior process. If STEP is nonzero,
|
||
single-step it. If SIGNAL is nonzero, give it that signal. */
|
||
|
||
void
|
||
i386_fbsd_nat_target::resume (ptid_t ptid, int step, enum gdb_signal signal)
|
||
{
|
||
pid_t pid = ptid.pid ();
|
||
int request = PT_STEP;
|
||
|
||
if (pid == -1)
|
||
/* Resume all threads. This only gets used in the non-threaded
|
||
case, where "resume all threads" and "resume inferior_ptid" are
|
||
the same. */
|
||
pid = inferior_ptid.pid ();
|
||
|
||
if (!step)
|
||
{
|
||
struct regcache *regcache = get_current_regcache ();
|
||
ULONGEST eflags;
|
||
|
||
/* Workaround for a bug in FreeBSD. Make sure that the trace
|
||
flag is off when doing a continue. There is a code path
|
||
through the kernel which leaves the flag set when it should
|
||
have been cleared. If a process has a signal pending (such
|
||
as SIGALRM) and we do a PT_STEP, the process never really has
|
||
a chance to run because the kernel needs to notify the
|
||
debugger that a signal is being sent. Therefore, the process
|
||
never goes through the kernel's trap() function which would
|
||
normally clear it. */
|
||
|
||
regcache_cooked_read_unsigned (regcache, I386_EFLAGS_REGNUM,
|
||
&eflags);
|
||
if (eflags & 0x0100)
|
||
regcache_cooked_write_unsigned (regcache, I386_EFLAGS_REGNUM,
|
||
eflags & ~0x0100);
|
||
|
||
request = PT_CONTINUE;
|
||
}
|
||
|
||
/* An addres of (caddr_t) 1 tells ptrace to continue from where it
|
||
was. (If GDB wanted it to start some other way, we have already
|
||
written a new PC value to the child.) */
|
||
if (ptrace (request, pid, (caddr_t) 1,
|
||
gdb_signal_to_host (signal)) == -1)
|
||
perror_with_name (("ptrace"));
|
||
}
|
||
|
||
|
||
/* Support for debugging kernel virtual memory images. */
|
||
|
||
#include <machine/pcb.h>
|
||
|
||
#include "bsd-kvm.h"
|
||
|
||
static int
|
||
i386fbsd_supply_pcb (struct regcache *regcache, struct pcb *pcb)
|
||
{
|
||
/* The following is true for FreeBSD 4.7:
|
||
|
||
The pcb contains %eip, %ebx, %esp, %ebp, %esi, %edi and %gs.
|
||
This accounts for all callee-saved registers specified by the
|
||
psABI and then some. Here %esp contains the stack pointer at the
|
||
point just after the call to cpu_switch(). From this information
|
||
we reconstruct the register state as it would look when we just
|
||
returned from cpu_switch(). */
|
||
|
||
/* The stack pointer shouldn't be zero. */
|
||
if (pcb->pcb_esp == 0)
|
||
return 0;
|
||
|
||
pcb->pcb_esp += 4;
|
||
regcache->raw_supply (I386_EDI_REGNUM, &pcb->pcb_edi);
|
||
regcache->raw_supply (I386_ESI_REGNUM, &pcb->pcb_esi);
|
||
regcache->raw_supply (I386_EBP_REGNUM, &pcb->pcb_ebp);
|
||
regcache->raw_supply (I386_ESP_REGNUM, &pcb->pcb_esp);
|
||
regcache->raw_supply (I386_EBX_REGNUM, &pcb->pcb_ebx);
|
||
regcache->raw_supply (I386_EIP_REGNUM, &pcb->pcb_eip);
|
||
regcache->raw_supply (I386_GS_REGNUM, &pcb->pcb_gs);
|
||
|
||
return 1;
|
||
}
|
||
|
||
|
||
#ifdef PT_GETXSTATE_INFO
|
||
/* Implement the read_description method. */
|
||
|
||
const struct target_desc *
|
||
i386_fbsd_nat_target::read_description ()
|
||
{
|
||
static int xsave_probed;
|
||
static uint64_t xcr0;
|
||
|
||
if (!xsave_probed)
|
||
{
|
||
struct ptrace_xstate_info info;
|
||
|
||
if (ptrace (PT_GETXSTATE_INFO, inferior_ptid.pid (),
|
||
(PTRACE_TYPE_ARG3) &info, sizeof (info)) == 0)
|
||
{
|
||
x86bsd_xsave_len = info.xsave_len;
|
||
xcr0 = info.xsave_mask;
|
||
}
|
||
xsave_probed = 1;
|
||
}
|
||
|
||
if (x86bsd_xsave_len == 0)
|
||
xcr0 = X86_XSTATE_SSE_MASK;
|
||
|
||
return i386_target_description (xcr0, true);
|
||
}
|
||
#endif
|
||
|
||
#if defined(HAVE_PT_GETDBREGS) && defined(USE_SIGTRAP_SIGINFO)
|
||
/* Implement the supports_stopped_by_hw_breakpoints method. */
|
||
|
||
bool
|
||
i386_fbsd_nat_target::supports_stopped_by_hw_breakpoint ()
|
||
{
|
||
return true;
|
||
}
|
||
#endif
|
||
|
||
void
|
||
_initialize_i386fbsd_nat (void)
|
||
{
|
||
add_inf_child_target (&the_i386_fbsd_nat_target);
|
||
|
||
/* Support debugging kernel virtual memory images. */
|
||
bsd_kvm_add_target (i386fbsd_supply_pcb);
|
||
|
||
#ifdef KERN_PROC_SIGTRAMP
|
||
/* Normally signal frames are detected via i386fbsd_sigtramp_p.
|
||
However, FreeBSD 9.2 through 10.1 do not include the page holding
|
||
the signal code in core dumps. These releases do provide a
|
||
kern.proc.sigtramp.<pid> sysctl that returns the location of the
|
||
signal trampoline for a running process. We fetch the location
|
||
of the current (gdb) process and use this to identify signal
|
||
frames in core dumps from these releases. */
|
||
{
|
||
int mib[4];
|
||
struct kinfo_sigtramp kst;
|
||
size_t len;
|
||
|
||
mib[0] = CTL_KERN;
|
||
mib[1] = KERN_PROC;
|
||
mib[2] = KERN_PROC_SIGTRAMP;
|
||
mib[3] = getpid ();
|
||
len = sizeof (kst);
|
||
if (sysctl (mib, 4, &kst, &len, NULL, 0) == 0)
|
||
{
|
||
i386fbsd_sigtramp_start_addr = (uintptr_t) kst.ksigtramp_start;
|
||
i386fbsd_sigtramp_end_addr = (uintptr_t) kst.ksigtramp_end;
|
||
}
|
||
}
|
||
#endif
|
||
}
|