/benchmarks/randomaccess/hpcc/HPL_timer_cputime.c

https://bitbucket.org/vbui/cs533-project · C · 162 lines · 62 code · 18 blank · 82 comment · 4 complexity · 8ac8d00290997ef58b6eaf92b62f215f MD5 · raw file

  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_timer_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 HPL_STDC_HEADERS
  71. double HPL_timer_cputime( void )
  72. #else
  73. double HPL_timer_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 HPL_STDC_HEADERS
  89. double HPL_timer_cputime( void )
  90. #else
  91. double HPL_timer_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_GETPROCESSTIMES )
  102. #include <time.h>
  103. #include <windows.h>
  104. #ifdef HPL_STDC_HEADERS
  105. double HPL_timer_cputime( void )
  106. #else
  107. double HPL_timer_cputime()
  108. #endif
  109. {
  110. FILETIME creation, exit, kernel, user;
  111. GetProcessTimes( GetCurrentProcess(), &creation, &exit, &kernel, &user );
  112. return (*(LONGLONG*)&kernel+*(LONGLONG*)&user)*1e-7;
  113. }
  114. /* #elif defined( HPL_USE_GETRUSAGE ) */
  115. #else
  116. #include <sys/time.h>
  117. #include <sys/resource.h>
  118. #ifdef HPL_STDC_HEADERS
  119. double HPL_timer_cputime( void )
  120. #else
  121. double HPL_timer_cputime()
  122. #endif
  123. {
  124. struct rusage ruse;
  125. (void) getrusage( RUSAGE_SELF, &ruse );
  126. return( (double)( ruse.ru_utime.tv_sec ) +
  127. ( (double)( ruse.ru_utime.tv_usec ) / 1000000.0 ) );
  128. }
  129. /*
  130. #else
  131. #ifdef HPL_STDC_HEADERS
  132. double HPL_timer_cputime( void )
  133. #else
  134. double HPL_timer_cputime()
  135. #endif
  136. {
  137. return( HPL_TIMER_ERROR );
  138. }
  139. */
  140. #endif
  141. /*
  142. * End of HPL_timer_cputime
  143. */