Mercurial > hg > truffle
annotate test/compiler/whitebox/IsMethodCompilableTest.java @ 18711:88c280297bd2
put GeneratedSourcesSha1 into com.oracle.graal.hotspot.sourcegen package
author | Doug Simon <doug.simon@oracle.com> |
---|---|
date | Thu, 18 Dec 2014 13:10:23 +1000 |
parents | 52b4284cb496 |
children | 7848fc12602b |
rev | line source |
---|---|
8051 | 1 /* |
17711
d559dbbded7a
8027124: [TESTBUG] NonTieredLevelsTest: java.lang.RuntimeException: private TestCase$Helper(java.lang.Object) must be osr_compiled
iignatyev
parents:
14203
diff
changeset
|
2 * Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. |
8051 | 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 */ | |
23 | |
24 /* | |
25 * @test IsMethodCompilableTest | |
12073 | 26 * @bug 8007270 8006683 8007288 8022832 |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
27 * @library /testlibrary /testlibrary/whitebox /testlibrary/com/oracle/java/testlibrary |
8098
1b0dc9f87e75
8006753: fix failed for JDK-8002415 White box testing API for HotSpot
mgerdin
parents:
8051
diff
changeset
|
28 * @build IsMethodCompilableTest |
1b0dc9f87e75
8006753: fix failed for JDK-8002415 White box testing API for HotSpot
mgerdin
parents:
8051
diff
changeset
|
29 * @run main ClassFileInstaller sun.hotspot.WhiteBox |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
30 * @run main ClassFileInstaller com.oracle.java.testlibrary.Platform |
17982
e5d5e7922283
8040244: compiler/whitebox/IsMethodCompilableTest.java fails
neliasso
parents:
17869
diff
changeset
|
31 * @run main/othervm/timeout=2400 -Xbootclasspath/a:. -Xmixed -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -XX:PerMethodRecompilationCutoff=3 -XX:CompileCommand=compileonly,SimpleTestCase$Helper::* IsMethodCompilableTest |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
32 * @summary testing of WB::isMethodCompilable() |
8051 | 33 * @author igor.ignatyev@oracle.com |
34 */ | |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
35 |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
36 import com.oracle.java.testlibrary.Platform; |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
37 |
8051 | 38 public class IsMethodCompilableTest extends CompilerWhiteBoxTest { |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
39 /** |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
40 * Value of {@code -XX:PerMethodRecompilationCutoff} |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
41 */ |
8051 | 42 protected static final long PER_METHOD_RECOMPILATION_CUTOFF; |
43 | |
44 static { | |
45 long tmp = Long.parseLong( | |
46 getVMOption("PerMethodRecompilationCutoff", "400")); | |
47 if (tmp == -1) { | |
48 PER_METHOD_RECOMPILATION_CUTOFF = -1 /* Inf */; | |
49 } else { | |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
50 PER_METHOD_RECOMPILATION_CUTOFF = (0xFFFFFFFFL & tmp); |
8051 | 51 } |
52 } | |
53 | |
54 public static void main(String[] args) throws Exception { | |
14203
f9a4b59ae350
8028587: New tests development for intrisics for basic operators - add, neg, inc, dec, sub, mul
iignatyev
parents:
12328
diff
changeset
|
55 CompilerWhiteBoxTest.main(IsMethodCompilableTest::new, args); |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
56 } |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
57 |
14203
f9a4b59ae350
8028587: New tests development for intrisics for basic operators - add, neg, inc, dec, sub, mul
iignatyev
parents:
12328
diff
changeset
|
58 private IsMethodCompilableTest(TestCase testCase) { |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
59 super(testCase); |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
60 // to prevent inlining of #method |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
61 WHITE_BOX.testSetDontInlineMethod(method, true); |
8051 | 62 } |
63 | |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
64 /** |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
65 * Tests {@code WB::isMethodCompilable()} by recompilation of tested method |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
66 * 'PerMethodRecompilationCutoff' times and checks compilation status. Also |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
67 * checks that WB::clearMethodState() clears no-compilable flags. Only |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
68 * applicable to c2 compiled methods. |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
69 * |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
70 * @throws Exception if one of the checks fails. |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
71 */ |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
72 @Override |
8051 | 73 protected void test() throws Exception { |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
74 // Only c2 compilations can be disabled through PerMethodRecompilationCutoff |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
75 if (!Platform.isServer()) { |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
76 return; |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
77 } |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
78 |
17711
d559dbbded7a
8027124: [TESTBUG] NonTieredLevelsTest: java.lang.RuntimeException: private TestCase$Helper(java.lang.Object) must be osr_compiled
iignatyev
parents:
14203
diff
changeset
|
79 if (skipXcompOSR()) { |
12328
303826f477c6
8023452: TestCase$Helper(java.lang.Object) must be osr_compiled
iignatyev
parents:
12073
diff
changeset
|
80 return; |
303826f477c6
8023452: TestCase$Helper(java.lang.Object) must be osr_compiled
iignatyev
parents:
12073
diff
changeset
|
81 } |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
82 if (!isCompilable(COMP_LEVEL_FULL_OPTIMIZATION)) { |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
83 throw new RuntimeException(method + " must be compilable"); |
8051 | 84 } |
85 System.out.println("PerMethodRecompilationCutoff = " | |
86 + PER_METHOD_RECOMPILATION_CUTOFF); | |
87 if (PER_METHOD_RECOMPILATION_CUTOFF == -1) { | |
88 System.err.println( | |
89 "Warning: test is not applicable if PerMethodRecompilationCutoff == Inf"); | |
90 return; | |
91 } | |
9080
b84fd7d73702
8007288: Additional WB API for compiler's testing
iignatyev
parents:
8766
diff
changeset
|
92 |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
93 // deoptimize 'PerMethodRecompilationCutoff' times |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
94 for (long attempts = 0, successes = 0; |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
95 (successes < PER_METHOD_RECOMPILATION_CUTOFF) && |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
96 (attempts < PER_METHOD_RECOMPILATION_CUTOFF*2) && |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
97 isCompilable(COMP_LEVEL_FULL_OPTIMIZATION); attempts++) { |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
98 if (compileAndDeoptimize() == COMP_LEVEL_FULL_OPTIMIZATION) { |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
99 successes++; |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
100 } |
9080
b84fd7d73702
8007288: Additional WB API for compiler's testing
iignatyev
parents:
8766
diff
changeset
|
101 } |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
102 |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
103 if (!testCase.isOsr() && !isCompilable(COMP_LEVEL_FULL_OPTIMIZATION)) { |
12073 | 104 // in osr test case count of deopt maybe more than iterations |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
105 throw new RuntimeException(method + " is not compilable after " |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
106 + PER_METHOD_RECOMPILATION_CUTOFF + " iterations"); |
9080
b84fd7d73702
8007288: Additional WB API for compiler's testing
iignatyev
parents:
8766
diff
changeset
|
107 } |
8051 | 108 |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
109 // Now compile once more |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
110 compileAndDeoptimize(); |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
111 |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
112 if (isCompilable(COMP_LEVEL_FULL_OPTIMIZATION)) { |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
113 throw new RuntimeException(method + " is still compilable after " |
8051 | 114 + PER_METHOD_RECOMPILATION_CUTOFF + " iterations"); |
115 } | |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
116 checkNotCompiled(); |
8051 | 117 compile(); |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
118 waitBackgroundCompilation(); |
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
119 checkNotCompiled(COMP_LEVEL_FULL_OPTIMIZATION); |
9080
b84fd7d73702
8007288: Additional WB API for compiler's testing
iignatyev
parents:
8766
diff
changeset
|
120 |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
121 // WB.clearMethodState() must reset no-compilable flags |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
122 WHITE_BOX.clearMethodState(method); |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
123 if (!isCompilable(COMP_LEVEL_FULL_OPTIMIZATION)) { |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
124 throw new RuntimeException(method |
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
125 + " is not compilable after clearMethodState()"); |
8051 | 126 } |
9080
b84fd7d73702
8007288: Additional WB API for compiler's testing
iignatyev
parents:
8766
diff
changeset
|
127 compile(); |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
128 checkCompiled(); |
9080
b84fd7d73702
8007288: Additional WB API for compiler's testing
iignatyev
parents:
8766
diff
changeset
|
129 } |
b84fd7d73702
8007288: Additional WB API for compiler's testing
iignatyev
parents:
8766
diff
changeset
|
130 |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
131 private int compileAndDeoptimize() throws Exception { |
9080
b84fd7d73702
8007288: Additional WB API for compiler's testing
iignatyev
parents:
8766
diff
changeset
|
132 compile(); |
10113
4b2eebe03f93
8011971: WB API doesn't accept j.l.reflect.Constructor
iignatyev
parents:
9080
diff
changeset
|
133 waitBackgroundCompilation(); |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
134 int compLevel = getCompLevel(); |
12073 | 135 deoptimize(); |
17869
5e6f84e7a942
8007270: Make IsMethodCompilable test work with tiered
neliasso
parents:
17711
diff
changeset
|
136 return compLevel; |
8051 | 137 } |
138 } |