/* * Copyright (C) 2004 Anton Blanchard , IBM * * Based on alpha version. * * 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. */ #ifndef OP_IMPL_H #define OP_IMPL_H 1 #define OP_MAX_COUNTER 8 #define MSR_PMM (1UL << (63 - 61)) /* freeze counters. set to 1 on a perfmon exception */ #define MMCR0_FC (1UL << (31 - 0)) /* freeze counters while MSR mark = 1 */ #define MMCR0_FCM1 (1UL << (31 - 3)) /* performance monitor exception enable */ #define MMCR0_PMXE (1UL << (31 - 5)) /* freeze counters on enabled condition or event */ #define MMCR0_FCECE (1UL << (31 - 6)) /* performance monitor alert has occurred, set to 0 after handling exception */ #define MMCR0_PMAO (1UL << (31 - 24)) /* PMC1 count enable*/ #define MMCR0_PMC1INTCONTROL (1UL << (31 - 16)) /* PMCn count enable*/ #define MMCR0_PMCNINTCONTROL (1UL << (31 - 17)) /* state of MSR HV when SIAR set */ #define MMCRA_SIHV (1UL << (63 - 35)) /* state of MSR PR when SIAR set */ #define MMCRA_SIPR (1UL << (63 - 36)) /* enable sampling */ #define MMCRA_SAMPLE_ENABLE (1UL << (63 - 63)) /* Per-counter configuration as set via oprofilefs. */ struct op_counter_config { unsigned long valid; unsigned long enabled; unsigned long event; unsigned long count; unsigned long kernel; /* We dont support per counter user/kernel selection */ unsigned long user; unsigned long unit_mask; }; /* System-wide configuration as set via oprofilefs. */ struct op_system_config { unsigned long enable_kernel; unsigned long enable_user; }; /* Per-arch configuration */ struct op_ppc64_model { void (*reg_setup) (struct op_counter_config *, struct op_system_config *, int num_counters); void (*cpu_setup) (void *); void (*start) (struct op_counter_config *); void (*stop) (void); void (*handle_interrupt) (struct pt_regs *, struct op_counter_config *); int num_counters; }; static inline unsigned int ctr_read(unsigned int i) { switch(i) { case 0: return mfspr(SPRN_PMC1); case 1: return mfspr(SPRN_PMC2); case 2: return mfspr(SPRN_PMC3); case 3: return mfspr(SPRN_PMC4); case 4: return mfspr(SPRN_PMC5); case 5: return mfspr(SPRN_PMC6); case 6: return mfspr(SPRN_PMC7); case 7: return mfspr(SPRN_PMC8); default: return 0; } } static inline void ctr_write(unsigned int i, unsigned int val) { switch(i) { case 0: mtspr(SPRN_PMC1, val); break; case 1: mtspr(SPRN_PMC2, val); break; case 2: mtspr(SPRN_PMC3, val); break; case 3: mtspr(SPRN_PMC4, val); break; case 4: mtspr(SPRN_PMC5, val); break; case 5: mtspr(SPRN_PMC6, val); break; case 6: mtspr(SPRN_PMC7, val); break; case 7: mtspr(SPRN_PMC8, val); break; default: break; } } #endif