Removed warnings, changes for compiling with Visual C++ and xlc
[dyninst.git] / common / src / timing.C
1 /*
2  * Copyright (c) 1996 Barton P. Miller
3  * 
4  * We provide the Paradyn Parallel Performance Tools (below
5  * described as Paradyn") on an AS IS basis, and do not warrant its
6  * validity or performance.  We reserve the right to update, modify,
7  * or discontinue this software at any time.  We shall have no
8  * obligation to supply such updates or modifications or any other
9  * form of support to you.
10  * 
11  * This license is for research uses.  For such uses, there is no
12  * charge. We define "research use" to mean you may freely use it
13  * inside your organization for whatever purposes you see fit. But you
14  * may not re-distribute Paradyn or parts of Paradyn, in any form
15  * source or binary (including derivatives), electronic or otherwise,
16  * to any other organization or entity without our permission.
17  * 
18  * (for other uses, please contact us at paradyn@cs.wisc.edu)
19  * 
20  * All warranties, including without limitation, any warranty of
21  * merchantability or fitness for a particular purpose, are hereby
22  * excluded.
23  * 
24  * By your use of Paradyn, you understand and agree that we (or any
25  * other person or entity with proprietary rights in Paradyn) are
26  * under no obligation to provide either maintenance services,
27  * update services, notices of latent defects, or correction of
28  * defects for Paradyn.
29  * 
30  * Even if advised of the possibility of such damages, under no
31  * circumstances shall we (or any other person or entity with
32  * proprietary rights in the software licensed hereunder) be liable
33  * to you or any third party for direct, indirect, or consequential
34  * damages of any character regardless of type of action, including,
35  * without limitation, loss of profits, loss of use, loss of good
36  * will, or computer failure or malfunction.  You agree to indemnify
37  * us (and any other person or entity with proprietary rights in the
38  * software licensed hereunder) for any and all liability it may
39  * incur to third parties resulting from your use of Paradyn.
40  */
41
42
43 #include "util/h/Timer.h"
44 #define NOPS_4  asm("nop"); asm("nop"); asm("nop"); asm("nop")
45 #define NOPS_16 NOPS_4; NOPS_4; NOPS_4; NOPS_4
46
47 double timing_loop(const unsigned TRIES, const unsigned LOOP_LIMIT) {
48   const double MILLION = 1.0e6;
49   unsigned       i, j;
50   double         speed;
51   timer stopwatch;
52   double max_speed=0;
53
54   for (j=0; j<TRIES; j++) {
55     stopwatch.start();
56     for (i = 0; i < LOOP_LIMIT; i++) {
57       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
58       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
59       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
60       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
61     }
62     stopwatch.stop();
63     speed   = ((256*LOOP_LIMIT)/stopwatch.usecs())/MILLION;
64     stopwatch.clear();
65     if (speed > max_speed)
66       max_speed = speed;
67   }
68
69   for (j=0; j<TRIES; j++) {
70     stopwatch.start();
71     for (i = 0; i < LOOP_LIMIT; i++) {
72       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
73       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
74       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
75       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
76       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
77       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
78       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
79       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
80     }
81     stopwatch.stop();
82     speed   = ((512*LOOP_LIMIT)/stopwatch.usecs())/MILLION;
83     stopwatch.clear();
84     if (speed > max_speed)
85       max_speed = speed;
86   }
87
88   for (j=0; j<TRIES; j++) {
89     stopwatch.start();
90     for (i = 0; i < LOOP_LIMIT; i++) {
91       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
92       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
93       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
94       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
95       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
96       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
97       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
98       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
99       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
100       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
101       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
102       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
103       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
104       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
105       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
106       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
107     }
108     stopwatch.stop();
109     speed   = ((1024*LOOP_LIMIT)/stopwatch.usecs())/MILLION;
110     stopwatch.clear();
111     if (speed > max_speed)
112       max_speed = speed;
113   }
114
115 #ifdef i386_unknown_solaris2_5
116   // the speed of the pentium is being overestimated by a factor of 2
117   max_speed /= 2;
118 #endif
119
120   return max_speed;
121 }