Blame backends/aarch64_corenote.c

Packit 032894
/* AArch64 specific core note handling.
Packit 032894
   Copyright (C) 2013 Red Hat, Inc.
Packit 032894
   This file is part of elfutils.
Packit 032894
Packit 032894
   This file is free software; you can redistribute it and/or modify
Packit 032894
   it under the terms of either
Packit 032894
Packit 032894
     * the GNU Lesser General Public License as published by the Free
Packit 032894
       Software Foundation; either version 3 of the License, or (at
Packit 032894
       your option) any later version
Packit 032894
Packit 032894
   or
Packit 032894
Packit 032894
     * the GNU General Public License as published by the Free
Packit 032894
       Software Foundation; either version 2 of the License, or (at
Packit 032894
       your option) any later version
Packit 032894
Packit 032894
   or both in parallel, as here.
Packit 032894
Packit 032894
   elfutils is distributed in the hope that it will be useful, but
Packit 032894
   WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 032894
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 032894
   General Public License for more details.
Packit 032894
Packit 032894
   You should have received copies of the GNU General Public License and
Packit 032894
   the GNU Lesser General Public License along with this program.  If
Packit 032894
   not, see <http://www.gnu.org/licenses/>.  */
Packit 032894
Packit 032894
#ifdef HAVE_CONFIG_H
Packit 032894
# include <config.h>
Packit 032894
#endif
Packit 032894
Packit 032894
#include <elf.h>
Packit 032894
#include <inttypes.h>
Packit 032894
#include <stddef.h>
Packit 032894
#include <stdio.h>
Packit 032894
#include <sys/time.h>
Packit 032894
Packit 032894
#define BACKEND aarch64_
Packit 032894
#include "libebl_CPU.h"
Packit 032894
Packit 032894
#define	ULONG			uint64_t
Packit 032894
#define PID_T			int32_t
Packit 032894
#define	UID_T			uint32_t
Packit 032894
#define	GID_T			uint32_t
Packit 032894
#define ALIGN_ULONG		8
Packit 032894
#define ALIGN_PID_T		4
Packit 032894
#define ALIGN_UID_T		4
Packit 032894
#define ALIGN_GID_T		4
Packit 032894
#define TYPE_ULONG		ELF_T_XWORD
Packit 032894
#define TYPE_PID_T		ELF_T_SWORD
Packit 032894
#define TYPE_UID_T		ELF_T_WORD
Packit 032894
#define TYPE_GID_T		ELF_T_WORD
Packit 032894
Packit 032894
#define PRSTATUS_REGS_SIZE	(34 * 8)
Packit 032894
Packit 032894
static const Ebl_Register_Location prstatus_regs[] =
Packit 032894
  {
Packit 032894
    { .offset = 0, .regno = 0, .count = 32, .bits = 64 }, /* x0..x30, sp */
Packit 032894
  };
Packit 032894
Packit 032894
#define PRSTATUS_REGSET_ITEMS						\
Packit 032894
  {									\
Packit 032894
    .name = "pc", .type = ELF_T_XWORD, .format = 'x',			\
Packit 032894
    .offset = (offsetof (struct EBLHOOK(prstatus), pr_reg)		\
Packit 032894
	       + PRSTATUS_REGS_SIZE - 16),				\
Packit 032894
    .group = "register",						\
Packit 032894
    .pc_register = true							\
Packit 032894
  },									\
Packit 032894
  {									\
Packit 032894
    .name = "pstate", .type = ELF_T_XWORD, .format = 'x',		\
Packit 032894
    .offset = (offsetof (struct EBLHOOK(prstatus), pr_reg)		\
Packit 032894
	       + PRSTATUS_REGS_SIZE - 8),				\
Packit 032894
    .group = "register"							\
Packit 032894
  }
Packit 032894
Packit 032894
static const Ebl_Register_Location aarch64_fpregset_regs[] =
Packit 032894
  {
Packit 032894
    { .offset = 0, .regno = 64, .count = 32, .bits = 128 }, /* v0..v31 */
Packit 032894
  };
Packit 032894
Packit 032894
static const Ebl_Core_Item aarch64_fpregset_items[] =
Packit 032894
  {
Packit 032894
    {
Packit 032894
      .name = "fpsr", .type = ELF_T_WORD, .format = 'x',
Packit 032894
      .offset = 512, .group = "register"
Packit 032894
    },
Packit 032894
    {
Packit 032894
      .name = "fpcr", .type = ELF_T_WORD, .format = 'x',
Packit 032894
      .offset = 516, .group = "register"
Packit 032894
    }
Packit 032894
  };
