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.

109 lines
2.5KB

  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 __linux__
  34. #ifdef __x86_64__
  35. typedef unsigned long cycles_t;
  36. extern cycles_t cacheflush_time;
  37. static inline unsigned long get_cycles(void)
  38. {
  39. unsigned int hi, lo;
  40. __asm__ __volatile__ ("rdtsc" : "=a"(lo), "=d"(hi));
  41. return (((unsigned long)hi)<<32) | ((unsigned long)lo);
  42. }
  43. #endif
  44. #ifdef __PPC__
  45. /* PowerPC */
  46. #define CPU_FTR_601 0x00000100
  47. typedef unsigned long cycles_t;
  48. /* For the "cycle" counter we use the timebase lower half. */
  49. extern cycles_t cacheflush_time;
  50. static inline cycles_t get_cycles(void)
  51. {
  52. cycles_t ret = 0;
  53. __asm__ __volatile__(
  54. "98: mftb %0\n"
  55. "99:\n"
  56. ".section __ftr_fixup,\"a\"\n"
  57. " .long %1\n"
  58. " .long 0\n"
  59. " .long 98b\n"
  60. " .long 99b\n"
  61. ".previous"
  62. : "=r" (ret) : "i" (CPU_FTR_601));
  63. return ret;
  64. }
  65. #endif
  66. #ifdef __i386__
  67. typedef unsigned long long cycles_t;
  68. extern cycles_t cacheflush_time;
  69. #define rdtscll(val) \
  70. __asm__ __volatile__("rdtsc" : "=A" (val))
  71. static inline cycles_t get_cycles (void)
  72. {
  73. unsigned long long ret;
  74. rdtscll(ret);
  75. return ret;
  76. }
  77. #endif
  78. #endif
  79. #endif /* __jack_cycles_h__ */