68dd718256
This change adds support for POWER8 and POWER9 PMCs (bare metal and pseries). All PowerISA 2.07B non-random events are supported. Implementation was based on that of PPC970. Reviewed by: jhibbits Sponsored by: Eldorado Research Institute (eldorado.org.br) Differential Revision: https://reviews.freebsd.org/D26110
97 lines
2.2 KiB
C
97 lines
2.2 KiB
C
/*-
|
|
* This file is in the public domain.
|
|
*
|
|
* $FreeBSD$
|
|
*/
|
|
|
|
#ifndef _MACHINE_PMC_MDEP_H_
|
|
#define _MACHINE_PMC_MDEP_H_
|
|
|
|
#define PMC_MDEP_CLASS_INDEX_POWERPC 1
|
|
|
|
union pmc_md_op_pmcallocate {
|
|
uint64_t __pad[4];
|
|
};
|
|
|
|
/* Logging */
|
|
#ifdef __powerpc64__
|
|
#define PMCLOG_READADDR PMCLOG_READ64
|
|
#define PMCLOG_EMITADDR PMCLOG_EMIT64
|
|
#else
|
|
#define PMCLOG_READADDR PMCLOG_READ32
|
|
#define PMCLOG_EMITADDR PMCLOG_EMIT32
|
|
#endif
|
|
|
|
#define mtpmr(reg, val) \
|
|
__asm __volatile("mtpmr %0,%1" : : "K"(reg), "r"(val))
|
|
#define mfpmr(reg) \
|
|
( { register_t val; \
|
|
__asm __volatile("mfpmr %0,%1" : "=r"(val) : "K"(reg)); \
|
|
val; } )
|
|
|
|
#define PMR_PMC0 16
|
|
#define PMR_PMC1 17
|
|
#define PMR_PMC2 18
|
|
#define PMR_PMC3 19
|
|
#define PMR_PMLCa0 144
|
|
#define PMLCax_FC 0x80000000
|
|
#define PMLCax_FCS 0x40000000
|
|
#define PMLCax_FCU 0x20000000
|
|
#define PMLCax_FCM1 0x10000000
|
|
#define PMLCax_FCM0 0x08000000
|
|
#define PMLCax_CE 0x04000000
|
|
#define PMLCax_EVENT(x) ((x) << 16)
|
|
#define PMLCax_FCGS1 0x00000002
|
|
#define PMLCax_FCGS0 0x00000001
|
|
#define PMR_PMLCa1 145
|
|
#define PMR_PMLCa2 146
|
|
#define PMR_PMLCa3 147
|
|
#define PMR_PMLCb0 272
|
|
#define PMLCbx_TRIGONCTL(x) ((x) << 28)
|
|
#define PMLCbx_TRIGOFFCTL(x) ((x) << 24)
|
|
#define PMLCbx_PMCC 0x00800000
|
|
#define PMLCbx_PMP(x) ((x) << 13)
|
|
#define PMLCbx_TREHMUL(x) ((x) << 8)
|
|
#define PMLCbx_TRESHOLD(x) ((x) << 0)
|
|
#define PMR_PMLCb1 273
|
|
#define PMR_PMLCb2 274
|
|
#define PMR_PMLCb3 275
|
|
#define PMR_PMGC0 400
|
|
#define PMGC_FAC 0x80000000
|
|
#define PMGC_PMIE 0x40000000
|
|
#define PMGC_FCECE 0x20000000
|
|
#define PMGC_TBSEL(x) ((x) << 11)
|
|
#define PMGC_TBEE 0x00000100
|
|
#define PMR_UPMC0 0
|
|
#define PMR_UPMC1 1
|
|
#define PMR_UPMC2 2
|
|
#define PMR_UPMC3 3
|
|
#define PMR_UPMLCa0 128
|
|
#define PMR_UPMLCa1 129
|
|
#define PMR_UPMLCa2 130
|
|
#define PMR_UPMLCa3 131
|
|
#define PMR_UPMLCb0 256
|
|
#define PMR_UPMLCb1 257
|
|
#define PMR_UPMLCb2 258
|
|
#define PMR_UPMLCb3 259
|
|
#define PMR_UPMGC0 384
|
|
|
|
#if _KERNEL
|
|
|
|
struct pmc_md_powerpc_pmc {
|
|
uint64_t pm_powerpc_overflowcnt;
|
|
uint32_t pm_powerpc_evsel;
|
|
};
|
|
|
|
union pmc_md_pmc {
|
|
struct pmc_md_powerpc_pmc pm_powerpc;
|
|
};
|
|
|
|
#define PMC_TRAPFRAME_TO_PC(TF) ((TF)->srr0)
|
|
#define PMC_TRAPFRAME_TO_FP(TF) ((TF)->fixreg[1])
|
|
#define PMC_TRAPFRAME_TO_SP(TF) (0)
|
|
|
|
#endif
|
|
|
|
#endif /* !_MACHINE_PMC_MDEP_H_ */
|