HPL_ptimer_cputime.c 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. /*
  2. * -- High Performance Computing Linpack Benchmark (HPL)
  3. * HPL - 2.0 - September 10, 2008
  4. * Antoine P. Petitet
  5. * University of Tennessee, Knoxville
  6. * Innovative Computing Laboratory
  7. * (C) Copyright 2000-2008 All Rights Reserved
  8. *
  9. * -- Copyright notice and Licensing terms:
  10. *
  11. * Redistribution and use in source and binary forms, with or without
  12. * modification, are permitted provided that the following conditions
  13. * are met:
  14. *
  15. * 1. Redistributions of source code must retain the above copyright
  16. * notice, this list of conditions and the following disclaimer.
  17. *
  18. * 2. Redistributions in binary form must reproduce the above copyright
  19. * notice, this list of conditions, and the following disclaimer in the
  20. * documentation and/or other materials provided with the distribution.
  21. *
  22. * 3. All advertising materials mentioning features or use of this
  23. * software must display the following acknowledgement:
  24. * This product includes software developed at the University of
  25. * Tennessee, Knoxville, Innovative Computing Laboratory.
  26. *
  27. * 4. The name of the University, the name of the Laboratory, or the
  28. * names of its contributors may not be used to endorse or promote
  29. * products derived from this software without specific written
  30. * permission.
  31. *
  32. * -- Disclaimer:
  33. *
  34. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  35. * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  36. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  37. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE UNIVERSITY
  38. * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  39. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  40. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  41. * DATA OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  42. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  43. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  44. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  45. * ---------------------------------------------------------------------
  46. */
  47. /*
  48. * Include files
  49. */
  50. #include "hpl.h"
  51. /*
  52. * Purpose
  53. * =======
  54. *
  55. * HPL_ptimer_cputime returns the cpu time. If HPL_USE_CLOCK is defined,
  56. * the clock() function is used to return an approximation of processor
  57. * time used by the program. The value returned is the CPU time used so
  58. * far as a clock_t; to get the number of seconds used, the result is
  59. * divided by CLOCKS_PER_SEC. This function is part of the ANSI/ISO C
  60. * standard library. If HPL_USE_TIMES is defined, the times() function
  61. * is used instead. This function returns the current process times.
  62. * times() returns the number of clock ticks that have elapsed since the
  63. * system has been up. Otherwise and by default, the standard library
  64. * function getrusage() is used.
  65. *
  66. * ---------------------------------------------------------------------
  67. */
  68. #if defined( HPL_USE_CLOCK )
  69. #include <time.h>
  70. #ifdef STDC_HEADERS
  71. double HPL_ptimer_cputime( void )
  72. #else
  73. double HPL_ptimer_cputime()
  74. #endif
  75. {
  76. static double cps = CLOCKS_PER_SEC;
  77. double d;
  78. clock_t t1;
  79. static clock_t t0 = 0;
  80. if( t0 == 0 ) t0 = clock();
  81. t1 = clock() - t0;
  82. d = (double)(t1) / cps;
  83. return( d );
  84. }
  85. #elif defined( HPL_USE_TIMES )
  86. #include <sys/times.h>
  87. #include <unistd.h>
  88. #ifdef STDC_HEADERS
  89. double HPL_ptimer_cputime( void )
  90. #else
  91. double HPL_ptimer_cputime()
  92. #endif
  93. {
  94. clock_t t1;
  95. struct tms ts;
  96. static double ClockTick = HPL_rzero;
  97. if( ClockTick == HPL_rzero ) ClockTick = (double)(sysconf(_SC_CLK_TCK));
  98. (void) times( &ts );
  99. return( (double)(ts.tms_utime) / ClockTick );
  100. }
  101. /* #elif defined( HPL_USE_GETRUSAGE ) */
  102. #else
  103. #include <sys/time.h>
  104. #include <sys/resource.h>
  105. #ifdef STDC_HEADERS
  106. double HPL_ptimer_cputime( void )
  107. #else
  108. double HPL_ptimer_cputime()
  109. #endif
  110. {
  111. struct rusage ruse;
  112. (void) getrusage( RUSAGE_SELF, &ruse );
  113. return( (double)( ruse.ru_utime.tv_sec ) +
  114. ( (double)( ruse.ru_utime.tv_usec ) / 1000000.0 ) );
  115. }
  116. /*
  117. #else
  118. #ifdef STDC_HEADERS
  119. double HPL_ptimer_cputime( void )
  120. #else
  121. double HPL_ptimer_cputime()
  122. #endif
  123. {
  124. return( HPL_PTIMER_ERROR );
  125. }
  126. */
  127. #endif
  128. /*
  129. * End of HPL_ptimer_cputime
  130. */