diff options
author | Walfred Tedeschi <walfred.tedeschi@intel.com> | 2016-02-02 11:42:56 +0100 |
---|---|---|
committer | Walfred Tedeschi <walfred.tedeschi@intel.com> | 2016-02-02 11:42:56 +0100 |
commit | 93813b37c86a70fbd4d8c9d63f95cf8b87bbf425 (patch) | |
tree | 25430ac2381dff66ca76bc9de89269e122be3334 /gdb/nat/amd64-linux-siginfo.h | |
parent | 67e5d8cd040854ec4350c5ac9c538202a5329578 (diff) | |
download | gdb-93813b37c86a70fbd4d8c9d63f95cf8b87bbf425.zip gdb-93813b37c86a70fbd4d8c9d63f95cf8b87bbf425.tar.gz gdb-93813b37c86a70fbd4d8c9d63f95cf8b87bbf425.tar.bz2 |
Merge gdb and gdbserver implementations for siginfo
Extract the compatible siginfo handling from amd64-linux-nat.c and
gdbserver/linux-x86-low to a new file nat/amd64-linux-siginfo.c.
2016-02-02 Walfred Tedeschi <walfred.tedeschi@intel.com>
gdb/ChangeLog:
* nat/amd64-linux-siginfo.c: New file.
* nat/amd64-linux-siginfo.h: New file.
* Makefile.in (HFILES_NO_SRCDIR): Add nat/amd64-linux-siginfo.h.
(amd64-linux-siginfo.o): New rule.
* config/i386/linux64.mh (NATDEPFILES): Add amd64-linux-siginfo.o.
* amd64-linux-nat.c (nat/amd64-linux-siginfo.h): New include.
(compat_siginfo_from_siginfo, siginfo_from_compat_siginfo)
(compat_x32_siginfo_from_siginfo, siginfo_from_compat_x32_siginfo)
(compat_timeval, compat_sigval, compat_x32_clock, cpt_si_pid)
(cpt_si_uid, cpt_si_timerid, cpt_si_overrun, cpt_si_status)
(cpt_si_utime, cpt_si_stime, cpt_si_ptr, cpt_si_addr, cpt_si_band)
(cpt_si_fd, si_timerid, si_overrun): Move to nat/amd64-linux-siginfo.c.
gdb/gdbserver/ChangeLog:
* configure.srv (x86_64-*-linux*): Add amd64-linux-siginfo.o
to srv_tgtobj.
(i[34567]86-*-linux*): Add amd64-linux-siginfo.o
to srv_tgtobj.
* linux-x86-low.c [__x86_64__]: Include
"nat/amd64-linux-siginfo.h".
(compat_siginfo_from_siginfo, siginfo_from_compat_siginfo)
(compat_x32_siginfo_from_siginfo, siginfo_from_compat_x32_siginfo)
(compat_timeval, compat_sigval, compat_x32_clock, cpt_si_pid)
(cpt_si_uid, cpt_si_timerid, cpt_si_overrun, cpt_si_status)
(cpt_si_utime, cpt_si_stime, cpt_si_ptr, cpt_si_addr, cpt_si_band)
(cpt_si_fd, si_timerid, si_overrun): Move from
nat/amd64-linux-siginfo.c.
* Makefile.in (amd64-linux-siginfo.o:): New rule.
Diffstat (limited to 'gdb/nat/amd64-linux-siginfo.h')
-rw-r--r-- | gdb/nat/amd64-linux-siginfo.h | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/gdb/nat/amd64-linux-siginfo.h b/gdb/nat/amd64-linux-siginfo.h new file mode 100644 index 0000000..a396966 --- /dev/null +++ b/gdb/nat/amd64-linux-siginfo.h @@ -0,0 +1,44 @@ +/* Low-level siginfo manipulation for amd64. + + Copyright (C) 2016 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/>. */ + +#ifndef AMD64_LINUX_SIGINFO_H +#define AMD64_LINUX_SIGINFO_H 1 + + +/* When GDB is built as a 64-bit application on Linux, the + PTRACE_GETSIGINFO data is always presented in 64-bit layout. Since + debugging a 32-bit inferior with a 64-bit GDB should look the same + as debugging it with a 32-bit GDB, we do the 32-bit <-> 64-bit + conversion in-place ourselves. */ + +/* Kind of siginfo fixup to be performed. */ + +enum amd64_siginfo_fixup_mode +{ + FIXUP_32 = 1, /* Fixup for 32bit. */ + FIXUP_X32 = 2 /* Fixup for x32. */ +}; + +/* Common code for performing the fixup of the siginfo. */ + +int amd64_linux_siginfo_fixup_common (siginfo_t *native, gdb_byte *inf, + int direction, + enum amd64_siginfo_fixup_mode mode); + +#endif |