diff options
Diffstat (limited to 'arch/x86')
-rw-r--r-- | arch/x86/oprofile/op_model_amd.c | 31 |
1 files changed, 16 insertions, 15 deletions
diff --git a/arch/x86/oprofile/op_model_amd.c b/arch/x86/oprofile/op_model_amd.c index 509513760a6e..fb67e1999d85 100644 --- a/arch/x86/oprofile/op_model_amd.c +++ b/arch/x86/oprofile/op_model_amd.c | |||
@@ -65,8 +65,10 @@ static unsigned long reset_value[NUM_COUNTERS]; | |||
65 | #define IBS_FETCH_BEGIN 3 | 65 | #define IBS_FETCH_BEGIN 3 |
66 | #define IBS_OP_BEGIN 4 | 66 | #define IBS_OP_BEGIN 4 |
67 | 67 | ||
68 | /* The function interface needs to be fixed, something like add | 68 | /* |
69 | data. Should then be added to linux/oprofile.h. */ | 69 | * The function interface needs to be fixed, something like add |
70 | * data. Should then be added to linux/oprofile.h. | ||
71 | */ | ||
70 | extern void | 72 | extern void |
71 | oprofile_add_ibs_sample(struct pt_regs *const regs, | 73 | oprofile_add_ibs_sample(struct pt_regs *const regs, |
72 | unsigned int *const ibs_sample, int ibs_code); | 74 | unsigned int *const ibs_sample, int ibs_code); |
@@ -106,7 +108,7 @@ struct ibs_op_sample { | |||
106 | 108 | ||
107 | /* | 109 | /* |
108 | * unitialize the APIC for the IBS interrupts if needed on AMD Family10h+ | 110 | * unitialize the APIC for the IBS interrupts if needed on AMD Family10h+ |
109 | */ | 111 | */ |
110 | static void clear_ibs_nmi(void); | 112 | static void clear_ibs_nmi(void); |
111 | 113 | ||
112 | static int ibs_allowed; /* AMD Family10h and later */ | 114 | static int ibs_allowed; /* AMD Family10h and later */ |
@@ -223,7 +225,7 @@ op_amd_handle_ibs(struct pt_regs * const regs, | |||
223 | (unsigned int *)&ibs_fetch, | 225 | (unsigned int *)&ibs_fetch, |
224 | IBS_FETCH_BEGIN); | 226 | IBS_FETCH_BEGIN); |
225 | 227 | ||
226 | /*reenable the IRQ */ | 228 | /* reenable the IRQ */ |
227 | rdmsr(MSR_AMD64_IBSFETCHCTL, low, high); | 229 | rdmsr(MSR_AMD64_IBSFETCHCTL, low, high); |
228 | high &= ~IBS_FETCH_HIGH_VALID_BIT; | 230 | high &= ~IBS_FETCH_HIGH_VALID_BIT; |
229 | high |= IBS_FETCH_HIGH_ENABLE; | 231 | high |= IBS_FETCH_HIGH_ENABLE; |
@@ -331,8 +333,10 @@ static void op_amd_stop(struct op_msrs const * const msrs) | |||
331 | unsigned int low, high; | 333 | unsigned int low, high; |
332 | int i; | 334 | int i; |
333 | 335 | ||
334 | /* Subtle: stop on all counters to avoid race with | 336 | /* |
335 | * setting our pm callback */ | 337 | * Subtle: stop on all counters to avoid race with setting our |
338 | * pm callback | ||
339 | */ | ||
336 | for (i = 0 ; i < NUM_COUNTERS ; ++i) { | 340 | for (i = 0 ; i < NUM_COUNTERS ; ++i) { |
337 | if (!reset_value[i]) | 341 | if (!reset_value[i]) |
338 | continue; | 342 | continue; |
@@ -343,13 +347,15 @@ static void op_amd_stop(struct op_msrs const * const msrs) | |||
343 | 347 | ||
344 | #ifdef CONFIG_OPROFILE_IBS | 348 | #ifdef CONFIG_OPROFILE_IBS |
345 | if (ibs_allowed && ibs_config.fetch_enabled) { | 349 | if (ibs_allowed && ibs_config.fetch_enabled) { |
346 | low = 0; /* clear max count and enable */ | 350 | /* clear max count and enable */ |
351 | low = 0; | ||
347 | high = 0; | 352 | high = 0; |
348 | wrmsr(MSR_AMD64_IBSFETCHCTL, low, high); | 353 | wrmsr(MSR_AMD64_IBSFETCHCTL, low, high); |
349 | } | 354 | } |
350 | 355 | ||
351 | if (ibs_allowed && ibs_config.op_enabled) { | 356 | if (ibs_allowed && ibs_config.op_enabled) { |
352 | low = 0; /* clear max count and enable */ | 357 | /* clear max count and enable */ |
358 | low = 0; | ||
353 | high = 0; | 359 | high = 0; |
354 | wrmsr(MSR_AMD64_IBSOPCTL, low, high); | 360 | wrmsr(MSR_AMD64_IBSOPCTL, low, high); |
355 | } | 361 | } |
@@ -443,10 +449,7 @@ static int pfm_amd64_setup_eilvt(void) | |||
443 | return 0; | 449 | return 0; |
444 | } | 450 | } |
445 | 451 | ||
446 | /* | 452 | /* initialize the APIC for the IBS interrupts if available */ |
447 | * initialize the APIC for the IBS interrupts | ||
448 | * if available (AMD Family10h rev B0 and later) | ||
449 | */ | ||
450 | static void setup_ibs(void) | 453 | static void setup_ibs(void) |
451 | { | 454 | { |
452 | ibs_allowed = boot_cpu_has(X86_FEATURE_IBS); | 455 | ibs_allowed = boot_cpu_has(X86_FEATURE_IBS); |
@@ -463,9 +466,7 @@ static void setup_ibs(void) | |||
463 | } | 466 | } |
464 | 467 | ||
465 | 468 | ||
466 | /* | 469 | /* uninitialize the APIC for the IBS interrupts if needed */ |
467 | * unitialize the APIC for the IBS interrupts if needed on AMD Family10h | ||
468 | * rev B0 and later */ | ||
469 | static void clear_ibs_nmi(void) | 470 | static void clear_ibs_nmi(void) |
470 | { | 471 | { |
471 | if (ibs_allowed) | 472 | if (ibs_allowed) |