From 122394f1476b1c925a281b15399119500c8231c1 Mon Sep 17 00:00:00 2001 From: Alan Hayward Date: Thu, 31 May 2018 14:36:48 +0100 Subject: Function for reading the Aarch64 SVE vector length Returns 0 for systems without SVE support. Note the defines taken from Linux kernel headers in aarch64-sve-linux-ptrace.h. gdb/ * Makefile.in: Add new header. * gdb/arch/aarch64.h (sve_vg_from_vl): New macro. (sve_vl_from_vg): Likewise. (sve_vq_from_vl): Likewise. (sve_vl_from_vq): Likewise. (sve_vq_from_vg): Likewise. (sve_vg_from_vq): Likewise. * configure.nat: Add new c file. * nat/aarch64-sve-linux-ptrace.c: New file. * nat/aarch64-sve-linux-ptrace.h: New file. gdbserver/ * configure.srv: Add new c/h file. --- gdb/nat/aarch64-sve-linux-ptrace.c | 58 ++++++++++++++++++++++++++++++ gdb/nat/aarch64-sve-linux-ptrace.h | 73 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 131 insertions(+) create mode 100644 gdb/nat/aarch64-sve-linux-ptrace.c create mode 100644 gdb/nat/aarch64-sve-linux-ptrace.h (limited to 'gdb/nat') diff --git a/gdb/nat/aarch64-sve-linux-ptrace.c b/gdb/nat/aarch64-sve-linux-ptrace.c new file mode 100644 index 0000000..3a1dbae --- /dev/null +++ b/gdb/nat/aarch64-sve-linux-ptrace.c @@ -0,0 +1,58 @@ +/* Common target dependent for AArch64 systems. + + Copyright (C) 2018 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 . */ + +#include +#include +#include "common-defs.h" +#include "elf/external.h" +#include "elf/common.h" +#include "aarch64-sve-linux-ptrace.h" +#include "arch/aarch64.h" + +/* See nat/aarch64-sve-linux-ptrace.h. */ + +unsigned long +aarch64_sve_get_vq (int tid) +{ + struct iovec iovec; + struct user_sve_header header; + + iovec.iov_len = sizeof (header); + iovec.iov_base = &header; + + /* Ptrace gives the vector length in bytes. Convert it to VQ, the number of + 128bit chunks in a Z register. We use VQ because 128bits is the minimum + a Z register can increase in size. */ + + if (ptrace (PTRACE_GETREGSET, tid, NT_ARM_SVE, &iovec) < 0) + { + /* SVE is not supported. */ + return 0; + } + + long vq = sve_vq_from_vl (header.vl); + + if (!sve_vl_valid (header.vl)) + { + warning (_("Invalid SVE state from kernel; SVE disabled.")); + return 0; + } + + return vq; +} diff --git a/gdb/nat/aarch64-sve-linux-ptrace.h b/gdb/nat/aarch64-sve-linux-ptrace.h new file mode 100644 index 0000000..a32ddf1 --- /dev/null +++ b/gdb/nat/aarch64-sve-linux-ptrace.h @@ -0,0 +1,73 @@ +/* Common target dependent for AArch64 systems. + + Copyright (C) 2018 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 . */ + +#ifndef AARCH64_SVE_LINUX_PTRACE_H +#define AARCH64_SVE_LINUX_PTRACE_H + +/* Where indicated, this file contains defines and macros lifted directly from + the Linux kernel headers, with no modification. + Refer to Linux kernel documentation for details. */ + +#include +#include +#include +#include + +/* Read VQ for the given tid using ptrace. If SVE is not supported then zero + is returned (on a system that supports SVE, then VQ cannot be zero). */ + +extern unsigned long aarch64_sve_get_vq (int tid); + +/* Structures and defines taken from sigcontext.h. */ + +#ifndef SVE_SIG_ZREGS_SIZE + +#define SVE_VQ_BYTES 16 /* number of bytes per quadword */ + +#define SVE_VQ_MIN 1 +#define SVE_VQ_MAX 512 + +#define SVE_VL_MIN (SVE_VQ_MIN * SVE_VQ_BYTES) +#define SVE_VL_MAX (SVE_VQ_MAX * SVE_VQ_BYTES) + +#define SVE_NUM_ZREGS 32 +#define SVE_NUM_PREGS 16 + +#define sve_vl_valid(vl) \ + ((vl) % SVE_VQ_BYTES == 0 && (vl) >= SVE_VL_MIN && (vl) <= SVE_VL_MAX) + +#endif /* SVE_SIG_ZREGS_SIZE. */ + + +/* Structures and defines taken from ptrace.h. */ + +#ifndef SVE_PT_SVE_ZREG_SIZE + +struct user_sve_header { + __u32 size; /* total meaningful regset content in bytes */ + __u32 max_size; /* maxmium possible size for this thread */ + __u16 vl; /* current vector length */ + __u16 max_vl; /* maximum possible vector length */ + __u16 flags; + __u16 __reserved; +}; + +#endif /* SVE_PT_SVE_ZREG_SIZE. */ + +#endif /* aarch64-sve-linux-ptrace.h */ -- cgit v1.1