76a4efa809
struct perf_sample_data lives on-stack, we should be careful about it's size. Furthermore, the pt_regs copy in there is only because x86_64 is a trainwreck, solve it differently. Reported-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Tested-by: Steven Rostedt <rostedt@goodmis.org> Link: https://lkml.kernel.org/r/20201030151955.258178461@infradead.org
51 lines
1.1 KiB
C
51 lines
1.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _LINUX_PERF_REGS_H
|
|
#define _LINUX_PERF_REGS_H
|
|
|
|
#include <linux/sched/task_stack.h>
|
|
|
|
struct perf_regs {
|
|
__u64 abi;
|
|
struct pt_regs *regs;
|
|
};
|
|
|
|
#ifdef CONFIG_HAVE_PERF_REGS
|
|
#include <asm/perf_regs.h>
|
|
|
|
#ifndef PERF_REG_EXTENDED_MASK
|
|
#define PERF_REG_EXTENDED_MASK 0
|
|
#endif
|
|
|
|
u64 perf_reg_value(struct pt_regs *regs, int idx);
|
|
int perf_reg_validate(u64 mask);
|
|
u64 perf_reg_abi(struct task_struct *task);
|
|
void perf_get_regs_user(struct perf_regs *regs_user,
|
|
struct pt_regs *regs);
|
|
#else
|
|
|
|
#define PERF_REG_EXTENDED_MASK 0
|
|
|
|
static inline u64 perf_reg_value(struct pt_regs *regs, int idx)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline int perf_reg_validate(u64 mask)
|
|
{
|
|
return mask ? -ENOSYS : 0;
|
|
}
|
|
|
|
static inline u64 perf_reg_abi(struct task_struct *task)
|
|
{
|
|
return PERF_SAMPLE_REGS_ABI_NONE;
|
|
}
|
|
|
|
static inline void perf_get_regs_user(struct perf_regs *regs_user,
|
|
struct pt_regs *regs)
|
|
{
|
|
regs_user->regs = task_pt_regs(current);
|
|
regs_user->abi = perf_reg_abi(current);
|
|
}
|
|
#endif /* CONFIG_HAVE_PERF_REGS */
|
|
#endif /* _LINUX_PERF_REGS_H */
|