forked from mirrors/linux
		
	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
		
			
				
	
	
		
			50 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			50 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 */
 |