jack2 codebase
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

130 lines
3.1KB

  1. /*
  2. Copyright (C) 2001 Paul Davis
  3. Code derived from various headers from the Linux kernel
  4. This program is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation; either version 2 of the License, or
  7. (at your option) any later version.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with this program; if not, write to the Free Software
  14. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  15. $Id: cycles.h,v 1.4.2.1 2006/06/20 14:44:00 letz Exp $
  16. */
  17. #ifndef __jack_cycles_h__
  18. #define __jack_cycles_h__
  19. /*
  20. * Standard way to access the cycle counter on i586+ CPUs.
  21. * Currently only used on SMP.
  22. *
  23. * If you really have a SMP machine with i486 chips or older,
  24. * compile for that, and this will just always return zero.
  25. * That's ok, it just means that the nicer scheduling heuristics
  26. * won't work for you.
  27. *
  28. * We only use the low 32 bits, and we'd simply better make sure
  29. * that we reschedule before that wraps. Scheduling at least every
  30. * four billion cycles just basically sounds like a good idea,
  31. * regardless of how fast the machine is.
  32. */
  33. #ifdef __x86_64__
  34. typedef unsigned long cycles_t;
  35. extern cycles_t cacheflush_time;
  36. static inline unsigned long get_cycles(void)
  37. {
  38. unsigned int hi, lo;
  39. __asm__ __volatile__ ("rdtsc" : "=a"(lo), "=d"(hi));
  40. return (((unsigned long)hi)<<32) | ((unsigned long)lo);
  41. }
  42. #endif /* __x86_64__ */
  43. #ifdef __sparc_v9__
  44. /* rd is V9 only */
  45. static inline unsigned long long get_cycles(void)
  46. {
  47. unsigned long long res;
  48. __asm__ __volatile__("rd %%tick, %0" : "=r"(res));
  49. return res;
  50. }
  51. #endif /* __sparc_v9__ */
  52. #ifdef __PPC__
  53. /* PowerPC */
  54. #define CPU_FTR_601 0x00000100
  55. typedef unsigned long cycles_t;
  56. /* For the "cycle" counter we use the timebase lower half. */
  57. extern cycles_t cacheflush_time;
  58. static inline cycles_t get_cycles(void)
  59. {
  60. cycles_t ret = 0;
  61. __asm__ __volatile__(
  62. "98: mftb %0\n"
  63. "99:\n"
  64. ".section __ftr_fixup,\"a\"\n"
  65. " .long %1\n"
  66. " .long 0\n"
  67. " .long 98b\n"
  68. " .long 99b\n"
  69. ".previous"
  70. : "=r" (ret) : "i" (CPU_FTR_601));
  71. return ret;
  72. }
  73. #endif /* __PPC__ */
  74. #ifdef __i386__
  75. typedef unsigned long long cycles_t;
  76. extern cycles_t cacheflush_time;
  77. #define rdtscll(val) \
  78. __asm__ __volatile__("rdtsc" : "=A" (val))
  79. static inline cycles_t get_cycles (void)
  80. {
  81. unsigned long long ret;
  82. rdtscll(ret);
  83. return ret;
  84. }
  85. #endif /* __i386__ */
  86. /* everything else but x86, amd64, sparcv9 or ppc */
  87. #if !defined (__PPC__) && !defined (__x86_64__) && !defined (__i386__) && !defined (__sparc_v9__)
  88. #warning No suitable get_cycles() implementation. Returning 0 instead
  89. typedef unsigned long long cycles_t;
  90. static inline cycles_t get_cycles(void)
  91. {
  92. return 0;
  93. }
  94. #endif /* everything else but x86, amd64, sparcv9 or ppc */
  95. #endif /* __jack_cycles_h__ */