summaryrefslogtreecommitdiffstats
path: root/lib/libpmc
diff options
context:
space:
mode:
authorjkoshy <jkoshy@FreeBSD.org>2005-06-10 03:45:04 +0000
committerjkoshy <jkoshy@FreeBSD.org>2005-06-10 03:45:04 +0000
commit7e72895a6534d348287f191f817595a9e6260bd5 (patch)
tree27255c53acd2fd9e1ce29ac04abff32621f85f15 /lib/libpmc
parenta3df0b223791d56229d079433841873c5d4353aa (diff)
downloadFreeBSD-src-7e72895a6534d348287f191f817595a9e6260bd5.zip
FreeBSD-src-7e72895a6534d348287f191f817595a9e6260bd5.tar.gz
Fix tinderbox breakage.
Diffstat (limited to 'lib/libpmc')
-rw-r--r--lib/libpmc/libpmc.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/lib/libpmc/libpmc.c b/lib/libpmc/libpmc.c
index 09cc2b4..3a42e07 100644
--- a/lib/libpmc/libpmc.c
+++ b/lib/libpmc/libpmc.c
@@ -139,7 +139,8 @@ static const char * pmc_state_names[] = {
static int pmc_syscall = -1; /* filled in by pmc_init() */
-struct pmc_op_getcpuinfo cpu_info; /* filled in by pmc_init() */
+static struct pmc_cpuinfo cpu_info; /* filled in by pmc_init() */
+
/* Architecture dependent event parsing */
static int (*pmc_mdep_allocate_pmc)(enum pmc_event _pe, char *_ctrspec,
@@ -1752,8 +1753,7 @@ pmc_cpuinfo(const struct pmc_cpuinfo **pci)
return -1;
}
- /* kernel<->library, library<->userland interfaces are identical */
- *pci = (struct pmc_cpuinfo *) &cpu_info;
+ *pci = &cpu_info;
return 0;
}
@@ -1893,8 +1893,10 @@ int
pmc_init(void)
{
int error, pmc_mod_id;
+ unsigned int n;
uint32_t abi_version;
struct module_stat pmc_modstat;
+ struct pmc_op_getcpuinfo op_cpu_info;
if (pmc_syscall != -1) /* already inited */
return 0;
@@ -1920,9 +1922,16 @@ pmc_init(void)
return (pmc_syscall = -1);
}
- if (PMC_CALL(GETCPUINFO, &cpu_info) < 0)
+ if (PMC_CALL(GETCPUINFO, &op_cpu_info) < 0)
return (pmc_syscall = -1);
+ cpu_info.pm_cputype = op_cpu_info.pm_cputype;
+ cpu_info.pm_ncpu = op_cpu_info.pm_ncpu;
+ cpu_info.pm_npmc = op_cpu_info.pm_npmc;
+ cpu_info.pm_nclass = op_cpu_info.pm_nclass;
+ for (n = 0; n < cpu_info.pm_nclass; n++)
+ cpu_info.pm_classes[n] = op_cpu_info.pm_classes[n];
+
/* set parser pointer */
switch (cpu_info.pm_cputype) {
#if defined(__i386__)
OpenPOWER on IntegriCloud