arch_timer.c 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. /*
  2. * linux/arch/arm/kernel/arch_timer.c
  3. *
  4. * Copyright (C) 2011 ARM Ltd.
  5. * All Rights Reserved
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License version 2 as
  9. * published by the Free Software Foundation.
  10. */
  11. #include <linux/init.h>
  12. #include <linux/types.h>
  13. #include <linux/errno.h>
  14. #include <linux/sched_clock.h>
  15. #include <asm/delay.h>
  16. #include <clocksource/arm_arch_timer.h>
  17. static unsigned long arch_timer_read_counter_long(void)
  18. {
  19. return arch_timer_read_counter();
  20. }
  21. static u32 sched_clock_mult __read_mostly;
  22. static unsigned long long notrace arch_timer_sched_clock(void)
  23. {
  24. return arch_timer_read_counter() * sched_clock_mult;
  25. }
  26. static struct delay_timer arch_delay_timer;
  27. static void __init arch_timer_delay_timer_register(void)
  28. {
  29. /* Use the architected timer for the delay loop. */
  30. arch_delay_timer.read_current_timer = arch_timer_read_counter_long;
  31. arch_delay_timer.freq = arch_timer_get_rate();
  32. register_current_timer_delay(&arch_delay_timer);
  33. }
  34. int __init arch_timer_arch_init(void)
  35. {
  36. u32 arch_timer_rate = arch_timer_get_rate();
  37. if (arch_timer_rate == 0)
  38. return -ENXIO;
  39. arch_timer_delay_timer_register();
  40. /* Cache the sched_clock multiplier to save a divide in the hot path. */
  41. sched_clock_mult = NSEC_PER_SEC / arch_timer_rate;
  42. sched_clock_func = arch_timer_sched_clock;
  43. pr_info("sched_clock: ARM arch timer >56 bits at %ukHz, resolution %uns\n",
  44. arch_timer_rate / 1000, sched_clock_mult);
  45. return 0;
  46. }