blob: a8ace5cc6301f184e5d37210e00402234a014a4b [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001// SPDX-License-Identifier: GPL-2.0
Heiko Carstensf602be62011-01-05 12:48:12 +01002/*
3 * Mapping of DWARF debug register numbers into register names.
4 *
Hendrik Bruecknera81c4212017-12-04 10:56:49 +01005 * Copyright IBM Corp. 2010, 2017
6 * Author(s): Heiko Carstens <heiko.carstens@de.ibm.com>,
7 * Hendrik Brueckner <brueckner@linux.vnet.ibm.com>
Heiko Carstensf602be62011-01-05 12:48:12 +01008 *
9 */
10
Hendrik Bruecknera81c4212017-12-04 10:56:49 +010011#include <errno.h>
Cody P Schafer861e10b2013-03-14 15:27:51 -070012#include <stddef.h>
Hendrik Bruecknera81c4212017-12-04 10:56:49 +010013#include <stdlib.h>
Hendrik Bruecknera9fc2db2017-11-08 09:01:12 +010014#include <linux/kernel.h>
Hendrik Bruecknera81c4212017-12-04 10:56:49 +010015#include <asm/ptrace.h>
16#include <string.h>
17#include <dwarf-regs.h>
Hendrik Bruecknera9fc2db2017-11-08 09:01:12 +010018#include "dwarf-regs-table.h"
Heiko Carstensf602be62011-01-05 12:48:12 +010019
20const char *get_arch_regstr(unsigned int n)
21{
Hendrik Bruecknera9fc2db2017-11-08 09:01:12 +010022 return (n >= ARRAY_SIZE(s390_dwarf_regs)) ? NULL : s390_dwarf_regs[n];
Heiko Carstensf602be62011-01-05 12:48:12 +010023}
Hendrik Bruecknera81c4212017-12-04 10:56:49 +010024
25/*
26 * Convert the register name into an offset to struct pt_regs (kernel).
27 * This is required by the BPF prologue generator. The BPF
28 * program is called in the BPF overflow handler in the perf
29 * core.
30 */
31int regs_query_register_offset(const char *name)
32{
33 unsigned long gpr;
34
35 if (!name || strncmp(name, "%r", 2))
36 return -EINVAL;
37
38 errno = 0;
39 gpr = strtoul(name + 2, NULL, 10);
40 if (errno || gpr >= 16)
41 return -EINVAL;
42
43 return offsetof(user_pt_regs, gprs) + 8 * gpr;
44}