aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2008-09-29 11:31:41 -0400
committerThomas Gleixner <tglx@linutronix.de>2008-10-20 05:51:30 -0400
commitc5b77a3d3a716a5c61a1999d7f2a78e9c39fd1b0 (patch)
tree14e0c3d2c504fded2dd208c774a38c183f496183 /kernel
parente67ef25a35b949561a9bd77693523ec94ab4a278 (diff)
timer_list: print cpu number of clockevents device
The per cpu clock events device output of timer_list lacks an association of the device to the cpu which is annoying when looking at the output of /proc/timer_list from a 128 way system. Add the CPU number info and mark the broadcast device in the device list printout. Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/time/timer_list.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/kernel/time/timer_list.c b/kernel/time/timer_list.c
index ec9ea6cadd85..5479c6e7a023 100644
--- a/kernel/time/timer_list.c
+++ b/kernel/time/timer_list.c
@@ -184,12 +184,16 @@ static void print_cpu(struct seq_file *m, int cpu, u64 now)
184 184
185#ifdef CONFIG_GENERIC_CLOCKEVENTS 185#ifdef CONFIG_GENERIC_CLOCKEVENTS
186static void 186static void
187print_tickdevice(struct seq_file *m, struct tick_device *td) 187print_tickdevice(struct seq_file *m, struct tick_device *td, int cpu)
188{ 188{
189 struct clock_event_device *dev = td->evtdev; 189 struct clock_event_device *dev = td->evtdev;
190 190
191 SEQ_printf(m, "\n"); 191 SEQ_printf(m, "\n");
192 SEQ_printf(m, "Tick Device: mode: %d\n", td->mode); 192 SEQ_printf(m, "Tick Device: mode: %d\n", td->mode);
193 if (cpu < 0)
194 SEQ_printf(m, "Broadcast device\n");
195 else
196 SEQ_printf(m, "Per CPU device: %d\n", cpu);
193 197
194 SEQ_printf(m, "Clock Event Device: "); 198 SEQ_printf(m, "Clock Event Device: ");
195 if (!dev) { 199 if (!dev) {
@@ -223,7 +227,7 @@ static void timer_list_show_tickdevices(struct seq_file *m)
223 int cpu; 227 int cpu;
224 228
225#ifdef CONFIG_GENERIC_CLOCKEVENTS_BROADCAST 229#ifdef CONFIG_GENERIC_CLOCKEVENTS_BROADCAST
226 print_tickdevice(m, tick_get_broadcast_device()); 230 print_tickdevice(m, tick_get_broadcast_device(), -1);
227 SEQ_printf(m, "tick_broadcast_mask: %08lx\n", 231 SEQ_printf(m, "tick_broadcast_mask: %08lx\n",
228 tick_get_broadcast_mask()->bits[0]); 232 tick_get_broadcast_mask()->bits[0]);
229#ifdef CONFIG_TICK_ONESHOT 233#ifdef CONFIG_TICK_ONESHOT
@@ -233,7 +237,7 @@ static void timer_list_show_tickdevices(struct seq_file *m)
233 SEQ_printf(m, "\n"); 237 SEQ_printf(m, "\n");
234#endif 238#endif
235 for_each_online_cpu(cpu) 239 for_each_online_cpu(cpu)
236 print_tickdevice(m, tick_get_device(cpu)); 240 print_tickdevice(m, tick_get_device(cpu), cpu);
237 SEQ_printf(m, "\n"); 241 SEQ_printf(m, "\n");
238} 242}
239#else 243#else