This patch implements IBS feature detection and initialzation. The code is shared between perf and oprofile. If IBS is available on the system for perf, a pmu is setup. Signed-off-by: Robert Richter <robert.richter@amd.com> Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl> Link: http://lkml.kernel.org/r/1316597423-25723-3-git-send-email-robert.richter@amd.com Signed-off-by: Ingo Molnar <mingo@elte.hu>
		
			
				
	
	
		
			90 lines
		
	
	
	
		
			2.5 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
	
		
			2.5 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
/**
 | 
						|
 * @file op_x86_model.h
 | 
						|
 * interface to x86 model-specific MSR operations
 | 
						|
 *
 | 
						|
 * @remark Copyright 2002 OProfile authors
 | 
						|
 * @remark Read the file COPYING
 | 
						|
 *
 | 
						|
 * @author Graydon Hoare
 | 
						|
 * @author Robert Richter <robert.richter@amd.com>
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef OP_X86_MODEL_H
 | 
						|
#define OP_X86_MODEL_H
 | 
						|
 | 
						|
#include <asm/types.h>
 | 
						|
#include <asm/perf_event.h>
 | 
						|
 | 
						|
struct op_msr {
 | 
						|
	unsigned long	addr;
 | 
						|
	u64		saved;
 | 
						|
};
 | 
						|
 | 
						|
struct op_msrs {
 | 
						|
	struct op_msr *counters;
 | 
						|
	struct op_msr *controls;
 | 
						|
	struct op_msr *multiplex;
 | 
						|
};
 | 
						|
 | 
						|
struct pt_regs;
 | 
						|
 | 
						|
struct oprofile_operations;
 | 
						|
 | 
						|
/* The model vtable abstracts the differences between
 | 
						|
 * various x86 CPU models' perfctr support.
 | 
						|
 */
 | 
						|
struct op_x86_model_spec {
 | 
						|
	unsigned int	num_counters;
 | 
						|
	unsigned int	num_controls;
 | 
						|
	unsigned int	num_virt_counters;
 | 
						|
	u64		reserved;
 | 
						|
	u16		event_mask;
 | 
						|
	int		(*init)(struct oprofile_operations *ops);
 | 
						|
	int		(*fill_in_addresses)(struct op_msrs * const msrs);
 | 
						|
	void		(*setup_ctrs)(struct op_x86_model_spec const *model,
 | 
						|
				      struct op_msrs const * const msrs);
 | 
						|
	int		(*check_ctrs)(struct pt_regs * const regs,
 | 
						|
				      struct op_msrs const * const msrs);
 | 
						|
	void		(*start)(struct op_msrs const * const msrs);
 | 
						|
	void		(*stop)(struct op_msrs const * const msrs);
 | 
						|
	void		(*shutdown)(struct op_msrs const * const msrs);
 | 
						|
#ifdef CONFIG_OPROFILE_EVENT_MULTIPLEX
 | 
						|
	void		(*switch_ctrl)(struct op_x86_model_spec const *model,
 | 
						|
				       struct op_msrs const * const msrs);
 | 
						|
#endif
 | 
						|
};
 | 
						|
 | 
						|
struct op_counter_config;
 | 
						|
 | 
						|
static inline void op_x86_warn_in_use(int counter)
 | 
						|
{
 | 
						|
	/*
 | 
						|
	 * The warning indicates an already running counter. If
 | 
						|
	 * oprofile doesn't collect data, then try using a different
 | 
						|
	 * performance counter on your platform to monitor the desired
 | 
						|
	 * event. Delete counter #%d from the desired event by editing
 | 
						|
	 * the /usr/share/oprofile/%s/<cpu>/events file. If the event
 | 
						|
	 * cannot be monitored by any other counter, contact your
 | 
						|
	 * hardware or BIOS vendor.
 | 
						|
	 */
 | 
						|
	pr_warning("oprofile: counter #%d on cpu #%d may already be used\n",
 | 
						|
		   counter, smp_processor_id());
 | 
						|
}
 | 
						|
 | 
						|
static inline void op_x86_warn_reserved(int counter)
 | 
						|
{
 | 
						|
	pr_warning("oprofile: counter #%d is already reserved\n", counter);
 | 
						|
}
 | 
						|
 | 
						|
extern u64 op_x86_get_ctrl(struct op_x86_model_spec const *model,
 | 
						|
			   struct op_counter_config *counter_config);
 | 
						|
extern int op_x86_phys_to_virt(int phys);
 | 
						|
extern int op_x86_virt_to_phys(int virt);
 | 
						|
 | 
						|
extern struct op_x86_model_spec op_ppro_spec;
 | 
						|
extern struct op_x86_model_spec op_p4_spec;
 | 
						|
extern struct op_x86_model_spec op_p4_ht2_spec;
 | 
						|
extern struct op_x86_model_spec op_amd_spec;
 | 
						|
extern struct op_x86_model_spec op_arch_perfmon_spec;
 | 
						|
 | 
						|
#endif /* OP_X86_MODEL_H */
 |