Changes for Windows NT port
[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 #if defined(rs6000_ibm_aix4_1)
45 #define NOPS_4  asm("oril 0,0,0"); asm("oril 0,0,0"); asm("oril 0,0,0"); asm("oril 0,0,0")
46 #elif defined(i386_unknown_nt4_0)
47 #define NOPS_4 { __asm nop __asm nop __asm nop __asm nop }
48 #else
49 #define NOPS_4  asm("nop"); asm("nop"); asm("nop"); asm("nop")
50 #endif
51 #define NOPS_16 NOPS_4; NOPS_4; NOPS_4; NOPS_4
52
53 double timing_loop(const unsigned TRIES, const unsigned LOOP_LIMIT) {
54   const double MILLION = 1.0e6;
55   unsigned       i, j;
56   double         speed;
57   timer stopwatch;
58   double max_speed=0;
59
60   for (j=0; j<TRIES; j++) {
61     stopwatch.start();
62     for (i = 0; i < LOOP_LIMIT; i++) {
63       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
64       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
65       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
66       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
67     }
68     stopwatch.stop();
69     speed   = ((256*LOOP_LIMIT)/stopwatch.usecs())/MILLION;
70     stopwatch.clear();
71     if (speed > max_speed)
72       max_speed = speed;
73   }
74
75   for (j=0; j<TRIES; j++) {
76     stopwatch.start();
77     for (i = 0; i < LOOP_LIMIT; i++) {
78       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
79       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
80       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
81       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
82       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
83       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
84       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
85       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
86     }
87     stopwatch.stop();
88     speed   = ((512*LOOP_LIMIT)/stopwatch.usecs())/MILLION;
89     stopwatch.clear();
90     if (speed > max_speed)
91       max_speed = speed;
92   }
93
94   for (j=0; j<TRIES; j++) {
95     stopwatch.start();
96     for (i = 0; i < LOOP_LIMIT; i++) {
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       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
108       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
109       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
110       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
111       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
112       NOPS_16; NOPS_16; NOPS_16; NOPS_16;
113     }
114     stopwatch.stop();
115     speed   = ((1024*LOOP_LIMIT)/stopwatch.usecs())/MILLION;
116     stopwatch.clear();
117     if (speed > max_speed)
118       max_speed = speed;
119   }
120
121 #if defined(i386_unknown_solaris2_5) || defined(i386_unknown_nt4_0)
122   // the speed of the pentium is being overestimated by a factor of 2
123   max_speed /= 2;
124 #endif
125
126   return max_speed;
127 }