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.

95 lines
2.3KB

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