Update copyright to LGPL on all files
[dyninst.git] / dyninstAPI / src / inst-sunos.C
1 /*
2  * Copyright (c) 1996-2009 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  * By your use of Paradyn, you understand and agree that we (or any
12  * other person or entity with proprietary rights in Paradyn) are
13  * under no obligation to provide either maintenance services,
14  * update services, notices of latent defects, or correction of
15  * defects for Paradyn.
16  * 
17  * This library is free software; you can redistribute it and/or
18  * modify it under the terms of the GNU Lesser General Public
19  * License as published by the Free Software Foundation; either
20  * version 2.1 of the License, or (at your option) any later version.
21  * 
22  * This library is distributed in the hope that it will be useful,
23  * but WITHOUT ANY WARRANTY; without even the implied warranty of
24  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
25  * Lesser General Public License for more details.
26  * 
27  * You should have received a copy of the GNU Lesser General Public
28  * License along with this library; if not, write to the Free Software
29  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
30  */
31
32 // $Id: inst-sunos.C,v 1.60 2008/06/19 22:13:42 jaw Exp $
33
34 #ifndef NULL
35 #define NULL 0
36 #endif
37
38 #include "dyninstAPI/src/os.h"
39 #include "dyninstAPI/src/dyninst.h"
40 #include "dyninstAPI/src/symtab.h"
41 #include "dyninstAPI/src/process.h"
42 #include "dyninstAPI/src/inst.h"
43 #include "dyninstAPI/src/instP.h"
44 #include "dyninstAPI/src/ast.h"
45 #include "dyninstAPI/src/util.h"
46 #include "common/h/stats.h"
47
48 //
49 // All costs are based on Measurements on a SPARC station 10/40.
50 //
51 void initPrimitiveCost()
52 {
53     /* Need to add code here to collect values for other machines */
54
55     // this doesn't really take any time
56     primitiveCosts["DYNINSTbreakPoint"] = 1;
57
58     // this happens before we start keeping time.
59     primitiveCosts["DYNINSTinit"] = 1;
60
61     primitiveCosts["DYNINSTprintCost"] = 1;
62
63     //
64     // I can't find DYNINSTincrementCounter or DYNINSTdecrementCounter
65     // I think they are not being used anywhere - naim
66     //
67     // isthmus acutal numbers from 7/3/94 -- jkh
68     // 240 ns
69     primitiveCosts["DYNINSTincrementCounter"] = 16;
70     // 240 ns
71     primitiveCosts["DYNINSTdecrementCounter"] = 16;
72
73 #if defined(i386_unknown_solaris2_5)
74     logLine("Solaris/x86 platform\n");
75     // Updated calculation of the cost for the following procedures.
76     // cost in cycles
77
78     // Values (in cycles) benchmarked on a Pentium II 400MHz
79     // Level 2 - Software Level
80     primitiveCosts["DYNINSTstartWallTimer"] = 1304;
81     primitiveCosts["DYNINSTstopWallTimer"] = 1321;
82     primitiveCosts["DYNINSTstartProcessTimer"] = 1324;
83     primitiveCosts["DYNINSTstopProcessTimer"] = 1350;
84
85     // These happen async of the rest of the system.
86     primitiveCosts["DYNINSTalarmExpire"] = 3724;
87     primitiveCosts["DYNINSTsampleValues"] = 13;
88     primitiveCosts["DYNINSTreportTimer"] = 1380;
89     primitiveCosts["DYNINSTreportCounter"] = 1270;
90     primitiveCosts["DYNINSTreportCost"] = 1350;
91     primitiveCosts["DYNINSTreportNewTags"] = 837;
92
93 #elif defined(sparc_sun_solaris2_4)
94     logLine("Solaris platform\n");
95
96     // Values (in cycles) benchmarked on an UltraSparcIIi 440MHz
97     // Level 2 - Software Level
98     primitiveCosts["DYNINSTstartWallTimer"] = 248;
99     primitiveCosts["DYNINSTstopWallTimer"] = 277;
100     primitiveCosts["DYNINSTstartProcessTimer"] = 105;
101     primitiveCosts["DYNINSTstopProcessTimer"] = 104;
102
103     // These happen async of the rest of the system.
104     // 148 usecs * 37.04 Mhz
105     primitiveCosts["DYNINSTalarmExpire"] = 5513;
106     // 0.81 usecs * 37.04 Mhz
107     primitiveCosts["DYNINSTsampleValues"] = 30;
108     // 23.08 usecs * 37.04 Mhz
109     primitiveCosts["DYNINSTreportTimer"] = 855;
110     // 7.85 usecs * 37.04 Mhz
111     primitiveCosts["DYNINSTreportCounter"] = 290;
112     // 4.22 usecs * 37.04 Mhz
113     primitiveCosts["DYNINSTreportCost"] = 156;
114     // 1.03 usecs * 37.04 Mhz
115     primitiveCosts["DYNINSTreportNewTags"] = 38;
116 #endif
117 }
118