perf_counter: frequency based adaptive irq_period, 32-bit fix
authorPeter Zijlstra <a.p.zijlstra@chello.nl>
Fri, 15 May 2009 13:37:47 +0000 (15:37 +0200)
committerIngo Molnar <mingo@elte.hu>
Fri, 15 May 2009 13:40:25 +0000 (15:40 +0200)
fix:

  kernel/built-in.o: In function `perf_counter_alloc':
  perf_counter.c:(.text+0x7ddc7): undefined reference to `__udivdi3'

[ Impact: build fix on 32-bit systems ]

Reported-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
LKML-Reference: <1242394667.6642.1887.camel@laptop>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
kernel/perf_counter.c

index 0ad1db4f3d65184fef3a557347276770952b1145..728a595399b00e7dc2218774b561aeb64dd31c0a 100644 (file)
@@ -2942,7 +2942,7 @@ perf_counter_alloc(struct perf_counter_hw_event *hw_event,
 
        hwc = &counter->hw;
        if (hw_event->freq && hw_event->irq_freq)
-               hwc->irq_period = TICK_NSEC / hw_event->irq_freq;
+               hwc->irq_period = div64_u64(TICK_NSEC, hw_event->irq_freq);
        else
                hwc->irq_period = hw_event->irq_period;