Packit 032894
Packit 032894
static const Ebl_Core_Item aarch64_tls_items[] =
Packit 032894
  {
Packit 032894
    {
Packit 032894
      .name = "tls", .type = ELF_T_XWORD, .format = 'x',
Packit 032894
      .offset = 0, .group = "register"
Packit 032894
    }
Packit 032894
  };
Packit 032894
Packit 032894
static const Ebl_Core_Item aarch64_syscall_items [] =
Packit 032894
  {
Packit 032894
    {
Packit 032894
      .name = "syscall", .type = ELF_T_WORD, .format = 'x',
Packit 032894
      .offset = 0, .group = "register"
Packit 032894
    }
Packit 032894
  };
Packit 032894
Packit 032894
#define AARCH64_HWBP_REG(KIND, N)					\
Packit 032894
    {									\
Packit 032894
      .name = "DBG" KIND "VR" #N "_EL1", .type = ELF_T_XWORD, .format = 'x', \
Packit 032894
      .offset = 8 + N * 16, .group = "register"				\
Packit 032894
    },									\
Packit 032894
    {									\
Packit 032894
      .name = "DBG" KIND "CR" #N "_EL1", .type = ELF_T_WORD, .format = 'x', \
Packit 032894
      .offset = 16 + N * 16, .group = "register"			\
Packit 032894
    }
Packit 032894
Packit 032894
#define AARCH64_BP_WP_GROUP(KIND, NAME)					\
Packit 032894
  static const Ebl_Core_Item NAME[] =					\
Packit 032894
    {									\
Packit 032894
      {									\
Packit 032894
	.name = "dbg_info", .type = ELF_T_WORD, .format = 'x',		\
Packit 032894
	.offset = 0, .group = "control"					\
Packit 032894
      },								\
Packit 032894
      /* N.B.: 4 bytes of padding here.  */				\
Packit 032894
									\
Packit 032894
      AARCH64_HWBP_REG(KIND, 0),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 1),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 2),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 3),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 4),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 5),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 6),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 7),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 8),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 9),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 10),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 11),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 12),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 13),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 14),					\
Packit 032894
      AARCH64_HWBP_REG(KIND, 15),					\
Packit 032894
									\
Packit 032894
      /* The DBGBVR+DBGBCR pair only takes 12 bytes.  There are 4 bytes	\
Packit 032894
	 of padding at the end of each pair.  The item formatter in	\
Packit 032894
	 readelf can skip those, but the missing 4 bytes at the end of	\
Packit 032894
	 the whole block cause it to assume the whole item bunch	\
Packit 032894
	 repeats, so it loops around to read more.  Insert an explicit	\
Packit 032894
	 (but invisible) padding word.  */				\
Packit 032894
      {									\
Packit 032894
	.name = "", .type = ELF_T_WORD, .format = 'h',			\
Packit 032894
	.offset = 260, .group = "register"				\
Packit 032894
      }									\
Packit 032894
    }
Packit 032894
Packit 032894
AARCH64_BP_WP_GROUP ("B", aarch64_hw_bp_items);
Packit 032894
AARCH64_BP_WP_GROUP ("W", aarch64_hw_wp_items);
Packit 032894
Packit 032894
#undef AARCH64_BP_WP_GROUP
Packit 032894
#undef AARCH64_HWBP_REG
Packit 032894
Packit 032894
#define EXTRA_NOTES							\
Packit 032894
  EXTRA_REGSET_ITEMS (NT_FPREGSET, 528,					\
Packit 032894
		      aarch64_fpregset_regs, aarch64_fpregset_items)	\
Packit 032894
  EXTRA_ITEMS (NT_ARM_TLS, 8, aarch64_tls_items)			\
Packit 032894
  EXTRA_ITEMS (NT_ARM_HW_BREAK, 264, aarch64_hw_bp_items)		\
Packit 032894
  EXTRA_ITEMS (NT_ARM_HW_WATCH, 264, aarch64_hw_wp_items)		\
Packit 032894
  EXTRA_ITEMS (NT_ARM_SYSTEM_CALL, 4, aarch64_syscall_items)
Packit 032894
Packit 032894
#include "linux-core-note.c"