binutils-gdb/gdb/nat/x86-linux.h
Andrew Burgess fab07978ec gdb/x86: move reading of cs and ds state into gdb/nat directory
This patch is part of a series that has the aim sharing the x86 Linux
target description creation code between GDB and gdbserver.

Within GDB part of this process involves reading the cs and ds state
from the 'struct user_regs_struct' using a ptrace call.

This isn't done by gdbserver, which is part of the motivation for this
whole series; the approach gdbserver takes is inferior to the approach
GDB takes (gdbserver relies on reading the file being debugged, and
extracting similar information from the file headers).

This commit moves the reading of cs and ds, which is used to figure
out if a thread is 32-bit or 64-bit (or in x32 mode), into the gdb/nat
directory so that the code can be shared with gdbserver, but at this
point I'm not actually using the code in gdbserver, that will come
later.

As such there should be no user visible changes after this commit, GDB
continues to do things as it did before (reading cs/ds), while
gdbserver continues to use its own approach (which doesn't require
reading cs/ds).

Approved-By: John Baldwin <jhb@FreeBSD.org>
Reviewed-By: Felix Willgerodt <felix.willgerodt@intel.com>
2024-06-14 09:08:45 +01:00

79 lines
2.4 KiB
C++

/* Native-dependent code for GNU/Linux x86 (i386 and x86-64).
Copyright (C) 1999-2024 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 NAT_X86_LINUX_H
#define NAT_X86_LINUX_H
#include "nat/linux-nat.h"
/* Set whether our local mirror of LWP's debug registers has been
changed since the values were last written to the thread. Nonzero
indicates that a change has been made, zero indicates no change. */
extern void lwp_set_debug_registers_changed (struct lwp_info *lwp,
int value);
/* Return nonzero if our local mirror of LWP's debug registers has
been changed since the values were last written to the thread,
zero otherwise. */
extern int lwp_debug_registers_changed (struct lwp_info *lwp);
/* Function to call when a new thread is detected. */
extern void x86_linux_new_thread (struct lwp_info *lwp);
/* Function to call when a thread is being deleted. */
extern void x86_linux_delete_thread (struct arch_lwp_info *arch_lwp);
/* Function to call prior to resuming a thread. */
extern void x86_linux_prepare_to_resume (struct lwp_info *lwp);
/* Return value from x86_linux_ptrace_get_arch_size function. Indicates if
a thread is 32-bit, 64-bit, or x32. */
struct x86_linux_arch_size
{
explicit x86_linux_arch_size (bool is_64bit, bool is_x32)
: m_is_64bit (is_64bit),
m_is_x32 (is_x32)
{
/* Nothing. */
}
bool is_64bit () const
{ return m_is_64bit; }
bool is_x32 () const
{ return m_is_x32; }
private:
bool m_is_64bit = false;
bool m_is_x32 = false;
};
/* Use ptrace calls to figure out if thread TID is 32-bit, 64-bit, or
64-bit running in x32 mode. */
extern x86_linux_arch_size x86_linux_ptrace_get_arch_size (int tid);
#endif /* NAT_X86_LINUX_H */