2003-07-14 00:15:59 +08:00
|
|
|
|
/* Target-dependent code for FreeBSD/amd64.
|
2003-10-11 22:54:24 +08:00
|
|
|
|
|
2019-01-01 14:01:51 +08:00
|
|
|
|
Copyright (C) 2003-2019 Free Software Foundation, Inc.
|
2003-07-14 00:15:59 +08:00
|
|
|
|
|
|
|
|
|
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
|
2007-08-24 02:08:50 +08:00
|
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
2003-07-14 00:15:59 +08:00
|
|
|
|
(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
|
2007-08-24 02:08:50 +08:00
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
2003-07-14 00:15:59 +08:00
|
|
|
|
|
|
|
|
|
#include "defs.h"
|
|
|
|
|
#include "arch-utils.h"
|
|
|
|
|
#include "frame.h"
|
|
|
|
|
#include "gdbcore.h"
|
2019-04-03 10:04:24 +08:00
|
|
|
|
#include "regcache.h"
|
2019-04-07 03:38:10 +08:00
|
|
|
|
#include "osabi.h"
|
2015-02-22 05:43:30 +08:00
|
|
|
|
#include "regset.h"
|
2019-04-07 03:38:10 +08:00
|
|
|
|
#include "i386-fbsd-tdep.h"
|
Rename common to gdbsupport
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.
2019-05-06 10:29:24 +08:00
|
|
|
|
#include "gdbsupport/x86-xstate.h"
|
2019-04-07 03:38:10 +08:00
|
|
|
|
|
|
|
|
|
#include "amd64-tdep.h"
|
|
|
|
|
#include "fbsd-tdep.h"
|
* amd64fbsd-tdep.c: Include "solib-svr4.h".
(amd64fbsd_init_abi): Set link map offsets.
* amd64nbsd-tdep.c: Include "slib-svr4.h".
(amd64nbsd_init_abi): Set link map offsets.
* amd64obsd-tdep.c: Include "solib-svr4.h".
(amd64obsd_init_abi): Set link map offsets.
* i386fbsd-tdep.c: Include "solib-svr4.h".
(i386fbsd_init_abi): Set link map offsets.
* i386nbsd-tdep.c: Include "solib-svr4.h".
(i386nbsdelf_init_abi): Set link map offsets.
* Makefile.in (amd64fbsd-tdep.o, amd64nbsd-tdep.o)
(amd64obsd-tdep.o, i386fbsd-tdep.o): Update dependencies.
* config/i386/fbsd.mh (NATDEPFILES): Remove solib.o, solib-svr4.o,
solib-legacy.o and core-aout.o. Reformat.
* config/i386/fbsd64.mh (NATDEPFILES): Remove solib.o,
solib-svr4.o, solib-legacy.o. Reformat.
* config/i386/nbsdaout.mh (NATDEPFILES): Add solib.o. Reformat.
* config/i386/nbsdelf.mh: Reformat.
* config/i386/nbsd64.mh (NATDEPFILES): Remove solib.o,
solib-svr4.o, solib-legacy.o and corelow.o.
* config/i386/obsd.mh, config/i386/obsdaout.mh: Reformat.
* config/i386/obsd64.mh (NATDEPFILES): Remove solib.o,
solib-svr4.o, solib-legacy.o and corelow.o. Reformat.
* config/i386/fbsd.mt (TDEPFILES): Add solib.o, solib-svr4.o.
* config/i386/fbsd64.mt (TDEPFILES): Add solib.o, solib-svr4.o.
(TM_FILE): Set to tm-fbsd.h.
* config/i386/nbsd.mt (TDEPFILES): Reformat.
* config/i386/nbsd64.mt (TDEPFILES): Add corelow.o, solib.o and
solib-svr4.o.
* config/i386/obsd.mt (TDEPFILES): Add corelow.o, solib.o and
solib-svr4.o.
(TM_FILE): Set to nm-nbsd.h.
* config/i386/nm-fbsd.h: Update copyright year. Tweak comments.
Simplify shared library support. Don't include "elf/common.h".
(SVR4_SHARED_LIBS): Don't define.
* config/i386/nm-fbsd64.h: Update copyright year. Don't include
"solib.h".
* config/i386/nm-nbsd.h, config/i386/nm-nbsdaout.h,
config/i386/nm-obsd.h: Update copyright year. Tweak comments.
* config/i386/tm-fbsd.h: Update copyright tear. Tweak comments.
Don't include "i386/tm-i386.h". Include "solib.h".
* config/i386/tm-nbsd.h: Update copyright year. Tweak comments.
Don't include "i386/tm-i386.h".
* config/i386/xm-i386.h: Update copyright year. Tweak comments.
* config/i386/xm-nbsd.h: Update copyright year. Tweak comments.
Include "i386/xm-i386.h".
(HOST_LONG_DOUBLE_FORMAT): Remove.
2004-02-23 00:20:22 +08:00
|
|
|
|
#include "solib-svr4.h"
|
2003-07-14 00:15:59 +08:00
|
|
|
|
|
|
|
|
|
/* Support for signal handlers. */
|
|
|
|
|
|
2015-02-25 22:51:42 +08:00
|
|
|
|
/* Return whether THIS_FRAME corresponds to a FreeBSD sigtramp
|
|
|
|
|
routine. */
|
|
|
|
|
|
|
|
|
|
static const gdb_byte amd64fbsd_sigtramp_code[] =
|
|
|
|
|
{
|
|
|
|
|
0x48, 0x8d, 0x7c, 0x24, 0x10, /* lea SIGF_UC(%rsp),%rdi */
|
|
|
|
|
0x6a, 0x00, /* pushq $0 */
|
|
|
|
|
0x48, 0xc7, 0xc0, 0xa1, 0x01, 0x00, 0x00,
|
|
|
|
|
/* movq $SYS_sigreturn,%rax */
|
|
|
|
|
0x0f, 0x05 /* syscall */
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
|
amd64fbsd_sigtramp_p (struct frame_info *this_frame)
|
|
|
|
|
{
|
|
|
|
|
CORE_ADDR pc = get_frame_pc (this_frame);
|
|
|
|
|
gdb_byte buf[sizeof amd64fbsd_sigtramp_code];
|
|
|
|
|
|
|
|
|
|
if (!safe_frame_unwind_memory (this_frame, pc, buf, sizeof buf))
|
|
|
|
|
return 0;
|
2015-02-28 02:17:43 +08:00
|
|
|
|
if (memcmp (buf, amd64fbsd_sigtramp_code, sizeof amd64fbsd_sigtramp_code)
|
|
|
|
|
!= 0)
|
2015-02-25 22:51:42 +08:00
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
Update i386 and amd64 ports for unwinder changes.
* amd64-tdep.c (amd64_frame_cache): Expect this_frame.
(amd64_frame_this_id, amd64_frame_prev_register): Update signature.
(amd64_frame_unwind): Use default_frame_sniffer.
(amd64_frame_sniffer): Delete.
(amd64_sigtramp_frame_cache): Expect this_frame.
(amd64_sigtramp_frame_this_id, amd64_sigtramp_frame_prev_register)
(amd64_sigtramp_frame_sniffer): Update signature.
(amd64_sigtramp_frame_unwind): Add amd64_sigtramp_frame_sniffer.
(amd64_frame_base_address): Expect this_frame.
(amd64_dummy_id): Renamed from amd64_unwind_dummy_id. Expect
this_frame.
(amd64_init_abi): Use set_gdbarch_dummy_id and
frame_unwind_append_unwinder.
* i386-tdep.c (i386_frame_cache): Expect this_frame.
(i386_frame_this_id, i386_frame_prev_register): Update signature.
(i386_frame_unwind): Use default_frame_sniffer.
(i386_frame_sniffer): Delete.
(i386_sigtramp_frame_cache): Expect this_frame.
(i386_sigtramp_frame_this_id, i386_sigtramp_frame_prev_register)
(i386_sigtramp_frame_sniffer): Update signature.
(i386_sigtramp_frame_unwind): Use i386_sigtramp_frame_sniffer.
(i386_frame_base_address): Update signature.
(i386_dummy_id): Rename from i386_unwind_dummy_id. Expect this_frame.
(i386_push_dummy_call): Update comment.
(i386_sigtramp_p, i386_svr4_sigtramp_p, i386_svr4_sigcontext_addr):
Expect this_frame.
(i386_gdbarch_init): Use set_gdbarch_dummy_id, dwarf2_append_unwinders,
and frame_unwind_append_unwinder.
* amd64-linux-tdep.c, amd64-sol2-tdep.c, amd64fbsd-tdep.c,
amd64nbsd-tdep.c, amd64obsd-tdep.c, i386-linux-tdep.c,
i386-nto-tdep.c, i386bsd-tdep.c, i386-sol2-tdep.c, i386obsd-tdep.c,
i386nbsd-tdep.c: Update for unwinder changes.
2008-05-01 05:19:45 +08:00
|
|
|
|
/* Assuming THIS_FRAME is for a BSD sigtramp routine, return the
|
|
|
|
|
address of the associated sigcontext structure. */
|
2003-07-14 00:15:59 +08:00
|
|
|
|
|
|
|
|
|
static CORE_ADDR
|
Update i386 and amd64 ports for unwinder changes.
* amd64-tdep.c (amd64_frame_cache): Expect this_frame.
(amd64_frame_this_id, amd64_frame_prev_register): Update signature.
(amd64_frame_unwind): Use default_frame_sniffer.
(amd64_frame_sniffer): Delete.
(amd64_sigtramp_frame_cache): Expect this_frame.
(amd64_sigtramp_frame_this_id, amd64_sigtramp_frame_prev_register)
(amd64_sigtramp_frame_sniffer): Update signature.
(amd64_sigtramp_frame_unwind): Add amd64_sigtramp_frame_sniffer.
(amd64_frame_base_address): Expect this_frame.
(amd64_dummy_id): Renamed from amd64_unwind_dummy_id. Expect
this_frame.
(amd64_init_abi): Use set_gdbarch_dummy_id and
frame_unwind_append_unwinder.
* i386-tdep.c (i386_frame_cache): Expect this_frame.
(i386_frame_this_id, i386_frame_prev_register): Update signature.
(i386_frame_unwind): Use default_frame_sniffer.
(i386_frame_sniffer): Delete.
(i386_sigtramp_frame_cache): Expect this_frame.
(i386_sigtramp_frame_this_id, i386_sigtramp_frame_prev_register)
(i386_sigtramp_frame_sniffer): Update signature.
(i386_sigtramp_frame_unwind): Use i386_sigtramp_frame_sniffer.
(i386_frame_base_address): Update signature.
(i386_dummy_id): Rename from i386_unwind_dummy_id. Expect this_frame.
(i386_push_dummy_call): Update comment.
(i386_sigtramp_p, i386_svr4_sigtramp_p, i386_svr4_sigcontext_addr):
Expect this_frame.
(i386_gdbarch_init): Use set_gdbarch_dummy_id, dwarf2_append_unwinders,
and frame_unwind_append_unwinder.
* amd64-linux-tdep.c, amd64-sol2-tdep.c, amd64fbsd-tdep.c,
amd64nbsd-tdep.c, amd64obsd-tdep.c, i386-linux-tdep.c,
i386-nto-tdep.c, i386bsd-tdep.c, i386-sol2-tdep.c, i386obsd-tdep.c,
i386nbsd-tdep.c: Update for unwinder changes.
2008-05-01 05:19:45 +08:00
|
|
|
|
amd64fbsd_sigcontext_addr (struct frame_info *this_frame)
|
2003-07-14 00:15:59 +08:00
|
|
|
|
{
|
2015-02-26 19:07:57 +08:00
|
|
|
|
struct gdbarch *gdbarch = get_frame_arch (this_frame);
|
|
|
|
|
enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
|
2003-07-14 00:15:59 +08:00
|
|
|
|
CORE_ADDR sp;
|
2015-02-26 19:07:57 +08:00
|
|
|
|
gdb_byte buf[8];
|
2003-07-14 00:15:59 +08:00
|
|
|
|
|
2003-09-13 03:27:38 +08:00
|
|
|
|
/* The `struct sigcontext' (which really is an `ucontext_t' on
|
|
|
|
|
FreeBSD/amd64) lives at a fixed offset in the signal frame. See
|
|
|
|
|
<machine/sigframe.h>. */
|
2015-02-26 19:07:57 +08:00
|
|
|
|
get_frame_register (this_frame, AMD64_RSP_REGNUM, buf);
|
|
|
|
|
sp = extract_unsigned_integer (buf, 8, byte_order);
|
2003-09-13 03:27:38 +08:00
|
|
|
|
return sp + 16;
|
2003-07-14 00:15:59 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* FreeBSD 5.1-RELEASE or later. */
|
|
|
|
|
|
2003-10-11 22:54:24 +08:00
|
|
|
|
/* Mapping between the general-purpose registers in `struct reg'
|
|
|
|
|
format and GDB's register cache layout.
|
|
|
|
|
|
|
|
|
|
Note that some registers are 32-bit, but since we're little-endian
|
|
|
|
|
we get away with that. */
|
|
|
|
|
|
|
|
|
|
/* From <machine/reg.h>. */
|
|
|
|
|
static int amd64fbsd_r_reg_offset[] =
|
|
|
|
|
{
|
2004-01-10 20:52:41 +08:00
|
|
|
|
14 * 8, /* %rax */
|
|
|
|
|
11 * 8, /* %rbx */
|
|
|
|
|
13 * 8, /* %rcx */
|
|
|
|
|
12 * 8, /* %rdx */
|
|
|
|
|
9 * 8, /* %rsi */
|
|
|
|
|
8 * 8, /* %rdi */
|
|
|
|
|
10 * 8, /* %rbp */
|
|
|
|
|
20 * 8, /* %rsp */
|
2011-01-08 03:36:19 +08:00
|
|
|
|
7 * 8, /* %r8 ... */
|
2004-01-10 20:52:41 +08:00
|
|
|
|
6 * 8,
|
|
|
|
|
5 * 8,
|
|
|
|
|
4 * 8,
|
|
|
|
|
3 * 8,
|
|
|
|
|
2 * 8,
|
|
|
|
|
1 * 8,
|
|
|
|
|
0 * 8, /* ... %r15 */
|
|
|
|
|
17 * 8, /* %rip */
|
|
|
|
|
19 * 8, /* %eflags */
|
|
|
|
|
18 * 8, /* %cs */
|
|
|
|
|
21 * 8, /* %ss */
|
|
|
|
|
-1, /* %ds */
|
|
|
|
|
-1, /* %es */
|
|
|
|
|
-1, /* %fs */
|
|
|
|
|
-1 /* %gs */
|
2003-10-11 22:54:24 +08:00
|
|
|
|
};
|
|
|
|
|
|
2003-07-14 00:15:59 +08:00
|
|
|
|
/* Location of the signal trampoline. */
|
2015-02-25 22:51:42 +08:00
|
|
|
|
CORE_ADDR amd64fbsd_sigtramp_start_addr;
|
|
|
|
|
CORE_ADDR amd64fbsd_sigtramp_end_addr;
|
2003-07-14 00:15:59 +08:00
|
|
|
|
|
|
|
|
|
/* From <machine/signal.h>. */
|
2004-01-10 20:52:41 +08:00
|
|
|
|
int amd64fbsd_sc_reg_offset[] =
|
2003-07-14 00:15:59 +08:00
|
|
|
|
{
|
2003-09-13 03:27:38 +08:00
|
|
|
|
24 + 6 * 8, /* %rax */
|
|
|
|
|
24 + 7 * 8, /* %rbx */
|
|
|
|
|
24 + 3 * 8, /* %rcx */
|
|
|
|
|
24 + 2 * 8, /* %rdx */
|
|
|
|
|
24 + 1 * 8, /* %rsi */
|
|
|
|
|
24 + 0 * 8, /* %rdi */
|
|
|
|
|
24 + 8 * 8, /* %rbp */
|
2003-11-06 06:54:46 +08:00
|
|
|
|
24 + 22 * 8, /* %rsp */
|
2011-01-08 03:36:19 +08:00
|
|
|
|
24 + 4 * 8, /* %r8 ... */
|
2004-01-10 20:52:41 +08:00
|
|
|
|
24 + 5 * 8,
|
|
|
|
|
24 + 9 * 8,
|
|
|
|
|
24 + 10 * 8,
|
|
|
|
|
24 + 11 * 8,
|
|
|
|
|
24 + 12 * 8,
|
|
|
|
|
24 + 13 * 8,
|
|
|
|
|
24 + 14 * 8, /* ... %r15 */
|
2003-11-06 06:54:46 +08:00
|
|
|
|
24 + 19 * 8, /* %rip */
|
|
|
|
|
24 + 21 * 8, /* %eflags */
|
2004-01-10 20:52:41 +08:00
|
|
|
|
24 + 20 * 8, /* %cs */
|
|
|
|
|
24 + 23 * 8, /* %ss */
|
2003-07-14 00:15:59 +08:00
|
|
|
|
-1, /* %ds */
|
|
|
|
|
-1, /* %es */
|
|
|
|
|
-1, /* %fs */
|
|
|
|
|
-1 /* %gs */
|
|
|
|
|
};
|
|
|
|
|
|
2015-02-22 05:43:30 +08:00
|
|
|
|
/* Implement the core_read_description gdbarch method. */
|
|
|
|
|
|
|
|
|
|
static const struct target_desc *
|
|
|
|
|
amd64fbsd_core_read_description (struct gdbarch *gdbarch,
|
|
|
|
|
struct target_ops *target,
|
|
|
|
|
bfd *abfd)
|
|
|
|
|
{
|
2018-06-30 06:42:27 +08:00
|
|
|
|
return amd64_target_description (i386fbsd_core_read_xcr0 (abfd), true);
|
2015-02-22 05:43:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Similar to amd64_supply_fpregset, but use XSAVE extended state. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
amd64fbsd_supply_xstateregset (const struct regset *regset,
|
|
|
|
|
struct regcache *regcache, int regnum,
|
|
|
|
|
const void *xstateregs, size_t len)
|
|
|
|
|
{
|
|
|
|
|
amd64_supply_xsave (regcache, regnum, xstateregs);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Similar to amd64_collect_fpregset, but use XSAVE extended state. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
amd64fbsd_collect_xstateregset (const struct regset *regset,
|
|
|
|
|
const struct regcache *regcache,
|
|
|
|
|
int regnum, void *xstateregs, size_t len)
|
|
|
|
|
{
|
|
|
|
|
amd64_collect_xsave (regcache, regnum, xstateregs, 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static const struct regset amd64fbsd_xstateregset =
|
|
|
|
|
{
|
|
|
|
|
NULL,
|
|
|
|
|
amd64fbsd_supply_xstateregset,
|
|
|
|
|
amd64fbsd_collect_xstateregset
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* Iterate over core file register note sections. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
amd64fbsd_iterate_over_regset_sections (struct gdbarch *gdbarch,
|
|
|
|
|
iterate_over_regset_sections_cb *cb,
|
|
|
|
|
void *cb_data,
|
|
|
|
|
const struct regcache *regcache)
|
|
|
|
|
{
|
|
|
|
|
struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
|
|
|
|
|
|
2018-08-13 17:04:11 +08:00
|
|
|
|
cb (".reg", tdep->sizeof_gregset, tdep->sizeof_gregset, &i386_gregset, NULL,
|
|
|
|
|
cb_data);
|
|
|
|
|
cb (".reg2", tdep->sizeof_fpregset, tdep->sizeof_fpregset, &amd64_fpregset,
|
|
|
|
|
NULL, cb_data);
|
|
|
|
|
cb (".reg-xstate", X86_XSTATE_SIZE (tdep->xcr0), X86_XSTATE_SIZE (tdep->xcr0),
|
2015-02-22 05:43:30 +08:00
|
|
|
|
&amd64fbsd_xstateregset, "XSAVE extended state", cb_data);
|
|
|
|
|
}
|
|
|
|
|
|
2019-03-13 04:39:02 +08:00
|
|
|
|
/* Implement the get_thread_local_address gdbarch method. */
|
|
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
|
amd64fbsd_get_thread_local_address (struct gdbarch *gdbarch, ptid_t ptid,
|
|
|
|
|
CORE_ADDR lm_addr, CORE_ADDR offset)
|
|
|
|
|
{
|
|
|
|
|
struct regcache *regcache;
|
|
|
|
|
|
|
|
|
|
regcache = get_thread_arch_regcache (ptid, gdbarch);
|
|
|
|
|
|
|
|
|
|
target_fetch_registers (regcache, AMD64_FSBASE_REGNUM);
|
|
|
|
|
|
|
|
|
|
ULONGEST fsbase;
|
|
|
|
|
if (regcache->cooked_read (AMD64_FSBASE_REGNUM, &fsbase) != REG_VALID)
|
|
|
|
|
error (_("Unable to fetch %%fsbase"));
|
|
|
|
|
|
|
|
|
|
CORE_ADDR dtv_addr = fsbase + gdbarch_ptr_bit (gdbarch) / 8;
|
|
|
|
|
return fbsd_get_thread_local_address (gdbarch, dtv_addr, lm_addr, offset);
|
|
|
|
|
}
|
|
|
|
|
|
2009-02-22 09:02:20 +08:00
|
|
|
|
static void
|
2003-07-14 00:15:59 +08:00
|
|
|
|
amd64fbsd_init_abi (struct gdbarch_info info, struct gdbarch *gdbarch)
|
|
|
|
|
{
|
|
|
|
|
struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
|
|
|
|
|
|
2014-03-29 18:04:26 +08:00
|
|
|
|
/* Generic FreeBSD support. */
|
|
|
|
|
fbsd_init_abi (info, gdbarch);
|
|
|
|
|
|
2003-07-14 00:15:59 +08:00
|
|
|
|
/* Obviously FreeBSD is BSD-based. */
|
|
|
|
|
i386bsd_init_abi (info, gdbarch);
|
|
|
|
|
|
2003-10-11 22:54:24 +08:00
|
|
|
|
tdep->gregset_reg_offset = amd64fbsd_r_reg_offset;
|
|
|
|
|
tdep->gregset_num_regs = ARRAY_SIZE (amd64fbsd_r_reg_offset);
|
|
|
|
|
tdep->sizeof_gregset = 22 * 8;
|
|
|
|
|
|
2017-09-04 18:33:56 +08:00
|
|
|
|
amd64_init_abi (info, gdbarch,
|
2018-06-30 06:42:27 +08:00
|
|
|
|
amd64_target_description (X86_XSTATE_SSE_MASK, true));
|
2003-07-14 00:15:59 +08:00
|
|
|
|
|
2015-02-25 22:51:42 +08:00
|
|
|
|
tdep->sigtramp_p = amd64fbsd_sigtramp_p;
|
2004-02-23 03:14:55 +08:00
|
|
|
|
tdep->sigtramp_start = amd64fbsd_sigtramp_start_addr;
|
|
|
|
|
tdep->sigtramp_end = amd64fbsd_sigtramp_end_addr;
|
2003-07-14 00:15:59 +08:00
|
|
|
|
tdep->sigcontext_addr = amd64fbsd_sigcontext_addr;
|
|
|
|
|
tdep->sc_reg_offset = amd64fbsd_sc_reg_offset;
|
2003-10-11 22:54:24 +08:00
|
|
|
|
tdep->sc_num_regs = ARRAY_SIZE (amd64fbsd_sc_reg_offset);
|
* amd64fbsd-tdep.c: Include "solib-svr4.h".
(amd64fbsd_init_abi): Set link map offsets.
* amd64nbsd-tdep.c: Include "slib-svr4.h".
(amd64nbsd_init_abi): Set link map offsets.
* amd64obsd-tdep.c: Include "solib-svr4.h".
(amd64obsd_init_abi): Set link map offsets.
* i386fbsd-tdep.c: Include "solib-svr4.h".
(i386fbsd_init_abi): Set link map offsets.
* i386nbsd-tdep.c: Include "solib-svr4.h".
(i386nbsdelf_init_abi): Set link map offsets.
* Makefile.in (amd64fbsd-tdep.o, amd64nbsd-tdep.o)
(amd64obsd-tdep.o, i386fbsd-tdep.o): Update dependencies.
* config/i386/fbsd.mh (NATDEPFILES): Remove solib.o, solib-svr4.o,
solib-legacy.o and core-aout.o. Reformat.
* config/i386/fbsd64.mh (NATDEPFILES): Remove solib.o,
solib-svr4.o, solib-legacy.o. Reformat.
* config/i386/nbsdaout.mh (NATDEPFILES): Add solib.o. Reformat.
* config/i386/nbsdelf.mh: Reformat.
* config/i386/nbsd64.mh (NATDEPFILES): Remove solib.o,
solib-svr4.o, solib-legacy.o and corelow.o.
* config/i386/obsd.mh, config/i386/obsdaout.mh: Reformat.
* config/i386/obsd64.mh (NATDEPFILES): Remove solib.o,
solib-svr4.o, solib-legacy.o and corelow.o. Reformat.
* config/i386/fbsd.mt (TDEPFILES): Add solib.o, solib-svr4.o.
* config/i386/fbsd64.mt (TDEPFILES): Add solib.o, solib-svr4.o.
(TM_FILE): Set to tm-fbsd.h.
* config/i386/nbsd.mt (TDEPFILES): Reformat.
* config/i386/nbsd64.mt (TDEPFILES): Add corelow.o, solib.o and
solib-svr4.o.
* config/i386/obsd.mt (TDEPFILES): Add corelow.o, solib.o and
solib-svr4.o.
(TM_FILE): Set to nm-nbsd.h.
* config/i386/nm-fbsd.h: Update copyright year. Tweak comments.
Simplify shared library support. Don't include "elf/common.h".
(SVR4_SHARED_LIBS): Don't define.
* config/i386/nm-fbsd64.h: Update copyright year. Don't include
"solib.h".
* config/i386/nm-nbsd.h, config/i386/nm-nbsdaout.h,
config/i386/nm-obsd.h: Update copyright year. Tweak comments.
* config/i386/tm-fbsd.h: Update copyright tear. Tweak comments.
Don't include "i386/tm-i386.h". Include "solib.h".
* config/i386/tm-nbsd.h: Update copyright year. Tweak comments.
Don't include "i386/tm-i386.h".
* config/i386/xm-i386.h: Update copyright year. Tweak comments.
* config/i386/xm-nbsd.h: Update copyright year. Tweak comments.
Include "i386/xm-i386.h".
(HOST_LONG_DOUBLE_FORMAT): Remove.
2004-02-23 00:20:22 +08:00
|
|
|
|
|
2015-02-22 05:43:30 +08:00
|
|
|
|
tdep->xsave_xcr0_offset = I386_FBSD_XSAVE_XCR0_OFFSET;
|
|
|
|
|
|
|
|
|
|
/* Iterate over core file register note sections. */
|
|
|
|
|
set_gdbarch_iterate_over_regset_sections
|
|
|
|
|
(gdbarch, amd64fbsd_iterate_over_regset_sections);
|
|
|
|
|
|
|
|
|
|
set_gdbarch_core_read_description (gdbarch,
|
|
|
|
|
amd64fbsd_core_read_description);
|
|
|
|
|
|
* amd64fbsd-tdep.c: Include "solib-svr4.h".
(amd64fbsd_init_abi): Set link map offsets.
* amd64nbsd-tdep.c: Include "slib-svr4.h".
(amd64nbsd_init_abi): Set link map offsets.
* amd64obsd-tdep.c: Include "solib-svr4.h".
(amd64obsd_init_abi): Set link map offsets.
* i386fbsd-tdep.c: Include "solib-svr4.h".
(i386fbsd_init_abi): Set link map offsets.
* i386nbsd-tdep.c: Include "solib-svr4.h".
(i386nbsdelf_init_abi): Set link map offsets.
* Makefile.in (amd64fbsd-tdep.o, amd64nbsd-tdep.o)
(amd64obsd-tdep.o, i386fbsd-tdep.o): Update dependencies.
* config/i386/fbsd.mh (NATDEPFILES): Remove solib.o, solib-svr4.o,
solib-legacy.o and core-aout.o. Reformat.
* config/i386/fbsd64.mh (NATDEPFILES): Remove solib.o,
solib-svr4.o, solib-legacy.o. Reformat.
* config/i386/nbsdaout.mh (NATDEPFILES): Add solib.o. Reformat.
* config/i386/nbsdelf.mh: Reformat.
* config/i386/nbsd64.mh (NATDEPFILES): Remove solib.o,
solib-svr4.o, solib-legacy.o and corelow.o.
* config/i386/obsd.mh, config/i386/obsdaout.mh: Reformat.
* config/i386/obsd64.mh (NATDEPFILES): Remove solib.o,
solib-svr4.o, solib-legacy.o and corelow.o. Reformat.
* config/i386/fbsd.mt (TDEPFILES): Add solib.o, solib-svr4.o.
* config/i386/fbsd64.mt (TDEPFILES): Add solib.o, solib-svr4.o.
(TM_FILE): Set to tm-fbsd.h.
* config/i386/nbsd.mt (TDEPFILES): Reformat.
* config/i386/nbsd64.mt (TDEPFILES): Add corelow.o, solib.o and
solib-svr4.o.
* config/i386/obsd.mt (TDEPFILES): Add corelow.o, solib.o and
solib-svr4.o.
(TM_FILE): Set to nm-nbsd.h.
* config/i386/nm-fbsd.h: Update copyright year. Tweak comments.
Simplify shared library support. Don't include "elf/common.h".
(SVR4_SHARED_LIBS): Don't define.
* config/i386/nm-fbsd64.h: Update copyright year. Don't include
"solib.h".
* config/i386/nm-nbsd.h, config/i386/nm-nbsdaout.h,
config/i386/nm-obsd.h: Update copyright year. Tweak comments.
* config/i386/tm-fbsd.h: Update copyright tear. Tweak comments.
Don't include "i386/tm-i386.h". Include "solib.h".
* config/i386/tm-nbsd.h: Update copyright year. Tweak comments.
Don't include "i386/tm-i386.h".
* config/i386/xm-i386.h: Update copyright year. Tweak comments.
* config/i386/xm-nbsd.h: Update copyright year. Tweak comments.
Include "i386/xm-i386.h".
(HOST_LONG_DOUBLE_FORMAT): Remove.
2004-02-23 00:20:22 +08:00
|
|
|
|
/* FreeBSD uses SVR4-style shared libraries. */
|
|
|
|
|
set_solib_svr4_fetch_link_map_offsets
|
|
|
|
|
(gdbarch, svr4_lp64_fetch_link_map_offsets);
|
2019-03-13 04:39:02 +08:00
|
|
|
|
|
|
|
|
|
set_gdbarch_fetch_tls_load_module_address (gdbarch,
|
|
|
|
|
svr4_fetch_objfile_link_map);
|
|
|
|
|
set_gdbarch_get_thread_local_address (gdbarch,
|
|
|
|
|
amd64fbsd_get_thread_local_address);
|
2003-07-14 00:15:59 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
_initialize_amd64fbsd_tdep (void)
|
|
|
|
|
{
|
|
|
|
|
gdbarch_register_osabi (bfd_arch_i386, bfd_mach_x86_64,
|
2016-12-10 00:08:49 +08:00
|
|
|
|
GDB_OSABI_FREEBSD, amd64fbsd_init_abi);
|
2003-07-14 00:15:59 +08:00
|
|
|
|
}
|