op_impl.h

来自「Linux Kernel 2.6.9 for OMAP1710」· C头文件 代码 · 共 146 行

H
146
字号
/* * Copyright (C) 2004 Anton Blanchard <anton@au.ibm.com>, IBM * * Based on alpha version. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version * 2 of the License, or (at your option) any later version. */#ifndef OP_IMPL_H#define OP_IMPL_H 1#define OP_MAX_COUNTER 8#define MSR_PMM		(1UL << (63 - 61))/* freeze counters. set to 1 on a perfmon exception */#define MMCR0_FC	(1UL << (31 - 0))/* freeze in supervisor state */#define MMCR0_KERNEL_DISABLE (1UL << (31 - 1))/* freeze in problem state */#define MMCR0_PROBLEM_DISABLE (1UL << (31 - 2))/* freeze counters while MSR mark = 1 */#define MMCR0_FCM1	(1UL << (31 - 3))/* performance monitor exception enable */#define MMCR0_PMXE	(1UL << (31 - 5))/* freeze counters on enabled condition or event */#define MMCR0_FCECE	(1UL << (31 - 6))/* PMC1 count enable*/#define MMCR0_PMC1INTCONTROL	(1UL << (31 - 16))/* PMCn count enable*/#define MMCR0_PMCNINTCONTROL	(1UL << (31 - 17))/* performance monitor alert has occurred, set to 0 after handling exception */#define MMCR0_PMAO	(1UL << (31 - 24))/* state of MSR HV when SIAR set */#define MMCRA_SIHV	(1UL << (63 - 35))/* state of MSR PR when SIAR set */#define MMCRA_SIPR	(1UL << (63 - 36))/* enable sampling */#define MMCRA_SAMPLE_ENABLE	(1UL << (63 - 63))/* Per-counter configuration as set via oprofilefs.  */struct op_counter_config {	unsigned long valid;	unsigned long enabled;	unsigned long event;	unsigned long count;	unsigned long kernel;	/* We dont support per counter user/kernel selection */	unsigned long user;	unsigned long unit_mask;};/* System-wide configuration as set via oprofilefs.  */struct op_system_config {	unsigned long mmcr0;	unsigned long mmcr1;	unsigned long mmcra;	unsigned long enable_kernel;	unsigned long enable_user;};/* Per-arch configuration */struct op_ppc64_model {	void (*reg_setup) (struct op_counter_config *,			   struct op_system_config *,			   int num_counters);	void (*cpu_setup) (void *);	void (*start) (struct op_counter_config *);	void (*stop) (void);	void (*handle_interrupt) (struct pt_regs *,				  struct op_counter_config *);	int num_counters;};static inline unsigned int ctr_read(unsigned int i){	switch(i) {	case 0:		return mfspr(SPRN_PMC1);	case 1:		return mfspr(SPRN_PMC2);	case 2:		return mfspr(SPRN_PMC3);	case 3:		return mfspr(SPRN_PMC4);	case 4:		return mfspr(SPRN_PMC5);	case 5:		return mfspr(SPRN_PMC6);	case 6:		return mfspr(SPRN_PMC7);	case 7:		return mfspr(SPRN_PMC8);	default:		return 0;	}}static inline void ctr_write(unsigned int i, unsigned int val){	switch(i) {	case 0:		mtspr(SPRN_PMC1, val);		break;	case 1:		mtspr(SPRN_PMC2, val);		break;	case 2:		mtspr(SPRN_PMC3, val);		break;	case 3:		mtspr(SPRN_PMC4, val);		break;	case 4:		mtspr(SPRN_PMC5, val);		break;	case 5:		mtspr(SPRN_PMC6, val);		break;	case 6:		mtspr(SPRN_PMC7, val);		break;	case 7:		mtspr(SPRN_PMC8, val);		break;	default:		break;	}}#endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?