2  * Copyright (C) 2004 Anton Blanchard <anton@au.ibm.com>, IBM
 
   3  * Added mmcra[slot] support:
 
   4  * Copyright (C) 2006-2007 Will Schmidt <willschm@us.ibm.com>, IBM
 
   6  * This program is free software; you can redistribute it and/or
 
   7  * modify it under the terms of the GNU General Public License
 
   8  * as published by the Free Software Foundation; either version
 
   9  * 2 of the License, or (at your option) any later version.
 
  12 #include <linux/oprofile.h>
 
  13 #include <linux/init.h>
 
  14 #include <linux/smp.h>
 
  15 #include <asm/firmware.h>
 
  16 #include <asm/ptrace.h>
 
  17 #include <asm/system.h>
 
  18 #include <asm/processor.h>
 
  19 #include <asm/cputable.h>
 
  21 #include <asm/oprofile_impl.h>
 
  26 static unsigned long reset_value[OP_MAX_COUNTER];
 
  28 static int oprofile_running;
 
  30 /* mmcr values are set in power4_reg_setup, used in power4_cpu_setup */
 
  35 static int power4_reg_setup(struct op_counter_config *ctr,
 
  36                              struct op_system_config *sys,
 
  42          * The performance counter event settings are given in the mmcr0,
 
  43          * mmcr1 and mmcra values passed from the user in the
 
  44          * op_system_config structure (sys variable).
 
  46         mmcr0_val = sys->mmcr0;
 
  47         mmcr1_val = sys->mmcr1;
 
  48         mmcra_val = sys->mmcra;
 
  50         for (i = 0; i < cur_cpu_spec->num_pmcs; ++i)
 
  51                 reset_value[i] = 0x80000000UL - ctr[i].count;
 
  53         /* setup user and kernel profiling */
 
  54         if (sys->enable_kernel)
 
  55                 mmcr0_val &= ~MMCR0_KERNEL_DISABLE;
 
  57                 mmcr0_val |= MMCR0_KERNEL_DISABLE;
 
  60                 mmcr0_val &= ~MMCR0_PROBLEM_DISABLE;
 
  62                 mmcr0_val |= MMCR0_PROBLEM_DISABLE;
 
  67 extern void ppc_enable_pmcs(void);
 
  70  * Older CPUs require the MMCRA sample bit to be always set, but newer 
 
  71  * CPUs only want it set for some groups. Eventually we will remove all
 
  72  * knowledge of this bit in the kernel, oprofile userspace should be
 
  73  * setting it when required.
 
  75  * In order to keep current installations working we force the bit for
 
  76  * those older CPUs. Once everyone has updated their oprofile userspace we
 
  77  * can remove this hack.
 
  79 static inline int mmcra_must_set_sample(void)
 
  81         if (__is_processor(PV_POWER4) || __is_processor(PV_POWER4p) ||
 
  82             __is_processor(PV_970) || __is_processor(PV_970FX) ||
 
  83             __is_processor(PV_970MP) || __is_processor(PV_970GX))
 
  89 static int power4_cpu_setup(struct op_counter_config *ctr)
 
  91         unsigned int mmcr0 = mmcr0_val;
 
  92         unsigned long mmcra = mmcra_val;
 
  96         /* set the freeze bit */
 
  98         mtspr(SPRN_MMCR0, mmcr0);
 
 100         mmcr0 |= MMCR0_FCM1|MMCR0_PMXE|MMCR0_FCECE;
 
 101         mmcr0 |= MMCR0_PMC1CE|MMCR0_PMCjCE;
 
 102         mtspr(SPRN_MMCR0, mmcr0);
 
 104         mtspr(SPRN_MMCR1, mmcr1_val);
 
 106         if (mmcra_must_set_sample())
 
 107                 mmcra |= MMCRA_SAMPLE_ENABLE;
 
 108         mtspr(SPRN_MMCRA, mmcra);
 
 110         dbg("setup on cpu %d, mmcr0 %lx\n", smp_processor_id(),
 
 112         dbg("setup on cpu %d, mmcr1 %lx\n", smp_processor_id(),
 
 114         dbg("setup on cpu %d, mmcra %lx\n", smp_processor_id(),
 
 120 static int power4_start(struct op_counter_config *ctr)
 
 125         /* set the PMM bit (see comment below) */
 
 126         mtmsrd(mfmsr() | MSR_PMM);
 
 128         for (i = 0; i < cur_cpu_spec->num_pmcs; ++i) {
 
 129                 if (ctr[i].enabled) {
 
 130                         classic_ctr_write(i, reset_value[i]);
 
 132                         classic_ctr_write(i, 0);
 
 136         mmcr0 = mfspr(SPRN_MMCR0);
 
 139          * We must clear the PMAO bit on some (GQ) chips. Just do it
 
 142         mmcr0 &= ~MMCR0_PMAO;
 
 145          * now clear the freeze bit, counting will not start until we
 
 146          * rfid from this excetion, because only at that point will
 
 147          * the PMM bit be cleared
 
 150         mtspr(SPRN_MMCR0, mmcr0);
 
 152         oprofile_running = 1;
 
 154         dbg("start on cpu %d, mmcr0 %x\n", smp_processor_id(), mmcr0);
 
 158 static void power4_stop(void)
 
 162         /* freeze counters */
 
 163         mmcr0 = mfspr(SPRN_MMCR0);
 
 165         mtspr(SPRN_MMCR0, mmcr0);
 
 167         oprofile_running = 0;
 
 169         dbg("stop on cpu %d, mmcr0 %x\n", smp_processor_id(), mmcr0);
 
 174 /* Fake functions used by canonicalize_pc */
 
 175 static void __used hypervisor_bucket(void)
 
 179 static void __used rtas_bucket(void)
 
 183 static void __used kernel_unknown_bucket(void)
 
 188  * On GQ and newer the MMCRA stores the HV and PR bits at the time
 
 189  * the SIAR was sampled. We use that to work out if the SIAR was sampled in
 
 190  * the hypervisor, our exception vectors or RTAS.
 
 191  * If the MMCRA_SAMPLE_ENABLE bit is set, we can use the MMCRA[slot] bits
 
 192  * to more accurately identify the address of the sampled instruction. The
 
 193  * mmcra[slot] bits represent the slot number of a sampled instruction
 
 194  * within an instruction group.  The slot will contain a value between 1
 
 195  * and 5 if MMCRA_SAMPLE_ENABLE is set, otherwise 0.
 
 197 static unsigned long get_pc(struct pt_regs *regs)
 
 199         unsigned long pc = mfspr(SPRN_SIAR);
 
 203         /* Cant do much about it */
 
 204         if (!cur_cpu_spec->oprofile_mmcra_sihv)
 
 207         mmcra = mfspr(SPRN_MMCRA);
 
 209         if (mmcra & MMCRA_SAMPLE_ENABLE) {
 
 210                 slot = ((mmcra & MMCRA_SLOT) >> MMCRA_SLOT_SHIFT);
 
 212                         pc += 4 * (slot - 1);
 
 215         /* Were we in the hypervisor? */
 
 216         if (firmware_has_feature(FW_FEATURE_LPAR) &&
 
 217             (mmcra & cur_cpu_spec->oprofile_mmcra_sihv))
 
 218                 /* function descriptor madness */
 
 219                 return *((unsigned long *)hypervisor_bucket);
 
 221         /* We were in userspace, nothing to do */
 
 222         if (mmcra & cur_cpu_spec->oprofile_mmcra_sipr)
 
 225 #ifdef CONFIG_PPC_RTAS
 
 226         /* Were we in RTAS? */
 
 227         if (pc >= rtas.base && pc < (rtas.base + rtas.size))
 
 228                 /* function descriptor madness */
 
 229                 return *((unsigned long *)rtas_bucket);
 
 232         /* Were we in our exception vectors or SLB real mode miss handler? */
 
 233         if (pc < 0x1000000UL)
 
 234                 return (unsigned long)__va(pc);
 
 236         /* Not sure where we were */
 
 237         if (!is_kernel_addr(pc))
 
 238                 /* function descriptor madness */
 
 239                 return *((unsigned long *)kernel_unknown_bucket);
 
 244 static int get_kernel(unsigned long pc, unsigned long mmcra)
 
 248         if (!cur_cpu_spec->oprofile_mmcra_sihv) {
 
 249                 is_kernel = is_kernel_addr(pc);
 
 251                 is_kernel = ((mmcra & cur_cpu_spec->oprofile_mmcra_sipr) == 0);
 
 257 static void power4_handle_interrupt(struct pt_regs *regs,
 
 258                                     struct op_counter_config *ctr)
 
 267         mmcra = mfspr(SPRN_MMCRA);
 
 270         is_kernel = get_kernel(pc, mmcra);
 
 272         /* set the PMM bit (see comment below) */
 
 273         mtmsrd(mfmsr() | MSR_PMM);
 
 275         for (i = 0; i < cur_cpu_spec->num_pmcs; ++i) {
 
 276                 val = classic_ctr_read(i);
 
 278                         if (oprofile_running && ctr[i].enabled) {
 
 279                                 oprofile_add_ext_sample(pc, regs, i, is_kernel);
 
 280                                 classic_ctr_write(i, reset_value[i]);
 
 282                                 classic_ctr_write(i, 0);
 
 287         mmcr0 = mfspr(SPRN_MMCR0);
 
 289         /* reset the perfmon trigger */
 
 293          * We must clear the PMAO bit on some (GQ) chips. Just do it
 
 296         mmcr0 &= ~MMCR0_PMAO;
 
 298         /* Clear the appropriate bits in the MMCRA */
 
 299         mmcra &= ~cur_cpu_spec->oprofile_mmcra_clear;
 
 300         mtspr(SPRN_MMCRA, mmcra);
 
 303          * now clear the freeze bit, counting will not start until we
 
 304          * rfid from this exception, because only at that point will
 
 305          * the PMM bit be cleared
 
 308         mtspr(SPRN_MMCR0, mmcr0);
 
 311 struct op_powerpc_model op_model_power4 = {
 
 312         .reg_setup              = power4_reg_setup,
 
 313         .cpu_setup              = power4_cpu_setup,
 
 314         .start                  = power4_start,
 
 316         .handle_interrupt       = power4_handle_interrupt,