Mercurial > hg > truffle
annotate graal/com.oracle.max.graal.hotspot/src/com/oracle/graal/hotspot/ri/HotSpotProfilingInfo.java @ 5060:4ed4295ce15f
Update import statements.
author | Thomas Wuerthinger <thomas.wuerthinger@oracle.com> |
---|---|
date | Thu, 08 Mar 2012 19:11:12 +0100 |
parents | ed559a528128 |
children |
rev | line source |
---|---|
4446 | 1 /* |
2 * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. | |
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. | |
4 * | |
5 * This code is free software; you can redistribute it and/or modify it | |
6 * under the terms of the GNU General Public License version 2 only, as | |
7 * published by the Free Software Foundation. | |
8 * | |
9 * This code is distributed in the hope that it will be useful, but WITHOUT | |
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
12 * version 2 for more details (a copy is included in the LICENSE file that | |
13 * accompanied this code). | |
14 * | |
15 * You should have received a copy of the GNU General Public License version | |
16 * 2 along with this work; if not, write to the Free Software Foundation, | |
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | |
18 * | |
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA | |
20 * or visit www.oracle.com if you need additional information or have any | |
21 * questions. | |
22 */ | |
5060
4ed4295ce15f
Update import statements.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
5059
diff
changeset
|
23 package com.oracle.graal.hotspot.ri; |
4446 | 24 |
25 import com.oracle.max.cri.ri.*; | |
5060
4ed4295ce15f
Update import statements.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
5059
diff
changeset
|
26 import com.oracle.graal.debug.*; |
4ed4295ce15f
Update import statements.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
5059
diff
changeset
|
27 import com.oracle.graal.hotspot.*; |
4ed4295ce15f
Update import statements.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
5059
diff
changeset
|
28 import com.oracle.graal.hotspot.Compiler; |
4446 | 29 |
30 | |
31 public final class HotSpotProfilingInfo extends CompilerObject implements RiProfilingInfo { | |
32 | |
33 /** | |
34 * | |
35 */ | |
36 private static final long serialVersionUID = -8307682725047864875L; | |
4561
35ca3ade314d
enabled nmethod statistics for product build
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4553
diff
changeset
|
37 private static final DebugMetric metricInsufficentSpace = Debug.metric("InsufficientSpaceForProfilingData"); |
4446 | 38 |
39 private int position; | |
40 private int hintPosition; | |
41 private int hintBCI; | |
42 private HotSpotMethodDataAccessor dataAccessor; | |
43 private HotSpotMethodData methodData; | |
44 | |
45 public HotSpotProfilingInfo(Compiler compiler, HotSpotMethodData methodData) { | |
46 super(compiler); | |
47 this.methodData = methodData; | |
48 hintPosition = 0; | |
49 hintBCI = -1; | |
50 } | |
51 | |
52 @Override | |
53 public RiTypeProfile getTypeProfile(int bci) { | |
4450
d585b608bd78
more efficient methodData access
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4447
diff
changeset
|
54 findBCI(bci, false); |
4446 | 55 return dataAccessor.getTypeProfile(methodData, position); |
56 } | |
57 | |
58 @Override | |
59 public double getBranchTakenProbability(int bci) { | |
4450
d585b608bd78
more efficient methodData access
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4447
diff
changeset
|
60 findBCI(bci, false); |
4446 | 61 return dataAccessor.getBranchTakenProbability(methodData, position); |
62 } | |
63 | |
64 @Override | |
65 public double[] getSwitchProbabilities(int bci) { | |
4450
d585b608bd78
more efficient methodData access
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4447
diff
changeset
|
66 findBCI(bci, false); |
4446 | 67 return dataAccessor.getSwitchProbabilities(methodData, position); |
68 } | |
69 | |
70 @Override | |
4527
a0cca63cd366
fixed exceptionSeen profiling information
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4476
diff
changeset
|
71 public RiExceptionSeen getExceptionSeen(int bci) { |
4450
d585b608bd78
more efficient methodData access
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4447
diff
changeset
|
72 findBCI(bci, true); |
4457
5acf4a974e4a
fixed framestate for inlining multiple methods
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4450
diff
changeset
|
73 return dataAccessor.getExceptionSeen(methodData, position); |
4446 | 74 } |
75 | |
76 @Override | |
77 public int getExecutionCount(int bci) { | |
4450
d585b608bd78
more efficient methodData access
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4447
diff
changeset
|
78 findBCI(bci, false); |
4446 | 79 return dataAccessor.getExecutionCount(methodData, position); |
80 } | |
81 | |
4450
d585b608bd78
more efficient methodData access
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4447
diff
changeset
|
82 private void findBCI(int targetBCI, boolean searchExtraData) { |
4446 | 83 assert targetBCI >= 0 : "invalid BCI"; |
84 | |
85 if (methodData.hasNormalData()) { | |
86 int currentPosition = targetBCI < hintBCI ? 0 : hintPosition; | |
87 HotSpotMethodDataAccessor currentAccessor; | |
88 while ((currentAccessor = methodData.getNormalData(currentPosition)) != null) { | |
89 int currentBCI = currentAccessor.getBCI(methodData, currentPosition); | |
90 if (currentBCI == targetBCI) { | |
91 normalDataFound(currentAccessor, currentPosition, currentBCI); | |
92 return; | |
93 } else if (currentBCI > targetBCI) { | |
94 break; | |
95 } | |
96 currentPosition = currentPosition + currentAccessor.getSize(methodData, currentPosition); | |
97 } | |
98 } | |
99 | |
4527
a0cca63cd366
fixed exceptionSeen profiling information
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4476
diff
changeset
|
100 boolean exceptionPossiblyNotRecorded = false; |
4450
d585b608bd78
more efficient methodData access
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4447
diff
changeset
|
101 if (searchExtraData && methodData.hasExtraData()) { |
4476
00efac2934d3
methodData bugfix
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4457
diff
changeset
|
102 int currentPosition = methodData.getExtraDataBeginOffset(); |
4446 | 103 HotSpotMethodDataAccessor currentAccessor; |
104 while ((currentAccessor = methodData.getExtraData(currentPosition)) != null) { | |
105 int currentBCI = currentAccessor.getBCI(methodData, currentPosition); | |
106 if (currentBCI == targetBCI) { | |
107 extraDataFound(currentAccessor, currentPosition); | |
108 return; | |
109 } | |
110 currentPosition = currentPosition + currentAccessor.getSize(methodData, currentPosition); | |
111 } | |
4527
a0cca63cd366
fixed exceptionSeen profiling information
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4476
diff
changeset
|
112 |
4553
7d0d849abf80
added option to summarize debug values
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4527
diff
changeset
|
113 if (!methodData.isWithin(currentPosition)) { |
7d0d849abf80
added option to summarize debug values
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4527
diff
changeset
|
114 exceptionPossiblyNotRecorded = true; |
4561
35ca3ade314d
enabled nmethod statistics for product build
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4553
diff
changeset
|
115 metricInsufficentSpace.increment(); |
4553
7d0d849abf80
added option to summarize debug values
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4527
diff
changeset
|
116 } |
4446 | 117 } |
118 | |
4527
a0cca63cd366
fixed exceptionSeen profiling information
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4476
diff
changeset
|
119 noDataFound(exceptionPossiblyNotRecorded); |
4446 | 120 } |
121 | |
122 private void normalDataFound(HotSpotMethodDataAccessor data, int pos, int bci) { | |
123 setCurrentData(data, pos); | |
124 this.hintPosition = position; | |
125 this.hintBCI = bci; | |
126 } | |
127 | |
128 private void extraDataFound(HotSpotMethodDataAccessor data, int pos) { | |
129 setCurrentData(data, pos); | |
130 } | |
131 | |
4564
8fc6920e064b
avoid recursive inlining, escape analysis does no longer restart inlining with level 0, bugfixes
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4561
diff
changeset
|
132 private void noDataFound(boolean exceptionPossiblyNotRecorded) { |
8fc6920e064b
avoid recursive inlining, escape analysis does no longer restart inlining with level 0, bugfixes
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4561
diff
changeset
|
133 HotSpotMethodDataAccessor accessor = HotSpotMethodData.getNoDataAccessor(exceptionPossiblyNotRecorded); |
4527
a0cca63cd366
fixed exceptionSeen profiling information
Christian Haeubl <christian.haeubl@oracle.com>
parents:
4476
diff
changeset
|
134 setCurrentData(accessor, -1); |
4446 | 135 } |
136 | |
137 private void setCurrentData(HotSpotMethodDataAccessor dataAccessor, int position) { | |
138 this.dataAccessor = dataAccessor; | |
139 this.position = position; | |
140 } | |
141 } |