diff options
author | Paul Mackerras <paulus@samba.org> | 2009-03-16 06:00:00 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-04-06 03:30:14 -0400 |
commit | b6c5a71da1477d261bc36254fe1f20d32b57598d (patch) | |
tree | 02815fa0a0016eacd6203b1f496109f07bbd7be5 /arch/powerpc/include/asm/hw_irq.h | |
parent | 7bb497bd885eedd0f56dfe3cc1b5ff20710d33b9 (diff) |
perf_counter: abstract wakeup flag setting in core to fix powerpc build
Impact: build fix for powerpc
Commit bd753921015e7905 ("perf_counter: software counter event
infrastructure") introduced a use of TIF_PERF_COUNTERS into the core
perfcounter code. This breaks the build on powerpc because we use
a flag in a per-cpu area to signal wakeups on powerpc rather than
a thread_info flag, because the thread_info flags have to be
manipulated with atomic operations and are thus slower than per-cpu
flags.
This fixes the by changing the core to use an abstracted
set_perf_counter_pending() function, which is defined on x86 to set
the TIF_PERF_COUNTERS flag and on powerpc to set the per-cpu flag
(paca->perf_counter_pending). It changes the previous powerpc
definition of set_perf_counter_pending to not take an argument and
adds a clear_perf_counter_pending, so as to simplify the definition
on x86.
On x86, set_perf_counter_pending() is defined as a macro. Defining
it as a static inline in arch/x86/include/asm/perf_counters.h causes
compile failures because <asm/perf_counters.h> gets included early in
<linux/sched.h>, and the definitions of set_tsk_thread_flag etc. are
therefore not available in <asm/perf_counters.h>. (On powerpc this
problem is avoided by defining set_perf_counter_pending etc. in
<asm/hw_irq.h>.)
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch/powerpc/include/asm/hw_irq.h')
-rw-r--r-- | arch/powerpc/include/asm/hw_irq.h | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/arch/powerpc/include/asm/hw_irq.h b/arch/powerpc/include/asm/hw_irq.h index b43076ff92c9..cb32d571c9c7 100644 --- a/arch/powerpc/include/asm/hw_irq.h +++ b/arch/powerpc/include/asm/hw_irq.h | |||
@@ -142,10 +142,17 @@ static inline unsigned long get_perf_counter_pending(void) | |||
142 | return x; | 142 | return x; |
143 | } | 143 | } |
144 | 144 | ||
145 | static inline void set_perf_counter_pending(int x) | 145 | static inline void set_perf_counter_pending(void) |
146 | { | 146 | { |
147 | asm volatile("stb %0,%1(13)" : : | 147 | asm volatile("stb %0,%1(13)" : : |
148 | "r" (x), | 148 | "r" (1), |
149 | "i" (offsetof(struct paca_struct, perf_counter_pending))); | ||
150 | } | ||
151 | |||
152 | static inline void clear_perf_counter_pending(void) | ||
153 | { | ||
154 | asm volatile("stb %0,%1(13)" : : | ||
155 | "r" (0), | ||
149 | "i" (offsetof(struct paca_struct, perf_counter_pending))); | 156 | "i" (offsetof(struct paca_struct, perf_counter_pending))); |
150 | } | 157 | } |
151 | 158 | ||
@@ -158,7 +165,8 @@ static inline unsigned long get_perf_counter_pending(void) | |||
158 | return 0; | 165 | return 0; |
159 | } | 166 | } |
160 | 167 | ||
161 | static inline void set_perf_counter_pending(int x) {} | 168 | static inline void set_perf_counter_pending(void) {} |
169 | static inline void clear_perf_counter_pending(void) {} | ||
162 | static inline void perf_counter_do_pending(void) {} | 170 | static inline void perf_counter_do_pending(void) {} |
163 | #endif /* CONFIG_PERF_COUNTERS */ | 171 | #endif /* CONFIG_PERF_COUNTERS */ |
164 | 172 | ||