diff options
| author | Peter Zijlstra <a.p.zijlstra@chello.nl> | 2010-01-29 13:25:12 +0100 | 
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2010-02-04 09:59:50 +0100 | 
| commit | fce877e3a429940a986e085a41e8b57f2d922e36 (patch) | |
| tree | 5bdf6beeda1cfe774dc2a633454bd4d1546e1c08 /arch/x86/kernel/cpu/perf_event.c | |
| parent | 8c48e444191de0ff84e85d41180d7bc3e74f14ef (diff) | |
| download | olio-linux-3.10-fce877e3a429940a986e085a41e8b57f2d922e36.tar.xz olio-linux-3.10-fce877e3a429940a986e085a41e8b57f2d922e36.zip  | |
bitops: Ensure the compile time HWEIGHT is only used for such
Avoid accidental misuse by failing to compile things
Suggested-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
LKML-Reference: <new-submission>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/kernel/cpu/perf_event.c')
| -rw-r--r-- | arch/x86/kernel/cpu/perf_event.c | 10 | 
1 files changed, 7 insertions, 3 deletions
diff --git a/arch/x86/kernel/cpu/perf_event.c b/arch/x86/kernel/cpu/perf_event.c index 5b91992b6b2..96cfc1a4fe9 100644 --- a/arch/x86/kernel/cpu/perf_event.c +++ b/arch/x86/kernel/cpu/perf_event.c @@ -93,13 +93,16 @@ struct cpu_hw_events {  	struct perf_event	*event_list[X86_PMC_IDX_MAX]; /* in enabled order */  }; -#define EVENT_CONSTRAINT(c, n, m) {	\ +#define __EVENT_CONSTRAINT(c, n, m, w) {\  	{ .idxmsk64[0] = (n) },		\  	.code = (c),			\  	.cmask = (m),			\ -	.weight = HWEIGHT64((u64)(n)),	\ +	.weight = (w),			\  } +#define EVENT_CONSTRAINT(c, n, m)	\ +	__EVENT_CONSTRAINT(c, n, m, HWEIGHT(n)) +  #define INTEL_EVENT_CONSTRAINT(c, n)	\  	EVENT_CONSTRAINT(c, n, INTEL_ARCH_EVTSEL_MASK) @@ -2622,7 +2625,8 @@ void __init init_hw_perf_events(void)  	register_die_notifier(&perf_event_nmi_notifier);  	unconstrained = (struct event_constraint) -		EVENT_CONSTRAINT(0, (1ULL << x86_pmu.num_events) - 1, 0); +		__EVENT_CONSTRAINT(0, (1ULL << x86_pmu.num_events) - 1, +				   0, x86_pmu.num_events);  	pr_info("... version:                %d\n",     x86_pmu.version);  	pr_info("... bit width:              %d\n",     x86_pmu.event_bits);  |