Blame src/perfctr-2.6.x/examples/signal/ppc.c

Packit 577717
/* $Id: ppc.c,v 1.1.2.2 2004/12/19 13:53:11 mikpe Exp $
Packit 577717
 * PPC32-specific code.
Packit 577717
 *
Packit 577717
 * Copyright (C) 2004  Mikael Pettersson
Packit 577717
 */
Packit 577717
#include <sys/ucontext.h>
Packit 577717
#include <stdio.h>
Packit 577717
#include <stdlib.h>
Packit 577717
#include <string.h>
Packit 577717
#include "libperfctr.h"
Packit 577717
#include "arch.h"
Packit 577717
Packit 577717
unsigned long ucontext_pc(const struct ucontext *uc)
Packit 577717
{
Packit 577717
    /* glibc-2.3.3 (YDL4) changed the type of uc->uc_mcontext,
Packit 577717
     * breaking code which worked in glibc-2.3.1 (YDL3.0.1).
Packit 577717
     * This formulation works with both, and is cleaner than
Packit 577717
     * selecting glibc-2.3.3 specific code with "#ifdef NGREG".
Packit 577717
     */
Packit 577717
    return uc->uc_mcontext.regs->nip;
Packit 577717
}
Packit 577717
Packit 577717
void do_setup(const struct perfctr_info *info,
Packit 577717
	      struct perfctr_cpu_control *cpu_control)
Packit 577717
{
Packit 577717
    memset(cpu_control, 0, sizeof *cpu_control);
Packit 577717
Packit 577717
    cpu_control->tsc_on = 1;
Packit 577717
    cpu_control->nractrs = 0;
Packit 577717
    cpu_control->nrictrs = 1;
Packit 577717
    cpu_control->pmc_map[0] = 0;
Packit 577717
Packit 577717
    /* INSTRUCTIONS_COMPLETED */
Packit 577717
    cpu_control->evntsel[0] = 0x02;
Packit 577717
Packit 577717
    /* overflow after 100 events */
Packit 577717
    cpu_control->ireset[0] = 0x80000000-100;
Packit 577717
Packit 577717
    /* not kernel mode, enable interrupts, enable PMC1 interrupts */
Packit 577717
    cpu_control->ppc.mmcr0 = (1<<(31-1)) | (1<<(31-5)) | (1<<(31-16));
Packit 577717
}