arch_timer.c 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  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 <asm/delay.h>
  15. #include <asm/sched_clock.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_of_register(void)
  35. {
  36. int ret;
  37. ret = arch_timer_init();
  38. if (ret)
  39. return ret;
  40. arch_timer_delay_timer_register();
  41. return 0;
  42. }
  43. int __init arch_timer_sched_clock_init(void)
  44. {
  45. u32 arch_timer_rate = arch_timer_get_rate();
  46. if (arch_timer_rate == 0)
  47. return -ENXIO;
  48. /* Cache the sched_clock multiplier to save a divide in the hot path. */
  49. sched_clock_mult = NSEC_PER_SEC / arch_timer_rate;
  50. sched_clock_func = arch_timer_sched_clock;
  51. pr_info("sched_clock: ARM arch timer >56 bits at %ukHz, resolution %uns\n",
  52. arch_timer_rate / 1000, sched_clock_mult);
  53. return 0;
  54. }