linux/arch/powerpc/include/asm/perf_event.h
<<
>>
Prefs
   1/* SPDX-License-Identifier: GPL-2.0-or-later */
   2/*
   3 * Performance event support - hardware-specific disambiguation
   4 *
   5 * For now this is a compile-time decision, but eventually it should be
   6 * runtime.  This would allow multiplatform perf event support for e300 (fsl
   7 * embedded perf counters) plus server/classic, and would accommodate
   8 * devices other than the core which provide their own performance counters.
   9 *
  10 * Copyright 2010 Freescale Semiconductor, Inc.
  11 */
  12
  13#ifdef CONFIG_PPC_PERF_CTRS
  14#include <asm/perf_event_server.h>
  15#else
  16static inline bool is_sier_available(void) { return false; }
  17static inline unsigned long get_pmcs_ext_regs(int idx) { return 0; }
  18#endif
  19
  20#ifdef CONFIG_FSL_EMB_PERF_EVENT
  21#include <asm/perf_event_fsl_emb.h>
  22#endif
  23
  24#ifdef CONFIG_PERF_EVENTS
  25#include <asm/ptrace.h>
  26#include <asm/reg.h>
  27
  28#define perf_arch_bpf_user_pt_regs(regs) &regs->user_regs
  29
  30/*
  31 * Overload regs->result to specify whether we should use the MSR (result
  32 * is zero) or the SIAR (result is non zero).
  33 */
  34#define perf_arch_fetch_caller_regs(regs, __ip)                 \
  35        do {                                                    \
  36                (regs)->result = 0;                             \
  37                (regs)->nip = __ip;                             \
  38                (regs)->gpr[1] = current_stack_frame();         \
  39                asm volatile("mfmsr %0" : "=r" ((regs)->msr));  \
  40        } while (0)
  41
  42/* To support perf_regs sier update */
  43extern bool is_sier_available(void);
  44extern unsigned long get_pmcs_ext_regs(int idx);
  45/* To define perf extended regs mask value */
  46extern u64 PERF_REG_EXTENDED_MASK;
  47#define PERF_REG_EXTENDED_MASK  PERF_REG_EXTENDED_MASK
  48#endif
  49