2874c5fd28
Based on 1 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms of the gnu general public license as published by the free software foundation either version 2 of the license or at your option any later version extracted by the scancode license scanner the SPDX license identifier GPL-2.0-or-later has been chosen to replace the boilerplate/reference in 3029 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190527070032.746973796@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
42 lines
1.2 KiB
C
42 lines
1.2 KiB
C
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
/*
|
|
* Performance event support - hardware-specific disambiguation
|
|
*
|
|
* For now this is a compile-time decision, but eventually it should be
|
|
* runtime. This would allow multiplatform perf event support for e300 (fsl
|
|
* embedded perf counters) plus server/classic, and would accommodate
|
|
* devices other than the core which provide their own performance counters.
|
|
*
|
|
* Copyright 2010 Freescale Semiconductor, Inc.
|
|
*/
|
|
|
|
#ifdef CONFIG_PPC_PERF_CTRS
|
|
#include <asm/perf_event_server.h>
|
|
#endif
|
|
|
|
#ifdef CONFIG_FSL_EMB_PERF_EVENT
|
|
#include <asm/perf_event_fsl_emb.h>
|
|
#endif
|
|
|
|
#ifdef CONFIG_PERF_EVENTS
|
|
#include <asm/ptrace.h>
|
|
#include <asm/reg.h>
|
|
|
|
#define perf_arch_bpf_user_pt_regs(regs) ®s->user_regs
|
|
|
|
/*
|
|
* Overload regs->result to specify whether we should use the MSR (result
|
|
* is zero) or the SIAR (result is non zero).
|
|
*/
|
|
#define perf_arch_fetch_caller_regs(regs, __ip) \
|
|
do { \
|
|
(regs)->result = 0; \
|
|
(regs)->nip = __ip; \
|
|
(regs)->gpr[1] = current_stack_pointer(); \
|
|
asm volatile("mfmsr %0" : "=r" ((regs)->msr)); \
|
|
} while (0)
|
|
|
|
/* To support perf_regs sier update */
|
|
extern bool is_sier_available(void);
|
|
#endif
|