Fix hwpmc sampling for MPC74xxx (G4) processors.
With this, hwpmc sampling now works correctly on these processors. MFC after: 3 weeks Relnotes: yes
This commit is contained in:
parent
244d05e746
commit
da596c6bb1
@ -578,9 +578,9 @@ mpc7xxx_pcpu_init(struct pmc_mdep *md, int cpu)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Clear the MMCRs, and set FC, to disable all PMCs. */
|
/* Clear the MMCRs, and set FC, to disable all PMCs. */
|
||||||
mtspr(SPR_MMCR0, SPR_MMCR0_FC | SPR_MMCR0_PMXE | SPR_MMCR0_PMC1CE | SPR_MMCR0_PMCNCE);
|
mtspr(SPR_MMCR0, SPR_MMCR0_FC | SPR_MMCR0_PMXE |
|
||||||
|
SPR_MMCR0_FCECE | SPR_MMCR0_PMC1CE | SPR_MMCR0_PMCNCE);
|
||||||
mtspr(SPR_MMCR1, 0);
|
mtspr(SPR_MMCR1, 0);
|
||||||
mtmsr(mfmsr() | PSL_PMM);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -667,7 +667,6 @@ mpc7xxx_intr(int cpu, struct trapframe *tf)
|
|||||||
uint32_t config;
|
uint32_t config;
|
||||||
struct pmc *pm;
|
struct pmc *pm;
|
||||||
struct powerpc_cpu *pac;
|
struct powerpc_cpu *pac;
|
||||||
pmc_value_t v;
|
|
||||||
|
|
||||||
KASSERT(cpu >= 0 && cpu < pmc_cpu_max(),
|
KASSERT(cpu >= 0 && cpu < pmc_cpu_max(),
|
||||||
("[powerpc,%d] out of range CPU %d", __LINE__, cpu));
|
("[powerpc,%d] out of range CPU %d", __LINE__, cpu));
|
||||||
@ -679,8 +678,7 @@ mpc7xxx_intr(int cpu, struct trapframe *tf)
|
|||||||
|
|
||||||
pac = powerpc_pcpu[cpu];
|
pac = powerpc_pcpu[cpu];
|
||||||
|
|
||||||
config = mfspr(SPR_MMCR0);
|
config = mfspr(SPR_MMCR0) & ~SPR_MMCR0_FC;
|
||||||
mtspr(SPR_MMCR0, config | SPR_MMCR0_FC);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* look for all PMCs that have interrupted:
|
* look for all PMCs that have interrupted:
|
||||||
@ -704,21 +702,21 @@ mpc7xxx_intr(int cpu, struct trapframe *tf)
|
|||||||
if (pm->pm_state != PMC_STATE_RUNNING)
|
if (pm->pm_state != PMC_STATE_RUNNING)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* Stop the PMC, reload count. */
|
/* Stop the counter if logging fails. */
|
||||||
v = pm->pm_sc.pm_reloadcount;
|
|
||||||
mpc7xxx_pmcn_write(i, v);
|
|
||||||
|
|
||||||
/* Restart the counter if logging succeeded. */
|
|
||||||
error = pmc_process_interrupt(cpu, PMC_HR, pm, tf,
|
error = pmc_process_interrupt(cpu, PMC_HR, pm, tf,
|
||||||
TRAPF_USERMODE(tf));
|
TRAPF_USERMODE(tf));
|
||||||
if (error != 0)
|
if (error != 0)
|
||||||
mpc7xxx_stop_pmc(cpu, i);
|
mpc7xxx_stop_pmc(cpu, i);
|
||||||
|
|
||||||
|
/* reload count. */
|
||||||
|
mpc7xxx_write_pmc(cpu, i, pm->pm_sc.pm_reloadcount);
|
||||||
|
}
|
||||||
|
|
||||||
atomic_add_int(retval ? &pmc_stats.pm_intr_processed :
|
atomic_add_int(retval ? &pmc_stats.pm_intr_processed :
|
||||||
&pmc_stats.pm_intr_ignored, 1);
|
&pmc_stats.pm_intr_ignored, 1);
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Re-enable PERF exceptions. */
|
/* Re-enable PERF exceptions. */
|
||||||
|
if (retval)
|
||||||
mtspr(SPR_MMCR0, config | SPR_MMCR0_PMXE);
|
mtspr(SPR_MMCR0, config | SPR_MMCR0_PMXE);
|
||||||
|
|
||||||
return (retval);
|
return (retval);
|
||||||
|
Loading…
Reference in New Issue
Block a user