2020-09-03 00:53:41 +08:00
|
|
|
/* Internal interfaces for the NetBSD code.
|
|
|
|
|
2021-01-01 16:03:39 +08:00
|
|
|
Copyright (C) 2006-2021 Free Software Foundation, Inc.
|
2020-09-03 00:53:41 +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
|
|
|
|
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/>. */
|
|
|
|
|
2020-09-03 01:13:19 +08:00
|
|
|
#include "gdbsupport/common-defs.h"
|
2020-09-03 00:53:41 +08:00
|
|
|
#include "nat/netbsd-nat.h"
|
2020-09-03 01:13:19 +08:00
|
|
|
#include "gdbsupport/common-debug.h"
|
2020-09-03 00:53:41 +08:00
|
|
|
|
2020-09-03 01:08:37 +08:00
|
|
|
#include <sys/types.h>
|
2020-09-03 01:18:55 +08:00
|
|
|
#include <sys/ptrace.h>
|
2020-09-03 01:08:37 +08:00
|
|
|
#include <sys/sysctl.h>
|
|
|
|
|
2020-09-03 01:13:19 +08:00
|
|
|
#include <cstring>
|
|
|
|
|
|
|
|
#include "gdbsupport/function-view.h"
|
|
|
|
|
2020-09-03 00:53:41 +08:00
|
|
|
namespace netbsd_nat
|
|
|
|
{
|
2020-09-03 01:08:37 +08:00
|
|
|
|
|
|
|
/* See netbsd-nat.h. */
|
|
|
|
|
|
|
|
const char *
|
|
|
|
pid_to_exec_file (pid_t pid)
|
|
|
|
{
|
|
|
|
static char buf[PATH_MAX];
|
|
|
|
int mib[4] = {CTL_KERN, KERN_PROC_ARGS, pid, KERN_PROC_PATHNAME};
|
|
|
|
size_t buflen = sizeof (buf);
|
|
|
|
if (::sysctl (mib, ARRAY_SIZE (mib), buf, &buflen, NULL, 0) != 0)
|
|
|
|
return NULL;
|
|
|
|
return buf;
|
|
|
|
}
|
|
|
|
|
2020-09-03 01:13:19 +08:00
|
|
|
/* Generic thread (LWP) lister within a specified PID. The CALLBACK
|
|
|
|
parameters is a C++ function that is called for each detected thread.
|
|
|
|
When the CALLBACK function returns true, the iteration is interrupted.
|
|
|
|
|
|
|
|
This function assumes internally that the queried process is stopped
|
|
|
|
and the number of threads does not change between two sysctl () calls. */
|
|
|
|
|
|
|
|
static bool
|
|
|
|
netbsd_thread_lister (const pid_t pid,
|
|
|
|
gdb::function_view<bool (const struct kinfo_lwp *)>
|
|
|
|
callback)
|
|
|
|
{
|
|
|
|
int mib[5] = {CTL_KERN, KERN_LWP, pid, sizeof (struct kinfo_lwp), 0};
|
|
|
|
size_t size;
|
|
|
|
|
|
|
|
if (sysctl (mib, ARRAY_SIZE (mib), NULL, &size, NULL, 0) == -1 || size == 0)
|
|
|
|
perror_with_name (("sysctl"));
|
|
|
|
|
|
|
|
mib[4] = size / sizeof (size_t);
|
|
|
|
|
|
|
|
gdb::unique_xmalloc_ptr<struct kinfo_lwp[]> kl
|
|
|
|
((struct kinfo_lwp *) xcalloc (size, 1));
|
|
|
|
|
|
|
|
if (sysctl (mib, ARRAY_SIZE (mib), kl.get (), &size, NULL, 0) == -1
|
|
|
|
|| size == 0)
|
|
|
|
perror_with_name (("sysctl"));
|
|
|
|
|
|
|
|
for (size_t i = 0; i < size / sizeof (struct kinfo_lwp); i++)
|
|
|
|
{
|
|
|
|
struct kinfo_lwp *l = &kl[i];
|
|
|
|
|
|
|
|
/* Return true if the specified thread is alive. */
|
|
|
|
auto lwp_alive
|
|
|
|
= [] (struct kinfo_lwp *lwp)
|
|
|
|
{
|
|
|
|
switch (lwp->l_stat)
|
|
|
|
{
|
|
|
|
case LSSLEEP:
|
|
|
|
case LSRUN:
|
|
|
|
case LSONPROC:
|
|
|
|
case LSSTOP:
|
|
|
|
case LSSUSPENDED:
|
|
|
|
return true;
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Ignore embryonic or demised threads. */
|
|
|
|
if (!lwp_alive (l))
|
|
|
|
continue;
|
|
|
|
|
|
|
|
if (callback (l))
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* See netbsd-nat.h. */
|
|
|
|
|
|
|
|
bool
|
|
|
|
thread_alive (ptid_t ptid)
|
|
|
|
{
|
|
|
|
pid_t pid = ptid.pid ();
|
|
|
|
lwpid_t lwp = ptid.lwp ();
|
|
|
|
|
|
|
|
auto fn
|
|
|
|
= [=] (const struct kinfo_lwp *kl)
|
|
|
|
{
|
gdb, gdbserver, gdbsupport: fix leading space vs tabs issues
Many spots incorrectly use only spaces for indentation (for example,
there are a lot of spots in ada-lang.c). I've always found it awkward
when I needed to edit one of these spots: do I keep the original wrong
indentation, or do I fix it? What if the lines around it are also
wrong, do I fix them too? I probably don't want to fix them in the same
patch, to avoid adding noise to my patch.
So I propose to fix as much as possible once and for all (hopefully).
One typical counter argument for this is that it makes code archeology
more difficult, because git-blame will show this commit as the last
change for these lines. My counter counter argument is: when
git-blaming, you often need to do "blame the file at the parent commit"
anyway, to go past some other refactor that touched the line you are
interested in, but is not the change you are looking for. So you
already need a somewhat efficient way to do this.
Using some interactive tool, rather than plain git-blame, makes this
trivial. For example, I use "tig blame <file>", where going back past
the commit that changed the currently selected line is one keystroke.
It looks like Magit in Emacs does it too (though I've never used it).
Web viewers of Github and Gitlab do it too. My point is that it won't
really make archeology more difficult.
The other typical counter argument is that it will cause conflicts with
existing patches. That's true... but it's a one time cost, and those
are not conflicts that are difficult to resolve. I have also tried "git
rebase --ignore-whitespace", it seems to work well. Although that will
re-introduce the faulty indentation, so one needs to take care of fixing
the indentation in the patch after that (which is easy).
gdb/ChangeLog:
* aarch64-linux-tdep.c: Fix indentation.
* aarch64-ravenscar-thread.c: Fix indentation.
* aarch64-tdep.c: Fix indentation.
* aarch64-tdep.h: Fix indentation.
* ada-lang.c: Fix indentation.
* ada-lang.h: Fix indentation.
* ada-tasks.c: Fix indentation.
* ada-typeprint.c: Fix indentation.
* ada-valprint.c: Fix indentation.
* ada-varobj.c: Fix indentation.
* addrmap.c: Fix indentation.
* addrmap.h: Fix indentation.
* agent.c: Fix indentation.
* aix-thread.c: Fix indentation.
* alpha-bsd-nat.c: Fix indentation.
* alpha-linux-tdep.c: Fix indentation.
* alpha-mdebug-tdep.c: Fix indentation.
* alpha-nbsd-tdep.c: Fix indentation.
* alpha-obsd-tdep.c: Fix indentation.
* alpha-tdep.c: Fix indentation.
* amd64-bsd-nat.c: Fix indentation.
* amd64-darwin-tdep.c: Fix indentation.
* amd64-linux-nat.c: Fix indentation.
* amd64-linux-tdep.c: Fix indentation.
* amd64-nat.c: Fix indentation.
* amd64-obsd-tdep.c: Fix indentation.
* amd64-tdep.c: Fix indentation.
* amd64-windows-tdep.c: Fix indentation.
* annotate.c: Fix indentation.
* arc-tdep.c: Fix indentation.
* arch-utils.c: Fix indentation.
* arch/arm-get-next-pcs.c: Fix indentation.
* arch/arm.c: Fix indentation.
* arm-linux-nat.c: Fix indentation.
* arm-linux-tdep.c: Fix indentation.
* arm-nbsd-tdep.c: Fix indentation.
* arm-pikeos-tdep.c: Fix indentation.
* arm-tdep.c: Fix indentation.
* arm-tdep.h: Fix indentation.
* arm-wince-tdep.c: Fix indentation.
* auto-load.c: Fix indentation.
* auxv.c: Fix indentation.
* avr-tdep.c: Fix indentation.
* ax-gdb.c: Fix indentation.
* ax-general.c: Fix indentation.
* bfin-linux-tdep.c: Fix indentation.
* block.c: Fix indentation.
* block.h: Fix indentation.
* blockframe.c: Fix indentation.
* bpf-tdep.c: Fix indentation.
* break-catch-sig.c: Fix indentation.
* break-catch-syscall.c: Fix indentation.
* break-catch-throw.c: Fix indentation.
* breakpoint.c: Fix indentation.
* breakpoint.h: Fix indentation.
* bsd-uthread.c: Fix indentation.
* btrace.c: Fix indentation.
* build-id.c: Fix indentation.
* buildsym-legacy.h: Fix indentation.
* buildsym.c: Fix indentation.
* c-typeprint.c: Fix indentation.
* c-valprint.c: Fix indentation.
* c-varobj.c: Fix indentation.
* charset.c: Fix indentation.
* cli/cli-cmds.c: Fix indentation.
* cli/cli-decode.c: Fix indentation.
* cli/cli-decode.h: Fix indentation.
* cli/cli-script.c: Fix indentation.
* cli/cli-setshow.c: Fix indentation.
* coff-pe-read.c: Fix indentation.
* coffread.c: Fix indentation.
* compile/compile-cplus-types.c: Fix indentation.
* compile/compile-object-load.c: Fix indentation.
* compile/compile-object-run.c: Fix indentation.
* completer.c: Fix indentation.
* corefile.c: Fix indentation.
* corelow.c: Fix indentation.
* cp-abi.h: Fix indentation.
* cp-namespace.c: Fix indentation.
* cp-support.c: Fix indentation.
* cp-valprint.c: Fix indentation.
* cris-linux-tdep.c: Fix indentation.
* cris-tdep.c: Fix indentation.
* darwin-nat-info.c: Fix indentation.
* darwin-nat.c: Fix indentation.
* darwin-nat.h: Fix indentation.
* dbxread.c: Fix indentation.
* dcache.c: Fix indentation.
* disasm.c: Fix indentation.
* dtrace-probe.c: Fix indentation.
* dwarf2/abbrev.c: Fix indentation.
* dwarf2/attribute.c: Fix indentation.
* dwarf2/expr.c: Fix indentation.
* dwarf2/frame.c: Fix indentation.
* dwarf2/index-cache.c: Fix indentation.
* dwarf2/index-write.c: Fix indentation.
* dwarf2/line-header.c: Fix indentation.
* dwarf2/loc.c: Fix indentation.
* dwarf2/macro.c: Fix indentation.
* dwarf2/read.c: Fix indentation.
* dwarf2/read.h: Fix indentation.
* elfread.c: Fix indentation.
* eval.c: Fix indentation.
* event-top.c: Fix indentation.
* exec.c: Fix indentation.
* exec.h: Fix indentation.
* expprint.c: Fix indentation.
* f-lang.c: Fix indentation.
* f-typeprint.c: Fix indentation.
* f-valprint.c: Fix indentation.
* fbsd-nat.c: Fix indentation.
* fbsd-tdep.c: Fix indentation.
* findvar.c: Fix indentation.
* fork-child.c: Fix indentation.
* frame-unwind.c: Fix indentation.
* frame-unwind.h: Fix indentation.
* frame.c: Fix indentation.
* frv-linux-tdep.c: Fix indentation.
* frv-tdep.c: Fix indentation.
* frv-tdep.h: Fix indentation.
* ft32-tdep.c: Fix indentation.
* gcore.c: Fix indentation.
* gdb_bfd.c: Fix indentation.
* gdbarch.sh: Fix indentation.
* gdbarch.c: Re-generate
* gdbarch.h: Re-generate.
* gdbcore.h: Fix indentation.
* gdbthread.h: Fix indentation.
* gdbtypes.c: Fix indentation.
* gdbtypes.h: Fix indentation.
* glibc-tdep.c: Fix indentation.
* gnu-nat.c: Fix indentation.
* gnu-nat.h: Fix indentation.
* gnu-v2-abi.c: Fix indentation.
* gnu-v3-abi.c: Fix indentation.
* go32-nat.c: Fix indentation.
* guile/guile-internal.h: Fix indentation.
* guile/scm-cmd.c: Fix indentation.
* guile/scm-frame.c: Fix indentation.
* guile/scm-iterator.c: Fix indentation.
* guile/scm-math.c: Fix indentation.
* guile/scm-ports.c: Fix indentation.
* guile/scm-pretty-print.c: Fix indentation.
* guile/scm-value.c: Fix indentation.
* h8300-tdep.c: Fix indentation.
* hppa-linux-nat.c: Fix indentation.
* hppa-linux-tdep.c: Fix indentation.
* hppa-nbsd-nat.c: Fix indentation.
* hppa-nbsd-tdep.c: Fix indentation.
* hppa-obsd-nat.c: Fix indentation.
* hppa-tdep.c: Fix indentation.
* hppa-tdep.h: Fix indentation.
* i386-bsd-nat.c: Fix indentation.
* i386-darwin-nat.c: Fix indentation.
* i386-darwin-tdep.c: Fix indentation.
* i386-dicos-tdep.c: Fix indentation.
* i386-gnu-nat.c: Fix indentation.
* i386-linux-nat.c: Fix indentation.
* i386-linux-tdep.c: Fix indentation.
* i386-nto-tdep.c: Fix indentation.
* i386-obsd-tdep.c: Fix indentation.
* i386-sol2-nat.c: Fix indentation.
* i386-tdep.c: Fix indentation.
* i386-tdep.h: Fix indentation.
* i386-windows-tdep.c: Fix indentation.
* i387-tdep.c: Fix indentation.
* i387-tdep.h: Fix indentation.
* ia64-libunwind-tdep.c: Fix indentation.
* ia64-libunwind-tdep.h: Fix indentation.
* ia64-linux-nat.c: Fix indentation.
* ia64-linux-tdep.c: Fix indentation.
* ia64-tdep.c: Fix indentation.
* ia64-tdep.h: Fix indentation.
* ia64-vms-tdep.c: Fix indentation.
* infcall.c: Fix indentation.
* infcmd.c: Fix indentation.
* inferior.c: Fix indentation.
* infrun.c: Fix indentation.
* iq2000-tdep.c: Fix indentation.
* language.c: Fix indentation.
* linespec.c: Fix indentation.
* linux-fork.c: Fix indentation.
* linux-nat.c: Fix indentation.
* linux-tdep.c: Fix indentation.
* linux-thread-db.c: Fix indentation.
* lm32-tdep.c: Fix indentation.
* m2-lang.c: Fix indentation.
* m2-typeprint.c: Fix indentation.
* m2-valprint.c: Fix indentation.
* m32c-tdep.c: Fix indentation.
* m32r-linux-tdep.c: Fix indentation.
* m32r-tdep.c: Fix indentation.
* m68hc11-tdep.c: Fix indentation.
* m68k-bsd-nat.c: Fix indentation.
* m68k-linux-nat.c: Fix indentation.
* m68k-linux-tdep.c: Fix indentation.
* m68k-tdep.c: Fix indentation.
* machoread.c: Fix indentation.
* macrocmd.c: Fix indentation.
* macroexp.c: Fix indentation.
* macroscope.c: Fix indentation.
* macrotab.c: Fix indentation.
* macrotab.h: Fix indentation.
* main.c: Fix indentation.
* mdebugread.c: Fix indentation.
* mep-tdep.c: Fix indentation.
* mi/mi-cmd-catch.c: Fix indentation.
* mi/mi-cmd-disas.c: Fix indentation.
* mi/mi-cmd-env.c: Fix indentation.
* mi/mi-cmd-stack.c: Fix indentation.
* mi/mi-cmd-var.c: Fix indentation.
* mi/mi-cmds.c: Fix indentation.
* mi/mi-main.c: Fix indentation.
* mi/mi-parse.c: Fix indentation.
* microblaze-tdep.c: Fix indentation.
* minidebug.c: Fix indentation.
* minsyms.c: Fix indentation.
* mips-linux-nat.c: Fix indentation.
* mips-linux-tdep.c: Fix indentation.
* mips-nbsd-tdep.c: Fix indentation.
* mips-tdep.c: Fix indentation.
* mn10300-linux-tdep.c: Fix indentation.
* mn10300-tdep.c: Fix indentation.
* moxie-tdep.c: Fix indentation.
* msp430-tdep.c: Fix indentation.
* namespace.h: Fix indentation.
* nat/fork-inferior.c: Fix indentation.
* nat/gdb_ptrace.h: Fix indentation.
* nat/linux-namespaces.c: Fix indentation.
* nat/linux-osdata.c: Fix indentation.
* nat/netbsd-nat.c: Fix indentation.
* nat/x86-dregs.c: Fix indentation.
* nbsd-nat.c: Fix indentation.
* nbsd-tdep.c: Fix indentation.
* nios2-linux-tdep.c: Fix indentation.
* nios2-tdep.c: Fix indentation.
* nto-procfs.c: Fix indentation.
* nto-tdep.c: Fix indentation.
* objfiles.c: Fix indentation.
* objfiles.h: Fix indentation.
* opencl-lang.c: Fix indentation.
* or1k-tdep.c: Fix indentation.
* osabi.c: Fix indentation.
* osabi.h: Fix indentation.
* osdata.c: Fix indentation.
* p-lang.c: Fix indentation.
* p-typeprint.c: Fix indentation.
* p-valprint.c: Fix indentation.
* parse.c: Fix indentation.
* ppc-linux-nat.c: Fix indentation.
* ppc-linux-tdep.c: Fix indentation.
* ppc-nbsd-nat.c: Fix indentation.
* ppc-nbsd-tdep.c: Fix indentation.
* ppc-obsd-nat.c: Fix indentation.
* ppc-ravenscar-thread.c: Fix indentation.
* ppc-sysv-tdep.c: Fix indentation.
* ppc64-tdep.c: Fix indentation.
* printcmd.c: Fix indentation.
* proc-api.c: Fix indentation.
* producer.c: Fix indentation.
* producer.h: Fix indentation.
* prologue-value.c: Fix indentation.
* prologue-value.h: Fix indentation.
* psymtab.c: Fix indentation.
* python/py-arch.c: Fix indentation.
* python/py-bpevent.c: Fix indentation.
* python/py-event.c: Fix indentation.
* python/py-event.h: Fix indentation.
* python/py-finishbreakpoint.c: Fix indentation.
* python/py-frame.c: Fix indentation.
* python/py-framefilter.c: Fix indentation.
* python/py-inferior.c: Fix indentation.
* python/py-infthread.c: Fix indentation.
* python/py-objfile.c: Fix indentation.
* python/py-prettyprint.c: Fix indentation.
* python/py-registers.c: Fix indentation.
* python/py-signalevent.c: Fix indentation.
* python/py-stopevent.c: Fix indentation.
* python/py-stopevent.h: Fix indentation.
* python/py-threadevent.c: Fix indentation.
* python/py-tui.c: Fix indentation.
* python/py-unwind.c: Fix indentation.
* python/py-value.c: Fix indentation.
* python/py-xmethods.c: Fix indentation.
* python/python-internal.h: Fix indentation.
* python/python.c: Fix indentation.
* ravenscar-thread.c: Fix indentation.
* record-btrace.c: Fix indentation.
* record-full.c: Fix indentation.
* record.c: Fix indentation.
* reggroups.c: Fix indentation.
* regset.h: Fix indentation.
* remote-fileio.c: Fix indentation.
* remote.c: Fix indentation.
* reverse.c: Fix indentation.
* riscv-linux-tdep.c: Fix indentation.
* riscv-ravenscar-thread.c: Fix indentation.
* riscv-tdep.c: Fix indentation.
* rl78-tdep.c: Fix indentation.
* rs6000-aix-tdep.c: Fix indentation.
* rs6000-lynx178-tdep.c: Fix indentation.
* rs6000-nat.c: Fix indentation.
* rs6000-tdep.c: Fix indentation.
* rust-lang.c: Fix indentation.
* rx-tdep.c: Fix indentation.
* s12z-tdep.c: Fix indentation.
* s390-linux-tdep.c: Fix indentation.
* score-tdep.c: Fix indentation.
* ser-base.c: Fix indentation.
* ser-mingw.c: Fix indentation.
* ser-uds.c: Fix indentation.
* ser-unix.c: Fix indentation.
* serial.c: Fix indentation.
* sh-linux-tdep.c: Fix indentation.
* sh-nbsd-tdep.c: Fix indentation.
* sh-tdep.c: Fix indentation.
* skip.c: Fix indentation.
* sol-thread.c: Fix indentation.
* solib-aix.c: Fix indentation.
* solib-darwin.c: Fix indentation.
* solib-frv.c: Fix indentation.
* solib-svr4.c: Fix indentation.
* solib.c: Fix indentation.
* source.c: Fix indentation.
* sparc-linux-tdep.c: Fix indentation.
* sparc-nbsd-tdep.c: Fix indentation.
* sparc-obsd-tdep.c: Fix indentation.
* sparc-ravenscar-thread.c: Fix indentation.
* sparc-tdep.c: Fix indentation.
* sparc64-linux-tdep.c: Fix indentation.
* sparc64-nbsd-tdep.c: Fix indentation.
* sparc64-obsd-tdep.c: Fix indentation.
* sparc64-tdep.c: Fix indentation.
* stabsread.c: Fix indentation.
* stack.c: Fix indentation.
* stap-probe.c: Fix indentation.
* stubs/ia64vms-stub.c: Fix indentation.
* stubs/m32r-stub.c: Fix indentation.
* stubs/m68k-stub.c: Fix indentation.
* stubs/sh-stub.c: Fix indentation.
* stubs/sparc-stub.c: Fix indentation.
* symfile-mem.c: Fix indentation.
* symfile.c: Fix indentation.
* symfile.h: Fix indentation.
* symmisc.c: Fix indentation.
* symtab.c: Fix indentation.
* symtab.h: Fix indentation.
* target-float.c: Fix indentation.
* target.c: Fix indentation.
* target.h: Fix indentation.
* tic6x-tdep.c: Fix indentation.
* tilegx-linux-tdep.c: Fix indentation.
* tilegx-tdep.c: Fix indentation.
* top.c: Fix indentation.
* tracefile-tfile.c: Fix indentation.
* tracepoint.c: Fix indentation.
* tui/tui-disasm.c: Fix indentation.
* tui/tui-io.c: Fix indentation.
* tui/tui-regs.c: Fix indentation.
* tui/tui-stack.c: Fix indentation.
* tui/tui-win.c: Fix indentation.
* tui/tui-winsource.c: Fix indentation.
* tui/tui.c: Fix indentation.
* typeprint.c: Fix indentation.
* ui-out.h: Fix indentation.
* unittests/copy_bitwise-selftests.c: Fix indentation.
* unittests/memory-map-selftests.c: Fix indentation.
* utils.c: Fix indentation.
* v850-tdep.c: Fix indentation.
* valarith.c: Fix indentation.
* valops.c: Fix indentation.
* valprint.c: Fix indentation.
* valprint.h: Fix indentation.
* value.c: Fix indentation.
* value.h: Fix indentation.
* varobj.c: Fix indentation.
* vax-tdep.c: Fix indentation.
* windows-nat.c: Fix indentation.
* windows-tdep.c: Fix indentation.
* xcoffread.c: Fix indentation.
* xml-syscall.c: Fix indentation.
* xml-tdesc.c: Fix indentation.
* xstormy16-tdep.c: Fix indentation.
* xtensa-config.c: Fix indentation.
* xtensa-linux-nat.c: Fix indentation.
* xtensa-linux-tdep.c: Fix indentation.
* xtensa-tdep.c: Fix indentation.
gdbserver/ChangeLog:
* ax.cc: Fix indentation.
* dll.cc: Fix indentation.
* inferiors.h: Fix indentation.
* linux-low.cc: Fix indentation.
* linux-nios2-low.cc: Fix indentation.
* linux-ppc-ipa.cc: Fix indentation.
* linux-ppc-low.cc: Fix indentation.
* linux-x86-low.cc: Fix indentation.
* linux-xtensa-low.cc: Fix indentation.
* regcache.cc: Fix indentation.
* server.cc: Fix indentation.
* tracepoint.cc: Fix indentation.
gdbsupport/ChangeLog:
* common-exceptions.h: Fix indentation.
* event-loop.cc: Fix indentation.
* fileio.cc: Fix indentation.
* filestuff.cc: Fix indentation.
* gdb-dlfcn.cc: Fix indentation.
* gdb_string_view.h: Fix indentation.
* job-control.cc: Fix indentation.
* signals.cc: Fix indentation.
Change-Id: I4bad7ae6be0fbe14168b8ebafb98ffe14964a695
2020-11-02 23:26:14 +08:00
|
|
|
return kl->l_lid == lwp;
|
2020-09-03 01:13:19 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
return netbsd_thread_lister (pid, fn);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* See netbsd-nat.h. */
|
|
|
|
|
|
|
|
const char *
|
|
|
|
thread_name (ptid_t ptid)
|
|
|
|
{
|
|
|
|
pid_t pid = ptid.pid ();
|
|
|
|
lwpid_t lwp = ptid.lwp ();
|
|
|
|
|
|
|
|
static char buf[KI_LNAMELEN] = {};
|
|
|
|
|
|
|
|
auto fn
|
|
|
|
= [=] (const struct kinfo_lwp *kl)
|
|
|
|
{
|
|
|
|
if (kl->l_lid == lwp)
|
|
|
|
{
|
|
|
|
xsnprintf (buf, sizeof buf, "%s", kl->l_name);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
};
|
|
|
|
|
|
|
|
if (netbsd_thread_lister (pid, fn))
|
|
|
|
return buf;
|
|
|
|
else
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* See netbsd-nat.h. */
|
|
|
|
|
|
|
|
void
|
|
|
|
for_each_thread (pid_t pid, gdb::function_view<void (ptid_t)> callback)
|
|
|
|
{
|
|
|
|
auto fn
|
|
|
|
= [=, &callback] (const struct kinfo_lwp *kl)
|
|
|
|
{
|
|
|
|
ptid_t ptid = ptid_t (pid, kl->l_lid, 0);
|
|
|
|
callback (ptid);
|
|
|
|
return false;
|
|
|
|
};
|
|
|
|
|
|
|
|
netbsd_thread_lister (pid, fn);
|
|
|
|
}
|
|
|
|
|
2020-09-03 01:18:55 +08:00
|
|
|
/* See netbsd-nat.h. */
|
|
|
|
|
|
|
|
void
|
|
|
|
enable_proc_events (pid_t pid)
|
|
|
|
{
|
|
|
|
int events;
|
|
|
|
|
|
|
|
if (ptrace (PT_GET_EVENT_MASK, pid, &events, sizeof (events)) == -1)
|
|
|
|
perror_with_name (("ptrace"));
|
|
|
|
|
|
|
|
events |= PTRACE_LWP_CREATE;
|
|
|
|
events |= PTRACE_LWP_EXIT;
|
|
|
|
|
|
|
|
if (ptrace (PT_SET_EVENT_MASK, pid, &events, sizeof (events)) == -1)
|
|
|
|
perror_with_name (("ptrace"));
|
|
|
|
}
|
|
|
|
|
2020-09-03 01:21:19 +08:00
|
|
|
/* See netbsd-nat.h. */
|
|
|
|
|
|
|
|
int
|
|
|
|
qxfer_siginfo (pid_t pid, const char *annex, unsigned char *readbuf,
|
|
|
|
unsigned const char *writebuf, CORE_ADDR offset, int len)
|
|
|
|
{
|
|
|
|
ptrace_siginfo_t psi;
|
|
|
|
|
|
|
|
if (offset > sizeof (siginfo_t))
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (ptrace (PT_GET_SIGINFO, pid, &psi, sizeof (psi)) == -1)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (offset + len > sizeof (siginfo_t))
|
|
|
|
len = sizeof (siginfo_t) - offset;
|
|
|
|
|
|
|
|
if (readbuf != NULL)
|
|
|
|
memcpy (readbuf, ((gdb_byte *) &psi.psi_siginfo) + offset, len);
|
|
|
|
else
|
|
|
|
{
|
|
|
|
memcpy (((gdb_byte *) &psi.psi_siginfo) + offset, writebuf, len);
|
|
|
|
|
|
|
|
if (ptrace (PT_SET_SIGINFO, pid, &psi, sizeof (psi)) == -1)
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
return len;
|
|
|
|
}
|
|
|
|
|
2020-10-07 11:57:52 +08:00
|
|
|
/* See netbsd-nat.h. */
|
|
|
|
|
|
|
|
int
|
|
|
|
write_memory (pid_t pid, unsigned const char *writebuf, CORE_ADDR offset,
|
|
|
|
size_t len, size_t *xfered_len)
|
|
|
|
{
|
|
|
|
struct ptrace_io_desc io;
|
|
|
|
io.piod_op = PIOD_WRITE_D;
|
|
|
|
io.piod_len = len;
|
|
|
|
|
|
|
|
size_t bytes_written = 0;
|
|
|
|
|
|
|
|
/* Zero length write always succeeds. */
|
|
|
|
if (len > 0)
|
|
|
|
{
|
|
|
|
do
|
|
|
|
{
|
|
|
|
io.piod_addr = (void *)(writebuf + bytes_written);
|
|
|
|
io.piod_offs = (void *)(offset + bytes_written);
|
|
|
|
|
|
|
|
errno = 0;
|
|
|
|
int rv = ptrace (PT_IO, pid, &io, 0);
|
|
|
|
if (rv == -1)
|
|
|
|
{
|
|
|
|
gdb_assert (errno != 0);
|
|
|
|
return errno;
|
|
|
|
}
|
|
|
|
if (io.piod_len == 0)
|
2020-10-07 21:12:59 +08:00
|
|
|
break;
|
2020-10-07 11:57:52 +08:00
|
|
|
|
|
|
|
bytes_written += io.piod_len;
|
|
|
|
io.piod_len = len - bytes_written;
|
|
|
|
}
|
|
|
|
while (bytes_written < len);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (xfered_len != nullptr)
|
|
|
|
*xfered_len = bytes_written;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* See netbsd-nat.h. */
|
|
|
|
|
|
|
|
int
|
|
|
|
read_memory (pid_t pid, unsigned char *readbuf, CORE_ADDR offset,
|
|
|
|
size_t len, size_t *xfered_len)
|
|
|
|
{
|
|
|
|
struct ptrace_io_desc io;
|
|
|
|
io.piod_op = PIOD_READ_D;
|
|
|
|
io.piod_len = len;
|
|
|
|
|
|
|
|
size_t bytes_read = 0;
|
|
|
|
|
|
|
|
/* Zero length read always succeeds. */
|
|
|
|
if (len > 0)
|
|
|
|
{
|
|
|
|
do
|
|
|
|
{
|
|
|
|
io.piod_offs = (void *)(offset + bytes_read);
|
|
|
|
io.piod_addr = readbuf + bytes_read;
|
|
|
|
|
|
|
|
int rv = ptrace (PT_IO, pid, &io, 0);
|
|
|
|
if (rv == -1)
|
|
|
|
return errno;
|
|
|
|
if (io.piod_len == 0)
|
2020-10-07 21:12:59 +08:00
|
|
|
break;
|
2020-10-07 11:57:52 +08:00
|
|
|
|
|
|
|
bytes_read += io.piod_len;
|
|
|
|
io.piod_len = len - bytes_read;
|
|
|
|
}
|
|
|
|
while (bytes_read < len);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (xfered_len != nullptr)
|
|
|
|
*xfered_len = bytes_read;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2020-09-03 00:53:41 +08:00
|
|
|
}
|