Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0 |
Jiri Olsa | c9b951c4 | 2014-01-07 13:47:29 +0100 | [diff] [blame] | 2 | #include <errno.h> |
| 3 | #include "perf_regs.h" |
Jiri Olsa | 0c4e774 | 2014-04-17 19:39:10 +0200 | [diff] [blame] | 4 | #include "event.h" |
Jiri Olsa | c9b951c4 | 2014-01-07 13:47:29 +0100 | [diff] [blame] | 5 | |
Stephane Eranian | af4aead | 2015-09-01 11:30:14 +0200 | [diff] [blame] | 6 | const struct sample_reg __weak sample_reg_masks[] = { |
| 7 | SMPL_REG_END |
| 8 | }; |
| 9 | |
Ravi Bangoria | d451a20 | 2017-03-28 15:17:53 +0530 | [diff] [blame] | 10 | int __weak arch_sdt_arg_parse_op(char *old_op __maybe_unused, |
| 11 | char **new_op __maybe_unused) |
Alexis Berlemont | 3b1f831 | 2016-12-14 01:07:32 +0100 | [diff] [blame] | 12 | { |
Ravi Bangoria | d451a20 | 2017-03-28 15:17:53 +0530 | [diff] [blame] | 13 | return SDT_ARG_SKIP; |
Alexis Berlemont | 3b1f831 | 2016-12-14 01:07:32 +0100 | [diff] [blame] | 14 | } |
| 15 | |
Kan Liang | af785e7 | 2019-05-14 13:19:33 -0700 | [diff] [blame] | 16 | uint64_t __weak arch__intr_reg_mask(void) |
| 17 | { |
| 18 | return PERF_REGS_MASK; |
| 19 | } |
| 20 | |
| 21 | uint64_t __weak arch__user_reg_mask(void) |
| 22 | { |
| 23 | return PERF_REGS_MASK; |
| 24 | } |
| 25 | |
Sukadev Bhattiprolu | 9fb4765 | 2015-09-24 17:53:49 -0400 | [diff] [blame] | 26 | #ifdef HAVE_PERF_REGS_SUPPORT |
Jiri Olsa | c9b951c4 | 2014-01-07 13:47:29 +0100 | [diff] [blame] | 27 | int perf_reg_value(u64 *valp, struct regs_dump *regs, int id) |
| 28 | { |
| 29 | int i, idx = 0; |
| 30 | u64 mask = regs->mask; |
| 31 | |
Naveen N. Rao | f478220 | 2016-04-28 15:01:10 +0530 | [diff] [blame] | 32 | if (regs->cache_mask & (1ULL << id)) |
Jiri Olsa | 0c4e774 | 2014-04-17 19:39:10 +0200 | [diff] [blame] | 33 | goto out; |
| 34 | |
Naveen N. Rao | f478220 | 2016-04-28 15:01:10 +0530 | [diff] [blame] | 35 | if (!(mask & (1ULL << id))) |
Jiri Olsa | c9b951c4 | 2014-01-07 13:47:29 +0100 | [diff] [blame] | 36 | return -EINVAL; |
| 37 | |
| 38 | for (i = 0; i < id; i++) { |
Naveen N. Rao | f478220 | 2016-04-28 15:01:10 +0530 | [diff] [blame] | 39 | if (mask & (1ULL << i)) |
Jiri Olsa | c9b951c4 | 2014-01-07 13:47:29 +0100 | [diff] [blame] | 40 | idx++; |
| 41 | } |
| 42 | |
Naveen N. Rao | f478220 | 2016-04-28 15:01:10 +0530 | [diff] [blame] | 43 | regs->cache_mask |= (1ULL << id); |
Jiri Olsa | 0c4e774 | 2014-04-17 19:39:10 +0200 | [diff] [blame] | 44 | regs->cache_regs[id] = regs->regs[idx]; |
| 45 | |
| 46 | out: |
| 47 | *valp = regs->cache_regs[id]; |
Jiri Olsa | c9b951c4 | 2014-01-07 13:47:29 +0100 | [diff] [blame] | 48 | return 0; |
| 49 | } |
Sukadev Bhattiprolu | 9fb4765 | 2015-09-24 17:53:49 -0400 | [diff] [blame] | 50 | #endif |