Statistiques
| Révision :

root / testing / timer / HPL_timer_cputime.c @ 1

Historique | Voir | Annoter | Télécharger (5,35 ko)

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
/* 
53
 * Purpose
54
 * =======
55
 *
56
 * HPL_timer_cputime returns the cpu time.  If HPL_USE_CLOCK is defined,
57
 * the  clock() function is used to return an approximation of processor
58
 * time used by the program.  The value returned is the CPU time used so
59
 * far as a clock_t;  to get the number of seconds used,  the result  is
60
 * divided by  CLOCKS_PER_SEC.  This function is part of the  ANSI/ISO C
61
 * standard library.  If  HPL_USE_TIMES is defined, the times() function
62
 * is used instead.  This  function  returns  the current process times.
63
 * times() returns the number of clock ticks that have elapsed since the
64
 * system has been up.  Otherwise and by default,  the  standard library
65
 * function getrusage() is used.
66
 *
67
 * ---------------------------------------------------------------------
68
 */ 
69

    
70
#if   defined( HPL_USE_CLOCK )
71
 
72
#include <time.h>
73

    
74
#ifdef STDC_HEADERS
75
double HPL_timer_cputime( void )
76
#else
77
double HPL_timer_cputime()
78
#endif
79
{
80
   static double              cps = CLOCKS_PER_SEC;
81
   double                     d;
82
   clock_t                    t1;
83
   static clock_t             t0 = 0;
84
 
85
   if( t0 == 0 ) t0 = clock();
86
   t1 = clock() - t0;
87
   d = (double)(t1) / cps;
88
   return( d );
89
} 
90

    
91
#elif defined( HPL_USE_TIMES )
92
 
93
#include <sys/times.h>
94
#include <unistd.h>
95

    
96
#ifdef STDC_HEADERS
97
double HPL_timer_cputime( void )
98
#else
99
double HPL_timer_cputime()
100
#endif
101
{
102
   clock_t                    t1;
103
   struct tms                 ts;
104
   static double              ClockTick = HPL_rzero;
105
 
106
   if( ClockTick == HPL_rzero ) ClockTick = (double)(sysconf(_SC_CLK_TCK));
107
   (void) times( &ts );
108
   return( (double)(ts.tms_utime) / ClockTick );
109
}
110
 
111
/* #elif defined( HPL_USE_GETRUSAGE )  */
112
#else
113
 
114
#include <sys/time.h>
115
#include <sys/resource.h>
116

    
117
#ifdef STDC_HEADERS
118
double HPL_timer_cputime( void )
119
#else
120
double HPL_timer_cputime()
121
#endif
122
{
123
   struct rusage              ruse;
124
   (void) getrusage( RUSAGE_SELF, &ruse );
125
   return( (double)( ruse.ru_utime.tv_sec  ) +
126
           ( (double)( ruse.ru_utime.tv_usec ) / 1000000.0 ) );
127
}
128

    
129
/* 
130
#else
131

132
#ifdef STDC_HEADERS
133
double HPL_timer_cputime( void )
134
#else
135
double HPL_timer_cputime()
136
#endif
137
{
138
   return( HPL_TIMER_ERROR );
139
}
140
*/
141

    
142
#endif
143
/*
144
 * End of HPL_timer_cputime
145
 */