blob: f02405e0c662dd707b5d03abf3716b178a70834e [file] [log] [blame]
/* Copyright (c) 2010, The Linux Foundation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 and
* only version 2 as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
*/
/*
perf.h
DESCRIPTION: Reads and writes the performance monitoring registers in the ARM
by using the MRC and MCR instructions.
*/
#ifndef PERF_H
#define PERF_H
extern unsigned long perf_get_cycles(void);
extern void perf_set_count1(unsigned long val);
extern void perf_set_count0(unsigned long val);
extern unsigned long perf_get_count1(void);
extern unsigned long perf_get_count0(void);
extern unsigned long perf_get_ctrl(void);
extern void perf_set_ctrl(void);
extern void perf_set_ctrl_with(unsigned long v);
extern void perf_enable_counting(void);
extern void perf_disable_counting(void);
extern void perf_set_divider(int d);
extern unsigned long perf_get_overflow(void);
extern void perf_clear_overflow(unsigned long bit);
extern void perf_export_event(unsigned long bit);
extern void perf_reset_counts(void);
extern int perf_set_event(unsigned long index, unsigned long val);
extern unsigned long perf_get_count(unsigned long index);
extern void perf_set_cycles(unsigned long c);
extern void pm_stop_all(void);
extern void l2_pm_stop_all(void);
extern void pm_start_all(void);
extern void l2_pm_start_all(void);
extern void pm_reset_all(void);
extern void l2_pm_reset_all(void);
extern void pm_set_event(unsigned long monitorIndex, unsigned long eventIndex);
extern void l2_pm_set_event(unsigned long monitorIndex,
unsigned long eventIndex);
extern unsigned long pm_get_count(unsigned long monitorIndex);
extern unsigned long l2_pm_get_count(unsigned long monitorIndex);
extern unsigned long pm_get_cycle_count(void);
extern unsigned long l2_pm_get_cycle_count(void);
extern char *pm_find_event_name(unsigned long index);
extern void pm_set_local_iu(unsigned long events);
extern void pm_set_local_xu(unsigned long events);
extern void pm_set_local_su(unsigned long events);
extern void pm_set_local_l2(unsigned long events);
extern void pm_set_local_vu(unsigned long events);
extern void pm_set_local_bu(unsigned long events);
extern void pm_set_local_cb(unsigned long events);
extern void pm_set_local_mp(unsigned long events);
extern void pm_set_local_sp(unsigned long events);
extern void pm_set_local_scu(unsigned long events);
extern void pm_initialize(void);
extern void pm_deinitialize(void);
extern void l2_pm_initialize(void);
extern void l2_pm_deinitialize(void);
extern void pm_free_irq(void);
extern void l2_pm_free_irq(void);
extern int per_process_perf_init(void);
extern void per_process_perf_exit(void);
int per_process_read(char *page, char **start, off_t off, int count,
int *eof, void *data);
int per_process_write_hex(struct file *file, const char *buff,
unsigned long cnt, void *data);
int per_process_read_decimal(char *page, char **start, off_t off, int count,
int *eof, void *data);
int per_process_write_dec(struct file *file, const char *buff,
unsigned long cnt, void *data);
void perfmon_register_callback(void);
void _per_process_switch(unsigned long oldPid, unsigned long newPid);
extern unsigned int pp_loaded;
extern atomic_t pm_op_lock;
#endif /*PERF_H*/