Mercurial > hg > truffle
annotate graal/com.oracle.graal.compiler.test/src/com/oracle/graal/compiler/test/GraalCompilerTest.java @ 16713:47f9c47145fd
added "Parsing" debug scope in GraalCompilerTest.parse0
author | Doug Simon <doug.simon@oracle.com> |
---|---|
date | Wed, 06 Aug 2014 17:34:00 +0200 |
parents | a2ec1ac769e4 |
children | 1668de777c42 |
rev | line source |
---|---|
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
1 /* |
14053
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
2 * Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
4 * |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
5 * This code is free software; you can redistribute it and/or modify it |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
6 * under the terms of the GNU General Public License version 2 only, as |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
7 * published by the Free Software Foundation. |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
8 * |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
9 * This code is distributed in the hope that it will be useful, but WITHOUT |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
12 * version 2 for more details (a copy is included in the LICENSE file that |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
13 * accompanied this code). |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
14 * |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
15 * You should have received a copy of the GNU General Public License version |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
16 * 2 along with this work; if not, write to the Free Software Foundation, |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
18 * |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
20 * or visit www.oracle.com if you need additional information or have any |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
21 * questions. |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
22 */ |
6334
f8ba3bb81f6f
Renamed com.oracle.graal.tests project to com.oracle.graal.compiler.test
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
6329
diff
changeset
|
23 package com.oracle.graal.compiler.test; |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
24 |
9612
66db0353f55a
compilation is explicitly given a CallingConvention for the graph being compiled instead of deriving it from a method
Doug Simon <doug.simon@oracle.com>
parents:
9042
diff
changeset
|
25 import static com.oracle.graal.api.code.CodeUtil.*; |
13239 | 26 import static com.oracle.graal.compiler.GraalCompiler.*; |
15259
d90e5c22ba55
Move GraalOptions to graal.compiler.common.
Josef Eisl <josef.eisl@jku.at>
parents:
15193
diff
changeset
|
27 import static com.oracle.graal.compiler.common.GraalOptions.*; |
12573
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
28 import static com.oracle.graal.nodes.ConstantNode.*; |
9612
66db0353f55a
compilation is explicitly given a CallingConvention for the graph being compiled instead of deriving it from a method
Doug Simon <doug.simon@oracle.com>
parents:
9042
diff
changeset
|
29 |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
30 import java.lang.reflect.*; |
5650
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
31 import java.util.*; |
11740
a402610bc52b
made compilation ID allocation in tests be atomic
Doug Simon <doug.simon@oracle.com>
parents:
11738
diff
changeset
|
32 import java.util.concurrent.atomic.*; |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
33 |
7260
169bbc849ee9
moved deep array equality comparison into base test class
Doug Simon <doug.simon@oracle.com>
parents:
7154
diff
changeset
|
34 import org.junit.*; |
10885
3f43462ce829
Work around missing support for boolean[] in junit.
Roland Schatz <roland.schatz@oracle.com>
parents:
10764
diff
changeset
|
35 import org.junit.internal.*; |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
36 |
5510
426c605c9d3c
Move cri.ci to api.code.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
5507
diff
changeset
|
37 import com.oracle.graal.api.code.*; |
9612
66db0353f55a
compilation is explicitly given a CallingConvention for the graph being compiled instead of deriving it from a method
Doug Simon <doug.simon@oracle.com>
parents:
9042
diff
changeset
|
38 import com.oracle.graal.api.code.CallingConvention.Type; |
5507
dc71b06d09f8
Moving classes from cri.ri to api.meta.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
5499
diff
changeset
|
39 import com.oracle.graal.api.meta.*; |
15018
db4254246f9a
Remove Constant.forObject and Constant.asObject to improve compiler/VM separation
Christian Wimmer <christian.wimmer@oracle.com>
parents:
14919
diff
changeset
|
40 import com.oracle.graal.api.replacements.*; |
6540
31aa76ffd3bb
Rename project graal.api to graal.api.runtime
Christian Wimmer <christian.wimmer@oracle.com>
parents:
6539
diff
changeset
|
41 import com.oracle.graal.api.runtime.*; |
14066
56726a90dc71
First draft of baseline compiler.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
14056
diff
changeset
|
42 import com.oracle.graal.baseline.*; |
15193
96bb07a5d667
Spit up and move GraalInternalError.
Josef Eisl <josef.eisl@jku.at>
parents:
15188
diff
changeset
|
43 import com.oracle.graal.compiler.common.*; |
7836
a202f72872a4
Remove usage of left-over fields in GraalCompiler.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
7835
diff
changeset
|
44 import com.oracle.graal.compiler.target.*; |
5060
4ed4295ce15f
Update import statements.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
5059
diff
changeset
|
45 import com.oracle.graal.debug.*; |
13197
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
46 import com.oracle.graal.debug.Debug.Scope; |
5425
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
47 import com.oracle.graal.graph.*; |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
48 import com.oracle.graal.graph.Node.Verbosity; |
5060
4ed4295ce15f
Update import statements.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
5059
diff
changeset
|
49 import com.oracle.graal.java.*; |
13229
325b4e4efb60
added CompilationResultBuilderFactory to support peep-hole instrumentation of methods as their code is emitted
Doug Simon <doug.simon@oracle.com>
parents:
13228
diff
changeset
|
50 import com.oracle.graal.lir.asm.*; |
5060
4ed4295ce15f
Update import statements.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
5059
diff
changeset
|
51 import com.oracle.graal.nodes.*; |
6529
2e96dc4eb8e2
renamed package: com.oracle.graal.lir.cfg -> com.oracle.graal.nodes.cfg
Doug Simon <doug.simon@oracle.com>
parents:
6526
diff
changeset
|
52 import com.oracle.graal.nodes.cfg.*; |
5720
46ad94a0574a
moved everything from com.oracle.graal.nodes.cri into com.oracle.graal.nodes.spi
Doug Simon <doug.simon@oracle.com>
parents:
5719
diff
changeset
|
53 import com.oracle.graal.nodes.spi.*; |
8921
ea867ede377f
allow GraalCompilerTests to ignore virtual and floating nodes in graph comparison
Lukas Stadler <lukas.stadler@jku.at>
parents:
8598
diff
changeset
|
54 import com.oracle.graal.nodes.virtual.*; |
6525
2c913b643422
rename packages in graal.phases to match project name
Doug Simon <doug.simon@oracle.com>
parents:
6447
diff
changeset
|
55 import com.oracle.graal.phases.*; |
15990
ba0e3c75bd49
add ComputeLoopFrequenciesPhase after canonicalizer
Lukas Stadler <lukas.stadler@oracle.com>
parents:
15950
diff
changeset
|
56 import com.oracle.graal.phases.common.*; |
15949
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
57 import com.oracle.graal.phases.common.inlining.*; |
6525
2c913b643422
rename packages in graal.phases to match project name
Doug Simon <doug.simon@oracle.com>
parents:
6447
diff
changeset
|
58 import com.oracle.graal.phases.schedule.*; |
9968
3df534c97af1
Create Suites instance in runtime.
Roland Schatz <roland.schatz@oracle.com>
parents:
9864
diff
changeset
|
59 import com.oracle.graal.phases.tiers.*; |
12054
bba234a1670e
grouped provider values/parameters into a Providers object (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12052
diff
changeset
|
60 import com.oracle.graal.phases.util.*; |
7318
323ece2b012b
Refactor debug environment creation.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
7282
diff
changeset
|
61 import com.oracle.graal.printer.*; |
12488
1a4dc163cd0a
abstracted HotSpotGraalRuntime as a RuntimeProvider which removes the recent selector addition to the Graal capabilities API and also makes Truffle independent of the graal.hotspot project (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12456
diff
changeset
|
62 import com.oracle.graal.runtime.*; |
7717
cf94bd18eb47
lift GraalCompilerTest.getMethod to a common base class
Roland Schatz <roland.schatz@oracle.com>
parents:
7530
diff
changeset
|
63 import com.oracle.graal.test.*; |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
64 |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
65 /** |
6578 | 66 * Base class for Graal compiler unit tests. |
67 * <p> | |
68 * White box tests for Graal compiler transformations use this pattern: | |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
69 * <ol> |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
70 * <li>Create a graph by {@linkplain #parse(String) parsing} a method.</li> |
5360
6cc970203f30
moved creation of a RiCodeInfo to the runtime side of the CRI
Doug Simon <doug.simon@oracle.com>
parents:
5122
diff
changeset
|
71 * <li>Manually modify the graph (e.g. replace a parameter node with a constant).</li> |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
72 * <li>Apply a transformation to the graph.</li> |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
73 * <li>Assert that the transformed graph is equal to an expected graph.</li> |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
74 * </ol> |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
75 * <p> |
6578 | 76 * See {@link InvokeHintsTest} as an example of a white box test. |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
77 * <p> |
7530
5e3d1a68664e
applied mx eclipseformat to all Java files
Doug Simon <doug.simon@oracle.com>
parents:
7321
diff
changeset
|
78 * Black box tests use the {@link #test(String, Object...)} or |
5e3d1a68664e
applied mx eclipseformat to all Java files
Doug Simon <doug.simon@oracle.com>
parents:
7321
diff
changeset
|
79 * {@link #testN(int, String, Object...)} to execute some method in the interpreter and compare its |
5e3d1a68664e
applied mx eclipseformat to all Java files
Doug Simon <doug.simon@oracle.com>
parents:
7321
diff
changeset
|
80 * result against that produced by a Graal compiled version of the method. |
6578 | 81 * <p> |
82 * These tests will be run by the {@code mx unittest} command. | |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
83 */ |
7717
cf94bd18eb47
lift GraalCompilerTest.getMethod to a common base class
Roland Schatz <roland.schatz@oracle.com>
parents:
7530
diff
changeset
|
84 public abstract class GraalCompilerTest extends GraalTest { |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
85 |
12362
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
86 private final Providers providers; |
12456
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
87 private final Backend backend; |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
88 private final Suites suites; |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
89 |
15950
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
90 /** |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
91 * Can be overridden by unit tests to verify properties of the graph. |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
92 * |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
93 * @param graph the graph at the end of HighTier |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
94 */ |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
95 protected boolean checkHighTierGraph(StructuredGraph graph) { |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
96 return true; |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
97 } |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
98 |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
99 /** |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
100 * Can be overridden by unit tests to verify properties of the graph. |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
101 * |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
102 * @param graph the graph at the end of MidTier |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
103 */ |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
104 protected boolean checkMidTierGraph(StructuredGraph graph) { |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
105 return true; |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
106 } |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
107 |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
108 /** |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
109 * Can be overridden by unit tests to verify properties of the graph. |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
110 * |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
111 * @param graph the graph at the end of LowTier |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
112 */ |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
113 protected boolean checkLowTierGraph(StructuredGraph graph) { |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
114 return true; |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
115 } |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
116 |
14014
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
117 private static boolean substitutionsInstalled; |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
118 |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
119 private void installSubstitutions() { |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
120 if (!substitutionsInstalled) { |
15942
5c73b162eec2
reduced execution time of ReplacementsImple.registerSubstitutions() by deferring parsing of substitution classes until the first request for a substitute method is received
Doug Simon <doug.simon@oracle.com>
parents:
15622
diff
changeset
|
121 this.providers.getReplacements().registerSubstitutions(GraalCompilerTest.class, InjectProfileDataSubstitutions.class); |
14014
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
122 substitutionsInstalled = true; |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
123 } |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
124 } |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
125 |
15949
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
126 protected Suites createSuites() { |
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
127 Suites ret = backend.getSuites().createSuites(); |
15990
ba0e3c75bd49
add ComputeLoopFrequenciesPhase after canonicalizer
Lukas Stadler <lukas.stadler@oracle.com>
parents:
15950
diff
changeset
|
128 ListIterator<BasePhase<? super HighTierContext>> iter = ret.getHighTier().findPhase(InliningPhase.class); |
ba0e3c75bd49
add ComputeLoopFrequenciesPhase after canonicalizer
Lukas Stadler <lukas.stadler@oracle.com>
parents:
15950
diff
changeset
|
129 PhaseSuite.findNextPhase(iter, CanonicalizerPhase.class); |
ba0e3c75bd49
add ComputeLoopFrequenciesPhase after canonicalizer
Lukas Stadler <lukas.stadler@oracle.com>
parents:
15950
diff
changeset
|
130 iter.add(new Phase("ComputeLoopFrequenciesPhase") { |
15949
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
131 |
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
132 @Override |
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
133 protected void run(StructuredGraph graph) { |
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
134 ComputeLoopFrequenciesClosure.compute(graph); |
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
135 } |
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
136 }); |
15950
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
137 ret.getHighTier().appendPhase(new Phase("CheckGraphPhase") { |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
138 |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
139 @Override |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
140 protected void run(StructuredGraph graph) { |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
141 assert checkHighTierGraph(graph); |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
142 } |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
143 }); |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
144 ret.getMidTier().appendPhase(new Phase("CheckGraphPhase") { |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
145 |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
146 @Override |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
147 protected void run(StructuredGraph graph) { |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
148 assert checkMidTierGraph(graph); |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
149 } |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
150 }); |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
151 ret.getLowTier().appendPhase(new Phase("CheckGraphPhase") { |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
152 |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
153 @Override |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
154 protected void run(StructuredGraph graph) { |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
155 assert checkLowTierGraph(graph); |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
156 } |
e4567f9acc42
Interface to do graph verification after High/Mid/LowTier in unittests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15949
diff
changeset
|
157 }); |
15949
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
158 return ret; |
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
159 } |
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
160 |
5565
0083a59ced84
Renaming GraphTest => GraalCompilerTest.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
5546
diff
changeset
|
161 public GraalCompilerTest() { |
12488
1a4dc163cd0a
abstracted HotSpotGraalRuntime as a RuntimeProvider which removes the recent selector addition to the Graal capabilities API and also makes Truffle independent of the graal.hotspot project (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12456
diff
changeset
|
162 this.backend = Graal.getRequiredCapability(RuntimeProvider.class).getHostBackend(); |
12456
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
163 this.providers = getBackend().getProviders(); |
15949
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
164 this.suites = createSuites(); |
14014
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
165 installSubstitutions(); |
12456
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
166 } |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
167 |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
168 /** |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
169 * Set up a test for a non-default backend. The test should check (via {@link #getBackend()} ) |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
170 * whether the desired backend is available. |
14919
bd08e610e6f3
BaselineCompiler: create BytecodeParser.
Josef Eisl <josef.eisl@jku.at>
parents:
14890
diff
changeset
|
171 * |
12456
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
172 * @param arch the name of the desired backend architecture |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
173 */ |
12488
1a4dc163cd0a
abstracted HotSpotGraalRuntime as a RuntimeProvider which removes the recent selector addition to the Graal capabilities API and also makes Truffle independent of the graal.hotspot project (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12456
diff
changeset
|
174 public GraalCompilerTest(Class<? extends Architecture> arch) { |
1a4dc163cd0a
abstracted HotSpotGraalRuntime as a RuntimeProvider which removes the recent selector addition to the Graal capabilities API and also makes Truffle independent of the graal.hotspot project (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12456
diff
changeset
|
175 RuntimeProvider runtime = Graal.getRequiredCapability(RuntimeProvider.class); |
1a4dc163cd0a
abstracted HotSpotGraalRuntime as a RuntimeProvider which removes the recent selector addition to the Graal capabilities API and also makes Truffle independent of the graal.hotspot project (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12456
diff
changeset
|
176 Backend b = runtime.getBackend(arch); |
12456
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
177 if (b != null) { |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
178 this.backend = b; |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
179 } else { |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
180 // Fall back to the default/host backend |
12488
1a4dc163cd0a
abstracted HotSpotGraalRuntime as a RuntimeProvider which removes the recent selector addition to the Graal capabilities API and also makes Truffle independent of the graal.hotspot project (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12456
diff
changeset
|
181 this.backend = runtime.getHostBackend(); |
12456
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
182 } |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
183 this.providers = backend.getProviders(); |
15949
4243a6b8dd19
Fix insertion of profile data in unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
15942
diff
changeset
|
184 this.suites = createSuites(); |
14014
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
185 installSubstitutions(); |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
186 } |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
187 |
8598
5a3703970e3f
share debug environment across multiple tests
Doug Simon <doug.simon@oracle.com>
parents:
8349
diff
changeset
|
188 @BeforeClass |
11560 | 189 public static void initializeDebugging() { |
8598
5a3703970e3f
share debug environment across multiple tests
Doug Simon <doug.simon@oracle.com>
parents:
8349
diff
changeset
|
190 DebugEnvironment.initialize(System.out); |
5a3703970e3f
share debug environment across multiple tests
Doug Simon <doug.simon@oracle.com>
parents:
8349
diff
changeset
|
191 } |
5a3703970e3f
share debug environment across multiple tests
Doug Simon <doug.simon@oracle.com>
parents:
8349
diff
changeset
|
192 |
13197
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
193 private Scope debugScope; |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
194 |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
195 @Before |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
196 public void beforeTest() { |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
197 assert debugScope == null; |
14620
a0baf4eeb018
removed allocation for name of debug scope
Doug Simon <doug.simon@oracle.com>
parents:
14573
diff
changeset
|
198 debugScope = Debug.scope(getClass()); |
13197
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
199 } |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
200 |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
201 @After |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
202 public void afterTest() { |
13579
be2b096a5f69
GraalCompilerTest: fix NPE when debugging is not enabled.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
13239
diff
changeset
|
203 if (debugScope != null) { |
13580
8958eb3ff6b9
GraalCompilerTest: add messages to exception comparison asserts to make JUnit output clearer
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
13579
diff
changeset
|
204 debugScope.close(); |
13579
be2b096a5f69
GraalCompilerTest: fix NPE when debugging is not enabled.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
13239
diff
changeset
|
205 } |
13197
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
206 debugScope = null; |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
207 } |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
208 |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
209 protected void assertEquals(StructuredGraph expected, StructuredGraph graph) { |
14890
8ebeb60167ee
compare constants in graphs in GraalCompilerTest.assertEquals
Lukas Stadler <lukas.stadler@oracle.com>
parents:
14826
diff
changeset
|
210 assertEquals(expected, graph, false, true); |
8921
ea867ede377f
allow GraalCompilerTests to ignore virtual and floating nodes in graph comparison
Lukas Stadler <lukas.stadler@jku.at>
parents:
8598
diff
changeset
|
211 } |
ea867ede377f
allow GraalCompilerTests to ignore virtual and floating nodes in graph comparison
Lukas Stadler <lukas.stadler@jku.at>
parents:
8598
diff
changeset
|
212 |
12573
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
213 protected int countUnusedConstants(StructuredGraph graph) { |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
214 int total = 0; |
12655
2c4aa758ee18
made ConstantNodes external to a Graph (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12573
diff
changeset
|
215 for (ConstantNode node : getConstantNodes(graph)) { |
16073
b38191cd1665
removed code to make recording usages optional for ConstantNodes (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
15990
diff
changeset
|
216 if (node.usages().isEmpty()) { |
b38191cd1665
removed code to make recording usages optional for ConstantNodes (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
15990
diff
changeset
|
217 total++; |
12573
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
218 } |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
219 } |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
220 return total; |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
221 } |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
222 |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
223 protected int getNodeCountExcludingUnusedConstants(StructuredGraph graph) { |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
224 return graph.getNodeCount() - countUnusedConstants(graph); |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
225 } |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
226 |
14890
8ebeb60167ee
compare constants in graphs in GraalCompilerTest.assertEquals
Lukas Stadler <lukas.stadler@oracle.com>
parents:
14826
diff
changeset
|
227 protected void assertEquals(StructuredGraph expected, StructuredGraph graph, boolean excludeVirtual, boolean checkConstants) { |
8ebeb60167ee
compare constants in graphs in GraalCompilerTest.assertEquals
Lukas Stadler <lukas.stadler@oracle.com>
parents:
14826
diff
changeset
|
228 String expectedString = getCanonicalGraphString(expected, excludeVirtual, checkConstants); |
8ebeb60167ee
compare constants in graphs in GraalCompilerTest.assertEquals
Lukas Stadler <lukas.stadler@oracle.com>
parents:
14826
diff
changeset
|
229 String actualString = getCanonicalGraphString(graph, excludeVirtual, checkConstants); |
15188
bbd2583f4f1d
print graph names when assertEquals(StructuredGraph, StructuredGraph) fails
Lukas Stadler <lukas.stadler@oracle.com>
parents:
15162
diff
changeset
|
230 String mismatchString = "mismatch in graphs:\n========= expected (" + expected + ") =========\n" + expectedString + "\n\n========= actual (" + graph + ") =========\n" + actualString; |
5425
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
231 |
12573
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
232 if (!excludeVirtual && getNodeCountExcludingUnusedConstants(expected) != getNodeCountExcludingUnusedConstants(graph)) { |
4363
7462c3600c3a
Draft changes to the graph plotting.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
4265
diff
changeset
|
233 Debug.dump(expected, "Node count not matching - expected"); |
7462c3600c3a
Draft changes to the graph plotting.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
4265
diff
changeset
|
234 Debug.dump(graph, "Node count not matching - actual"); |
5425
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
235 Assert.fail("Graphs do not have the same number of nodes: " + expected.getNodeCount() + " vs. " + graph.getNodeCount() + "\n" + mismatchString); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
236 } |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
237 if (!expectedString.equals(actualString)) { |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
238 Debug.dump(expected, "mismatching graphs - expected"); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
239 Debug.dump(graph, "mismatching graphs - actual"); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
240 Assert.fail(mismatchString); |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
241 } |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
242 } |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
243 |
5657
d71eb56d6bb0
new stamp inference in CanonicalizerPhase, IntegerStamp.mask
Lukas Stadler <lukas.stadler@jku.at>
parents:
5650
diff
changeset
|
244 protected void assertConstantReturn(StructuredGraph graph, int value) { |
14890
8ebeb60167ee
compare constants in graphs in GraalCompilerTest.assertEquals
Lukas Stadler <lukas.stadler@oracle.com>
parents:
14826
diff
changeset
|
245 String graphString = getCanonicalGraphString(graph, false, true); |
13690
08f58bfde0dd
add IterableNodeType to ReturnNode
Lukas Stadler <lukas.stadler@jku.at>
parents:
13669
diff
changeset
|
246 Assert.assertEquals("unexpected number of ReturnNodes: " + graphString, graph.getNodes(ReturnNode.class).count(), 1); |
08f58bfde0dd
add IterableNodeType to ReturnNode
Lukas Stadler <lukas.stadler@jku.at>
parents:
13669
diff
changeset
|
247 ValueNode result = graph.getNodes(ReturnNode.class).first().result(); |
5657
d71eb56d6bb0
new stamp inference in CanonicalizerPhase, IntegerStamp.mask
Lukas Stadler <lukas.stadler@jku.at>
parents:
5650
diff
changeset
|
248 Assert.assertTrue("unexpected ReturnNode result node: " + graphString, result.isConstant()); |
6329
92bc58dc5b5e
More clean up and documentation in api.code and api.meta.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
5780
diff
changeset
|
249 Assert.assertEquals("unexpected ReturnNode result kind: " + graphString, result.asConstant().getKind(), Kind.Int); |
5657
d71eb56d6bb0
new stamp inference in CanonicalizerPhase, IntegerStamp.mask
Lukas Stadler <lukas.stadler@jku.at>
parents:
5650
diff
changeset
|
250 Assert.assertEquals("unexpected ReturnNode result: " + graphString, result.asConstant().asInt(), value); |
d71eb56d6bb0
new stamp inference in CanonicalizerPhase, IntegerStamp.mask
Lukas Stadler <lukas.stadler@jku.at>
parents:
5650
diff
changeset
|
251 } |
d71eb56d6bb0
new stamp inference in CanonicalizerPhase, IntegerStamp.mask
Lukas Stadler <lukas.stadler@jku.at>
parents:
5650
diff
changeset
|
252 |
14890
8ebeb60167ee
compare constants in graphs in GraalCompilerTest.assertEquals
Lukas Stadler <lukas.stadler@oracle.com>
parents:
14826
diff
changeset
|
253 protected static String getCanonicalGraphString(StructuredGraph graph, boolean excludeVirtual, boolean checkConstants) { |
5425
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
254 SchedulePhase schedule = new SchedulePhase(); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
255 schedule.apply(graph); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
256 |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
257 NodeMap<Integer> canonicalId = graph.createNodeMap(); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
258 int nextId = 0; |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
259 |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
260 StringBuilder result = new StringBuilder(); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
261 for (Block block : schedule.getCFG().getBlocks()) { |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
262 result.append("Block " + block + " "); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
263 if (block == schedule.getCFG().getStartBlock()) { |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
264 result.append("* "); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
265 } |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
266 result.append("-> "); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
267 for (Block succ : block.getSuccessors()) { |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
268 result.append(succ + " "); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
269 } |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
270 result.append("\n"); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
271 for (Node node : schedule.getBlockToNodesMap().get(block)) { |
16199
506583999cf2
handle dead-code eliminated nodes in GraalCOmpilerTest.getCanonicalGraphString
Doug Simon <doug.simon@oracle.com>
parents:
16073
diff
changeset
|
272 if (node.isAlive() && node.recordsUsages()) { |
12573
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
273 if (!excludeVirtual || !(node instanceof VirtualObjectNode || node instanceof ProxyNode)) { |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
274 int id; |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
275 if (canonicalId.get(node) != null) { |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
276 id = canonicalId.get(node); |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
277 } else { |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
278 id = nextId++; |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
279 canonicalId.set(node, id); |
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
280 } |
14890
8ebeb60167ee
compare constants in graphs in GraalCompilerTest.assertEquals
Lukas Stadler <lukas.stadler@oracle.com>
parents:
14826
diff
changeset
|
281 String name = node instanceof ConstantNode && checkConstants ? node.toString(Verbosity.Name) : node.getClass().getSimpleName(); |
12573
6332050441eb
fixed tests that need to take into account ConstantNodes not recording their usages (GRAAL-508)
Doug Simon <doug.simon@oracle.com>
parents:
12488
diff
changeset
|
282 result.append(" " + id + "|" + name + (excludeVirtual ? "\n" : " (" + node.usages().count() + ")\n")); |
8921
ea867ede377f
allow GraalCompilerTests to ignore virtual and floating nodes in graph comparison
Lukas Stadler <lukas.stadler@jku.at>
parents:
8598
diff
changeset
|
283 } |
5425
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
284 } |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
285 } |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
286 } |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
287 return result.toString(); |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
288 } |
0364a2a874b8
changes towards a canonical representation of comparisons:
Lukas Stadler <lukas.stadler@jku.at>
parents:
5360
diff
changeset
|
289 |
12456
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
290 protected Backend getBackend() { |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
291 return backend; |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
292 } |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
293 |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
294 protected Suites getSuites() { |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
295 return suites; |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
296 } |
f87c68d79f07
improved support for co-existing, multiple backends (GRAAL-363)
Doug Simon <doug.simon@oracle.com>
parents:
12362
diff
changeset
|
297 |
12054
bba234a1670e
grouped provider values/parameters into a Providers object (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12052
diff
changeset
|
298 protected Providers getProviders() { |
12362
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
299 return providers; |
12054
bba234a1670e
grouped provider values/parameters into a Providers object (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12052
diff
changeset
|
300 } |
bba234a1670e
grouped provider values/parameters into a Providers object (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12052
diff
changeset
|
301 |
15018
db4254246f9a
Remove Constant.forObject and Constant.asObject to improve compiler/VM separation
Christian Wimmer <christian.wimmer@oracle.com>
parents:
14919
diff
changeset
|
302 protected SnippetReflectionProvider getSnippetReflection() { |
db4254246f9a
Remove Constant.forObject and Constant.asObject to improve compiler/VM separation
Christian Wimmer <christian.wimmer@oracle.com>
parents:
14919
diff
changeset
|
303 return Graal.getRequiredCapability(SnippetReflectionProvider.class); |
db4254246f9a
Remove Constant.forObject and Constant.asObject to improve compiler/VM separation
Christian Wimmer <christian.wimmer@oracle.com>
parents:
14919
diff
changeset
|
304 } |
db4254246f9a
Remove Constant.forObject and Constant.asObject to improve compiler/VM separation
Christian Wimmer <christian.wimmer@oracle.com>
parents:
14919
diff
changeset
|
305 |
13132
922dd1415c0a
Commit pass target as a parameter to ReplacementImpl, so that it does not require a CodeCacheProvider
Christian Wimmer <christian.wimmer@oracle.com>
parents:
12655
diff
changeset
|
306 protected TargetDescription getTarget() { |
922dd1415c0a
Commit pass target as a parameter to ReplacementImpl, so that it does not require a CodeCacheProvider
Christian Wimmer <christian.wimmer@oracle.com>
parents:
12655
diff
changeset
|
307 return getProviders().getCodeCache().getTarget(); |
922dd1415c0a
Commit pass target as a parameter to ReplacementImpl, so that it does not require a CodeCacheProvider
Christian Wimmer <christian.wimmer@oracle.com>
parents:
12655
diff
changeset
|
308 } |
922dd1415c0a
Commit pass target as a parameter to ReplacementImpl, so that it does not require a CodeCacheProvider
Christian Wimmer <christian.wimmer@oracle.com>
parents:
12655
diff
changeset
|
309 |
12045
0fc653a9e019
made GraalCodeCacheProvider independent of CodeCacheProvider and renamed the former to LoweringProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
11959
diff
changeset
|
310 protected CodeCacheProvider getCodeCache() { |
12362
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
311 return getProviders().getCodeCache(); |
11959
23ccaa863eda
made CodeCacheProvider independent of MetaAccessProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
11740
diff
changeset
|
312 } |
23ccaa863eda
made CodeCacheProvider independent of MetaAccessProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
11740
diff
changeset
|
313 |
12052
0afe7370260c
refactored constantEquals(), lookupArrayLength() and readUnsafeConstant() out of MetaAccessProvider into ConstantReflectionProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12045
diff
changeset
|
314 protected ConstantReflectionProvider getConstantReflection() { |
12362
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
315 return getProviders().getConstantReflection(); |
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
316 } |
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
317 |
11959
23ccaa863eda
made CodeCacheProvider independent of MetaAccessProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
11740
diff
changeset
|
318 protected MetaAccessProvider getMetaAccess() { |
12362
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
319 return getProviders().getMetaAccess(); |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
320 } |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
321 |
12045
0fc653a9e019
made GraalCodeCacheProvider independent of CodeCacheProvider and renamed the former to LoweringProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
11959
diff
changeset
|
322 protected LoweringProvider getLowerer() { |
12362
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
323 return getProviders().getLowerer(); |
12045
0fc653a9e019
made GraalCodeCacheProvider independent of CodeCacheProvider and renamed the former to LoweringProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
11959
diff
changeset
|
324 } |
0fc653a9e019
made GraalCodeCacheProvider independent of CodeCacheProvider and renamed the former to LoweringProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
11959
diff
changeset
|
325 |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
326 /** |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
327 * Parses a Java method to produce a graph. |
14919
bd08e610e6f3
BaselineCompiler: create BytecodeParser.
Josef Eisl <josef.eisl@jku.at>
parents:
14890
diff
changeset
|
328 * |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
329 * @param methodName the name of the method in {@code this.getClass()} to be parsed |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
330 */ |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
331 protected StructuredGraph parse(String methodName) { |
4993
897b7d18bebc
added RiCompiledMethod.execute and the required VM infrastructure
Lukas Stadler <lukas.stadler@jku.at>
parents:
4410
diff
changeset
|
332 return parse(getMethod(methodName)); |
897b7d18bebc
added RiCompiledMethod.execute and the required VM infrastructure
Lukas Stadler <lukas.stadler@jku.at>
parents:
4410
diff
changeset
|
333 } |
897b7d18bebc
added RiCompiledMethod.execute and the required VM infrastructure
Lukas Stadler <lukas.stadler@jku.at>
parents:
4410
diff
changeset
|
334 |
11740
a402610bc52b
made compilation ID allocation in tests be atomic
Doug Simon <doug.simon@oracle.com>
parents:
11738
diff
changeset
|
335 private static AtomicInteger compilationId = new AtomicInteger(); |
5433
d7b5cc23945e
refactored tests to share support for dump-aware compilation
Doug Simon <doug.simon@oracle.com>
parents:
5425
diff
changeset
|
336 |
6370
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
337 protected void testN(int n, final String name, final Object... args) { |
11738
aa10794f1574
better reporting of failures during multi-threaded tests
Doug Simon <doug.simon@oracle.com>
parents:
11660
diff
changeset
|
338 final List<Throwable> errors = new ArrayList<>(n); |
6370
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
339 Thread[] threads = new Thread[n]; |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
340 for (int i = 0; i < n; i++) { |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
341 Thread t = new Thread(i + ":" + name) { |
7530
5e3d1a68664e
applied mx eclipseformat to all Java files
Doug Simon <doug.simon@oracle.com>
parents:
7321
diff
changeset
|
342 |
6370
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
343 @Override |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
344 public void run() { |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
345 try { |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
346 test(name, args); |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
347 } catch (Throwable e) { |
11738
aa10794f1574
better reporting of failures during multi-threaded tests
Doug Simon <doug.simon@oracle.com>
parents:
11660
diff
changeset
|
348 errors.add(e); |
6370
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
349 } |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
350 } |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
351 }; |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
352 threads[i] = t; |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
353 t.start(); |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
354 } |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
355 for (int i = 0; i < n; i++) { |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
356 try { |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
357 threads[i].join(); |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
358 } catch (InterruptedException e) { |
11738
aa10794f1574
better reporting of failures during multi-threaded tests
Doug Simon <doug.simon@oracle.com>
parents:
11660
diff
changeset
|
359 errors.add(e); |
6370
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
360 } |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
361 } |
11738
aa10794f1574
better reporting of failures during multi-threaded tests
Doug Simon <doug.simon@oracle.com>
parents:
11660
diff
changeset
|
362 if (!errors.isEmpty()) { |
aa10794f1574
better reporting of failures during multi-threaded tests
Doug Simon <doug.simon@oracle.com>
parents:
11660
diff
changeset
|
363 throw new MultiCauseAssertionError(errors.size() + " failures", errors.toArray(new Throwable[errors.size()])); |
aa10794f1574
better reporting of failures during multi-threaded tests
Doug Simon <doug.simon@oracle.com>
parents:
11660
diff
changeset
|
364 } |
6370
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
365 } |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
366 |
6431
2e376f8ea4e2
added snippet for lowering NewMultiArrayNodes
Doug Simon <doug.simon@oracle.com>
parents:
6370
diff
changeset
|
367 protected Object referenceInvoke(Method method, Object receiver, Object... args) throws IllegalAccessException, IllegalArgumentException, InvocationTargetException { |
2e376f8ea4e2
added snippet for lowering NewMultiArrayNodes
Doug Simon <doug.simon@oracle.com>
parents:
6370
diff
changeset
|
368 return method.invoke(receiver, args); |
2e376f8ea4e2
added snippet for lowering NewMultiArrayNodes
Doug Simon <doug.simon@oracle.com>
parents:
6370
diff
changeset
|
369 } |
2e376f8ea4e2
added snippet for lowering NewMultiArrayNodes
Doug Simon <doug.simon@oracle.com>
parents:
6370
diff
changeset
|
370 |
8232
ab374f69e4e8
JTTTest gets the expeted result only once
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8217
diff
changeset
|
371 protected static class Result { |
7530
5e3d1a68664e
applied mx eclipseformat to all Java files
Doug Simon <doug.simon@oracle.com>
parents:
7321
diff
changeset
|
372 |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
373 final Object returnValue; |
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
374 final Throwable exception; |
7530
5e3d1a68664e
applied mx eclipseformat to all Java files
Doug Simon <doug.simon@oracle.com>
parents:
7321
diff
changeset
|
375 |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
376 public Result(Object returnValue, Throwable exception) { |
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
377 this.returnValue = returnValue; |
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
378 this.exception = exception; |
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
379 } |
9682
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
380 |
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
381 @Override |
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
382 public String toString() { |
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
383 return exception == null ? returnValue == null ? "null" : returnValue.toString() : "!" + exception; |
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
384 } |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
385 } |
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
386 |
7282
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
387 /** |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
388 * Called before a test is executed. |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
389 */ |
9682
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
390 protected void before(@SuppressWarnings("unused") Method method) { |
7282
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
391 } |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
392 |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
393 /** |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
394 * Called after a test is executed. |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
395 */ |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
396 protected void after() { |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
397 } |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
398 |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
399 protected Result executeExpected(Method method, Object receiver, Object... args) { |
9682
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
400 before(method); |
5557
2e2a77f091f2
re-enabled disassembler output to C1Visualizer after code installation
Doug Simon <doug.simon@oracle.com>
parents:
5546
diff
changeset
|
401 try { |
7530
5e3d1a68664e
applied mx eclipseformat to all Java files
Doug Simon <doug.simon@oracle.com>
parents:
7321
diff
changeset
|
402 // This gives us both the expected return value as well as ensuring that the method to |
5e3d1a68664e
applied mx eclipseformat to all Java files
Doug Simon <doug.simon@oracle.com>
parents:
7321
diff
changeset
|
403 // be compiled is fully resolved |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
404 return new Result(referenceInvoke(method, receiver, args), null); |
5557
2e2a77f091f2
re-enabled disassembler output to C1Visualizer after code installation
Doug Simon <doug.simon@oracle.com>
parents:
5546
diff
changeset
|
405 } catch (InvocationTargetException e) { |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
406 return new Result(null, e.getTargetException()); |
5557
2e2a77f091f2
re-enabled disassembler output to C1Visualizer after code installation
Doug Simon <doug.simon@oracle.com>
parents:
5546
diff
changeset
|
407 } catch (Exception e) { |
2e2a77f091f2
re-enabled disassembler output to C1Visualizer after code installation
Doug Simon <doug.simon@oracle.com>
parents:
5546
diff
changeset
|
408 throw new RuntimeException(e); |
7282
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
409 } finally { |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
410 after(); |
5557
2e2a77f091f2
re-enabled disassembler output to C1Visualizer after code installation
Doug Simon <doug.simon@oracle.com>
parents:
5546
diff
changeset
|
411 } |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
412 } |
6370
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
413 |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
414 protected Result executeActual(Method method, Object receiver, Object... args) { |
9682
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
415 before(method); |
7282
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
416 Object[] executeArgs = argsWithReceiver(receiver, args); |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
417 |
12362
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
418 ResolvedJavaMethod javaMethod = getMetaAccess().lookupJavaMethod(method); |
8233
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
419 checkArgs(javaMethod, executeArgs); |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
420 |
14053
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
421 InstalledCode compiledMethod = null; |
14066
56726a90dc71
First draft of baseline compiler.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
14056
diff
changeset
|
422 if (UseBaselineCompiler.getValue()) { |
14053
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
423 compiledMethod = getCodeBaseline(javaMethod, method); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
424 } else { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
425 compiledMethod = getCode(javaMethod, parse(method)); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
426 } |
7282
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
427 try { |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
428 return new Result(compiledMethod.executeVarargs(executeArgs), null); |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
429 } catch (Throwable e) { |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
430 return new Result(null, e); |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
431 } finally { |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
432 after(); |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
433 } |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
434 } |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
435 |
14053
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
436 protected InstalledCode getCodeBaseline(ResolvedJavaMethod javaMethod, Method method) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
437 return getCodeBaseline(javaMethod, method, false); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
438 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
439 |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
440 protected InstalledCode getCodeBaseline(ResolvedJavaMethod javaMethod, Method method, boolean forceCompile) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
441 assert method.getAnnotation(Test.class) == null : "shouldn't parse method with @Test annotation: " + method; |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
442 |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
443 try (Scope bds = Debug.scope("Baseline")) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
444 Debug.log("getCodeBaseline()"); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
445 } catch (Throwable e) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
446 throw Debug.handle(e); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
447 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
448 |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
449 if (!forceCompile) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
450 InstalledCode cached = cache.get(javaMethod); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
451 if (cached != null) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
452 if (cached.isValid()) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
453 return cached; |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
454 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
455 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
456 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
457 |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
458 final int id = compilationId.incrementAndGet(); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
459 |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
460 InstalledCode installedCode = null; |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
461 try (Scope ds = Debug.scope("Compiling", new DebugDumpScope(String.valueOf(id), true))) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
462 final boolean printCompilation = PrintCompilation.getValue() && !TTY.isSuppressed(); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
463 |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
464 if (printCompilation) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
465 TTY.println(String.format("@%-6d Graal %-70s %-45s %-50s ...", id, javaMethod.getDeclaringClass().getName(), javaMethod.getName(), javaMethod.getSignature())); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
466 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
467 long start = System.currentTimeMillis(); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
468 |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
469 CompilationResult compResult = compileBaseline(javaMethod); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
470 |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
471 if (printCompilation) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
472 TTY.println(String.format("@%-6d Graal %-70s %-45s %-50s | %4dms %5dB", id, "", "", "", System.currentTimeMillis() - start, compResult.getTargetCodeSize())); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
473 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
474 |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
475 try (Scope s = Debug.scope("CodeInstall", getCodeCache(), javaMethod)) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
476 installedCode = addMethod(javaMethod, compResult); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
477 if (installedCode == null) { |
16480
10c12d09a8d2
moved format(String format, JavaMethod method) from MetaUtil to be a default method in JavaMethod
Doug Simon <doug.simon@oracle.com>
parents:
16199
diff
changeset
|
478 throw new GraalInternalError("Could not install code for " + javaMethod.format("%H.%n(%p)")); |
14053
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
479 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
480 } catch (Throwable e) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
481 throw Debug.handle(e); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
482 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
483 } catch (Throwable e) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
484 throw Debug.handle(e); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
485 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
486 |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
487 if (!forceCompile) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
488 cache.put(javaMethod, installedCode); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
489 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
490 return installedCode; |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
491 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
492 |
14055
89bbedfe0ad3
Direct LIR generation: refactoring alternative compilation path in GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14054
diff
changeset
|
493 private CompilationResult compileBaseline(ResolvedJavaMethod javaMethod) { |
14826 | 494 try (Scope bds = Debug.scope("CompileBaseline", javaMethod, providers.getCodeCache())) { |
14127
452bb6e73298
BaselineCompiler: fix typo.
Josef Eisl <josef.eisl@jku.at>
parents:
14067
diff
changeset
|
495 BaselineCompiler baselineCompiler = new BaselineCompiler(GraphBuilderConfiguration.getDefault(), providers.getMetaAccess()); |
14919
bd08e610e6f3
BaselineCompiler: create BytecodeParser.
Josef Eisl <josef.eisl@jku.at>
parents:
14890
diff
changeset
|
496 OptimisticOptimizations optimisticOpts = OptimisticOptimizations.ALL; |
bd08e610e6f3
BaselineCompiler: create BytecodeParser.
Josef Eisl <josef.eisl@jku.at>
parents:
14890
diff
changeset
|
497 return baselineCompiler.generate(javaMethod, -1, getBackend(), new CompilationResult(), javaMethod, CompilationResultBuilderFactory.Default, optimisticOpts); |
14053
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
498 } catch (Throwable e) { |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
499 throw Debug.handle(e); |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
500 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
501 } |
a7f26a522439
Direct LIR generation: added alternative compilation path to GraalCompilerTest.
Josef Eisl <josef.eisl@jku.at>
parents:
14014
diff
changeset
|
502 |
8233
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
503 protected void checkArgs(ResolvedJavaMethod method, Object[] args) { |
16486
d3fc4779fc60
moved signatureToTypes(ResolvedJavaMethod method) from MetaUtil to be a default method in ResolvedJavaMethod
Doug Simon <doug.simon@oracle.com>
parents:
16480
diff
changeset
|
504 JavaType[] sig = method.toParameterTypes(); |
8233
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
505 Assert.assertEquals(sig.length, args.length); |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
506 for (int i = 0; i < args.length; i++) { |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
507 JavaType javaType = sig[i]; |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
508 Kind kind = javaType.getKind(); |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
509 Object arg = args[i]; |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
510 if (kind == Kind.Object) { |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
511 if (arg != null && javaType instanceof ResolvedJavaType) { |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
512 ResolvedJavaType resolvedJavaType = (ResolvedJavaType) javaType; |
12362
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
513 Assert.assertTrue(resolvedJavaType + " from " + getMetaAccess().lookupJavaType(arg.getClass()), resolvedJavaType.isAssignableFrom(getMetaAccess().lookupJavaType(arg.getClass()))); |
8233
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
514 } |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
515 } else { |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
516 Assert.assertNotNull(arg); |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
517 Assert.assertEquals(kind.toBoxedJavaClass(), arg.getClass()); |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
518 } |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
519 } |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
520 } |
9484e7602276
GraalCompilerTest should assert that parameters passed to executeActual have the right type.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8232
diff
changeset
|
521 |
7282
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
522 /** |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
523 * Prepends a non-null receiver argument to a given list or args. |
14919
bd08e610e6f3
BaselineCompiler: create BytecodeParser.
Josef Eisl <josef.eisl@jku.at>
parents:
14890
diff
changeset
|
524 * |
7282
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
525 * @param receiver the receiver argument to prepend if it is non-null |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
526 */ |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
527 protected Object[] argsWithReceiver(Object receiver, Object... args) { |
6370
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
528 Object[] executeArgs; |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
529 if (receiver == null) { |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
530 executeArgs = args; |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
531 } else { |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
532 executeArgs = new Object[args.length + 1]; |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
533 executeArgs[0] = receiver; |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
534 for (int i = 0; i < args.length; i++) { |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
535 executeArgs[i + 1] = args[i]; |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
536 } |
703a6ab8ca82
added support for multi-threaded compiler tests
Doug Simon <doug.simon@oracle.com>
parents:
6334
diff
changeset
|
537 } |
7282
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
538 return executeArgs; |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
539 } |
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
540 |
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
541 protected void test(String name, Object... args) { |
13647
8edc6b0779f0
suppress the exception raised by Junit's "assume" mechanism in GraalCompilerTest.test()
Doug Simon <doug.simon@oracle.com>
parents:
13622
diff
changeset
|
542 try { |
8edc6b0779f0
suppress the exception raised by Junit's "assume" mechanism in GraalCompilerTest.test()
Doug Simon <doug.simon@oracle.com>
parents:
13622
diff
changeset
|
543 Method method = getMethod(name); |
8edc6b0779f0
suppress the exception raised by Junit's "assume" mechanism in GraalCompilerTest.test()
Doug Simon <doug.simon@oracle.com>
parents:
13622
diff
changeset
|
544 Object receiver = Modifier.isStatic(method.getModifiers()) ? null : this; |
8edc6b0779f0
suppress the exception raised by Junit's "assume" mechanism in GraalCompilerTest.test()
Doug Simon <doug.simon@oracle.com>
parents:
13622
diff
changeset
|
545 test(method, receiver, args); |
8edc6b0779f0
suppress the exception raised by Junit's "assume" mechanism in GraalCompilerTest.test()
Doug Simon <doug.simon@oracle.com>
parents:
13622
diff
changeset
|
546 } catch (AssumptionViolatedException e) { |
8edc6b0779f0
suppress the exception raised by Junit's "assume" mechanism in GraalCompilerTest.test()
Doug Simon <doug.simon@oracle.com>
parents:
13622
diff
changeset
|
547 // Suppress so that subsequent calls to this method within the |
8edc6b0779f0
suppress the exception raised by Junit's "assume" mechanism in GraalCompilerTest.test()
Doug Simon <doug.simon@oracle.com>
parents:
13622
diff
changeset
|
548 // same Junit @Test annotated method can proceed. |
8edc6b0779f0
suppress the exception raised by Junit's "assume" mechanism in GraalCompilerTest.test()
Doug Simon <doug.simon@oracle.com>
parents:
13622
diff
changeset
|
549 } |
8232
ab374f69e4e8
JTTTest gets the expeted result only once
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8217
diff
changeset
|
550 } |
ab374f69e4e8
JTTTest gets the expeted result only once
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8217
diff
changeset
|
551 |
ab374f69e4e8
JTTTest gets the expeted result only once
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8217
diff
changeset
|
552 protected void test(Method method, Object receiver, Object... args) { |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
553 Result expect = executeExpected(method, receiver, args); |
11959
23ccaa863eda
made CodeCacheProvider independent of MetaAccessProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
11740
diff
changeset
|
554 if (getCodeCache() == null) { |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
555 return; |
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
556 } |
11405
25161615539b
method rename to avoid ambiguous overloading
Doug Simon <doug.simon@oracle.com>
parents:
11316
diff
changeset
|
557 testAgainstExpected(method, expect, receiver, args); |
8232
ab374f69e4e8
JTTTest gets the expeted result only once
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8217
diff
changeset
|
558 } |
ab374f69e4e8
JTTTest gets the expeted result only once
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8217
diff
changeset
|
559 |
11405
25161615539b
method rename to avoid ambiguous overloading
Doug Simon <doug.simon@oracle.com>
parents:
11316
diff
changeset
|
560 protected void testAgainstExpected(Method method, Result expect, Object receiver, Object... args) { |
25161615539b
method rename to avoid ambiguous overloading
Doug Simon <doug.simon@oracle.com>
parents:
11316
diff
changeset
|
561 testAgainstExpected(method, expect, Collections.<DeoptimizationReason> emptySet(), receiver, args); |
9682
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
562 } |
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
563 |
10030
85f926430ae6
Test deoptimization in DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10019
diff
changeset
|
564 protected Result executeActualCheckDeopt(Method method, Set<DeoptimizationReason> shouldNotDeopt, Object receiver, Object... args) { |
9682
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
565 Map<DeoptimizationReason, Integer> deoptCounts = new EnumMap<>(DeoptimizationReason.class); |
12362
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
566 ResolvedJavaMethod javaMethod = getMetaAccess().lookupJavaMethod(method); |
11316
33ea8e2addac
Fix GraalCompilerTest deopt checks: need to re-aquire the profile after running the method since the MethodData may not be present before running it.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
11259
diff
changeset
|
567 ProfilingInfo profile = javaMethod.getProfilingInfo(); |
9682
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
568 for (DeoptimizationReason reason : shouldNotDeopt) { |
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
569 deoptCounts.put(reason, profile.getDeoptimizationCount(reason)); |
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
570 } |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
571 Result actual = executeActual(method, receiver, args); |
11316
33ea8e2addac
Fix GraalCompilerTest deopt checks: need to re-aquire the profile after running the method since the MethodData may not be present before running it.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
11259
diff
changeset
|
572 profile = javaMethod.getProfilingInfo(); // profile can change after execution |
9682
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
573 for (DeoptimizationReason reason : shouldNotDeopt) { |
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
574 Assert.assertEquals((int) deoptCounts.get(reason), profile.getDeoptimizationCount(reason)); |
86d24f120b78
Allow tests to check for deoptimizations, provide Method object in before hook.
Roland Schatz <roland.schatz@oracle.com>
parents:
9621
diff
changeset
|
575 } |
10030
85f926430ae6
Test deoptimization in DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10019
diff
changeset
|
576 return actual; |
85f926430ae6
Test deoptimization in DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10019
diff
changeset
|
577 } |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
578 |
10030
85f926430ae6
Test deoptimization in DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10019
diff
changeset
|
579 protected void assertEquals(Result expect, Result actual) { |
6447
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
580 if (expect.exception != null) { |
d7bcbdf4749c
minor restructuring of GraalCompilerTest
Doug Simon <doug.simon@oracle.com>
parents:
6431
diff
changeset
|
581 Assert.assertTrue("expected " + expect.exception, actual.exception != null); |
13580
8958eb3ff6b9
GraalCompilerTest: add messages to exception comparison asserts to make JUnit output clearer
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
13579
diff
changeset
|
582 Assert.assertEquals("Exception class", expect.exception.getClass(), actual.exception.getClass()); |
8958eb3ff6b9
GraalCompilerTest: add messages to exception comparison asserts to make JUnit output clearer
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
13579
diff
changeset
|
583 Assert.assertEquals("Exception message", expect.exception.getMessage(), actual.exception.getMessage()); |
5557
2e2a77f091f2
re-enabled disassembler output to C1Visualizer after code installation
Doug Simon <doug.simon@oracle.com>
parents:
5546
diff
changeset
|
584 } else { |
8232
ab374f69e4e8
JTTTest gets the expeted result only once
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8217
diff
changeset
|
585 if (actual.exception != null) { |
ab374f69e4e8
JTTTest gets the expeted result only once
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8217
diff
changeset
|
586 actual.exception.printStackTrace(); |
ab374f69e4e8
JTTTest gets the expeted result only once
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8217
diff
changeset
|
587 Assert.fail("expected " + expect.returnValue + " but got an exception"); |
ab374f69e4e8
JTTTest gets the expeted result only once
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
8217
diff
changeset
|
588 } |
15622
7b09605b29c5
renamed GraalTest.assertEquals* to assertDeepEquals to avoid confusion with JUnit API methods
Doug Simon <doug.simon@oracle.com>
parents:
15612
diff
changeset
|
589 assertDeepEquals(expect.returnValue, actual.returnValue); |
5557
2e2a77f091f2
re-enabled disassembler output to C1Visualizer after code installation
Doug Simon <doug.simon@oracle.com>
parents:
5546
diff
changeset
|
590 } |
2e2a77f091f2
re-enabled disassembler output to C1Visualizer after code installation
Doug Simon <doug.simon@oracle.com>
parents:
5546
diff
changeset
|
591 } |
2e2a77f091f2
re-enabled disassembler output to C1Visualizer after code installation
Doug Simon <doug.simon@oracle.com>
parents:
5546
diff
changeset
|
592 |
11405
25161615539b
method rename to avoid ambiguous overloading
Doug Simon <doug.simon@oracle.com>
parents:
11316
diff
changeset
|
593 protected void testAgainstExpected(Method method, Result expect, Set<DeoptimizationReason> shouldNotDeopt, Object receiver, Object... args) { |
10030
85f926430ae6
Test deoptimization in DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10019
diff
changeset
|
594 Result actual = executeActualCheckDeopt(method, shouldNotDeopt, receiver, args); |
85f926430ae6
Test deoptimization in DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10019
diff
changeset
|
595 assertEquals(expect, actual); |
85f926430ae6
Test deoptimization in DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10019
diff
changeset
|
596 } |
85f926430ae6
Test deoptimization in DynamicNewArrayNode.
Roland Schatz <roland.schatz@oracle.com>
parents:
10019
diff
changeset
|
597 |
5650
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
598 private Map<ResolvedJavaMethod, InstalledCode> cache = new HashMap<>(); |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
599 |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
600 /** |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
601 * Gets installed code for a given method and graph, compiling it first if necessary. |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
602 */ |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
603 protected InstalledCode getCode(final ResolvedJavaMethod method, final StructuredGraph graph) { |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
604 return getCode(method, graph, false); |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
605 } |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
606 |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
607 /** |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
608 * Gets installed code for a given method and graph, compiling it first if necessary. |
14919
bd08e610e6f3
BaselineCompiler: create BytecodeParser.
Josef Eisl <josef.eisl@jku.at>
parents:
14890
diff
changeset
|
609 * |
7530
5e3d1a68664e
applied mx eclipseformat to all Java files
Doug Simon <doug.simon@oracle.com>
parents:
7321
diff
changeset
|
610 * @param forceCompile specifies whether to ignore any previous code cached for the (method, |
5e3d1a68664e
applied mx eclipseformat to all Java files
Doug Simon <doug.simon@oracle.com>
parents:
7321
diff
changeset
|
611 * key) pair |
5650
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
612 */ |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
613 protected InstalledCode getCode(final ResolvedJavaMethod method, final StructuredGraph graph, boolean forceCompile) { |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
614 if (!forceCompile) { |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
615 InstalledCode cached = cache.get(method); |
7028
0353b031235a
added tests for instanceof with array types
Doug Simon <doug.simon@oracle.com>
parents:
6676
diff
changeset
|
616 if (cached != null) { |
0353b031235a
added tests for instanceof with array types
Doug Simon <doug.simon@oracle.com>
parents:
6676
diff
changeset
|
617 if (cached.isValid()) { |
0353b031235a
added tests for instanceof with array types
Doug Simon <doug.simon@oracle.com>
parents:
6676
diff
changeset
|
618 return cached; |
0353b031235a
added tests for instanceof with array types
Doug Simon <doug.simon@oracle.com>
parents:
6676
diff
changeset
|
619 } |
5650
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
620 } |
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
621 } |
7154
5d0bb7d52783
changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents:
7123
diff
changeset
|
622 |
11740
a402610bc52b
made compilation ID allocation in tests be atomic
Doug Simon <doug.simon@oracle.com>
parents:
11738
diff
changeset
|
623 final int id = compilationId.incrementAndGet(); |
7154
5d0bb7d52783
changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents:
7123
diff
changeset
|
624 |
13197
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
625 InstalledCode installedCode = null; |
14622
aff1511f13a9
added AllocSpy tool for analyzing allocation in Graal using the Java Allocation Instrumenter (https://code.google.com/p/java-allocation-instrumenter/)
Doug Simon <doug.simon@oracle.com>
parents:
14620
diff
changeset
|
626 try (AllocSpy spy = AllocSpy.open(method); Scope ds = Debug.scope("Compiling", new DebugDumpScope(String.valueOf(id), true))) { |
13197
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
627 final boolean printCompilation = PrintCompilation.getValue() && !TTY.isSuppressed(); |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
628 if (printCompilation) { |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
629 TTY.println(String.format("@%-6d Graal %-70s %-45s %-50s ...", id, method.getDeclaringClass().getName(), method.getName(), method.getSignature())); |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
630 } |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
631 long start = System.currentTimeMillis(); |
13622
02d3cfc90603
made GraalCompilerTest slightly more extensible
Doug Simon <doug.simon@oracle.com>
parents:
13612
diff
changeset
|
632 CompilationResult compResult = compile(method, graph); |
13197
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
633 if (printCompilation) { |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
634 TTY.println(String.format("@%-6d Graal %-70s %-45s %-50s | %4dms %5dB", id, "", "", "", System.currentTimeMillis() - start, compResult.getTargetCodeSize())); |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
635 } |
9767
e415e58e0db2
changed location of debug scope so that a subclass that overrides 'addMethod' still matches -G:Dump=CodeInstall option
Doug Simon <doug.simon@oracle.com>
parents:
9682
diff
changeset
|
636 |
13197
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
637 try (Scope s = Debug.scope("CodeInstall", getCodeCache(), method)) { |
13233
8ea51438445c
consolidated logging and dumping of InstalledCode to HotSpotCodeCacheProvider
Doug Simon <doug.simon@oracle.com>
parents:
13229
diff
changeset
|
638 installedCode = addMethod(method, compResult); |
8ea51438445c
consolidated logging and dumping of InstalledCode to HotSpotCodeCacheProvider
Doug Simon <doug.simon@oracle.com>
parents:
13229
diff
changeset
|
639 if (installedCode == null) { |
16480
10c12d09a8d2
moved format(String format, JavaMethod method) from MetaUtil to be a default method in JavaMethod
Doug Simon <doug.simon@oracle.com>
parents:
16199
diff
changeset
|
640 throw new GraalInternalError("Could not install code for " + method.format("%H.%n(%p)")); |
13197
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
641 } |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
642 } catch (Throwable e) { |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
643 throw Debug.handle(e); |
5433
d7b5cc23945e
refactored tests to share support for dump-aware compilation
Doug Simon <doug.simon@oracle.com>
parents:
5425
diff
changeset
|
644 } |
13197
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
645 } catch (Throwable e) { |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
646 throw Debug.handle(e); |
8569b9e047cd
change debug scopes implementation to prevent extra frames related to mechanism being added to call stack
Doug Simon <doug.simon@oracle.com>
parents:
13132
diff
changeset
|
647 } |
7154
5d0bb7d52783
changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents:
7123
diff
changeset
|
648 |
7282
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
649 if (!forceCompile) { |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
650 cache.put(method, installedCode); |
390448a6b535
converted the JTT tests to use the GraalCompilerTest framework which offers more control over what is compiled and executed
Doug Simon <doug.simon@oracle.com>
parents:
7260
diff
changeset
|
651 } |
5650
8d420cfd2a6f
added unit tests for the Word type
Doug Simon <doug.simon@oracle.com>
parents:
5599
diff
changeset
|
652 return installedCode; |
5433
d7b5cc23945e
refactored tests to share support for dump-aware compilation
Doug Simon <doug.simon@oracle.com>
parents:
5425
diff
changeset
|
653 } |
d7b5cc23945e
refactored tests to share support for dump-aware compilation
Doug Simon <doug.simon@oracle.com>
parents:
5425
diff
changeset
|
654 |
13622
02d3cfc90603
made GraalCompilerTest slightly more extensible
Doug Simon <doug.simon@oracle.com>
parents:
13612
diff
changeset
|
655 protected CompilationResult compile(ResolvedJavaMethod method, final StructuredGraph graph) { |
02d3cfc90603
made GraalCompilerTest slightly more extensible
Doug Simon <doug.simon@oracle.com>
parents:
13612
diff
changeset
|
656 CallingConvention cc = getCallingConvention(getCodeCache(), Type.JavaCallee, graph.method(), false); |
14142
4eac66a9b87d
Remove reference to graph in LIRGenerator.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
14127
diff
changeset
|
657 return compileGraph(graph, null, cc, method, getProviders(), getBackend(), getCodeCache().getTarget(), null, getDefaultGraphBuilderSuite(), OptimisticOptimizations.ALL, |
14143
8836f566b0bc
Remove withScope parameter on GraalCompiler.compileGraph.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
14142
diff
changeset
|
658 getProfilingInfo(graph), getSpeculationLog(), getSuites(), new CompilationResult(), CompilationResultBuilderFactory.Default); |
13773
e7c2351ed7d5
Throw-away speculation logs should not be used. Just use null instead
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
13690
diff
changeset
|
659 } |
e7c2351ed7d5
Throw-away speculation logs should not be used. Just use null instead
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
13690
diff
changeset
|
660 |
e7c2351ed7d5
Throw-away speculation logs should not be used. Just use null instead
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
13690
diff
changeset
|
661 protected SpeculationLog getSpeculationLog() { |
e7c2351ed7d5
Throw-away speculation logs should not be used. Just use null instead
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
13690
diff
changeset
|
662 return null; |
13622
02d3cfc90603
made GraalCompilerTest slightly more extensible
Doug Simon <doug.simon@oracle.com>
parents:
13612
diff
changeset
|
663 } |
02d3cfc90603
made GraalCompilerTest slightly more extensible
Doug Simon <doug.simon@oracle.com>
parents:
13612
diff
changeset
|
664 |
10019
6e4b72bcc97f
Remove graph from HotSpotNMethod
Christos Kotselidis <christos.kotselidis@oracle.com>
parents:
9969
diff
changeset
|
665 protected InstalledCode addMethod(final ResolvedJavaMethod method, final CompilationResult compResult) { |
15162
dbb1fe8348e6
Allow to supply predefined installed code object when adding a method to the code cache.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
15018
diff
changeset
|
666 return getCodeCache().addMethod(method, compResult, null, null); |
5360
6cc970203f30
moved creation of a RiCodeInfo to the runtime side of the CRI
Doug Simon <doug.simon@oracle.com>
parents:
5122
diff
changeset
|
667 } |
6cc970203f30
moved creation of a RiCodeInfo to the runtime side of the CRI
Doug Simon <doug.simon@oracle.com>
parents:
5122
diff
changeset
|
668 |
4340
5caca26cb1b9
small fix (missing changes)
Lukas Stadler <lukas.stadler@jku.at>
parents:
4315
diff
changeset
|
669 /** |
5caca26cb1b9
small fix (missing changes)
Lukas Stadler <lukas.stadler@jku.at>
parents:
4315
diff
changeset
|
670 * Parses a Java method to produce a graph. |
14919
bd08e610e6f3
BaselineCompiler: create BytecodeParser.
Josef Eisl <josef.eisl@jku.at>
parents:
14890
diff
changeset
|
671 * |
4340
5caca26cb1b9
small fix (missing changes)
Lukas Stadler <lukas.stadler@jku.at>
parents:
4315
diff
changeset
|
672 * @param methodName the name of the method in {@code this.getClass()} to be parsed |
5caca26cb1b9
small fix (missing changes)
Lukas Stadler <lukas.stadler@jku.at>
parents:
4315
diff
changeset
|
673 */ |
5caca26cb1b9
small fix (missing changes)
Lukas Stadler <lukas.stadler@jku.at>
parents:
4315
diff
changeset
|
674 protected StructuredGraph parseProfiled(String methodName) { |
4993
897b7d18bebc
added RiCompiledMethod.execute and the required VM infrastructure
Lukas Stadler <lukas.stadler@jku.at>
parents:
4410
diff
changeset
|
675 return parseProfiled(getMethod(methodName)); |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
676 } |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
677 |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
678 /** |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
679 * Parses a Java method to produce a graph. |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
680 */ |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
681 protected StructuredGraph parse(Method m) { |
13612
8c019a9beb16
use graph builder suite for compiler tests
Lukas Stadler <lukas.stadler@jku.at>
parents:
13585
diff
changeset
|
682 return parse0(m, getCustomGraphBuilderSuite(GraphBuilderConfiguration.getEagerDefault())); |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
683 } |
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
684 |
4340
5caca26cb1b9
small fix (missing changes)
Lukas Stadler <lukas.stadler@jku.at>
parents:
4315
diff
changeset
|
685 /** |
5caca26cb1b9
small fix (missing changes)
Lukas Stadler <lukas.stadler@jku.at>
parents:
4315
diff
changeset
|
686 * Parses a Java method to produce a graph. |
5caca26cb1b9
small fix (missing changes)
Lukas Stadler <lukas.stadler@jku.at>
parents:
4315
diff
changeset
|
687 */ |
5caca26cb1b9
small fix (missing changes)
Lukas Stadler <lukas.stadler@jku.at>
parents:
4315
diff
changeset
|
688 protected StructuredGraph parseProfiled(Method m) { |
13612
8c019a9beb16
use graph builder suite for compiler tests
Lukas Stadler <lukas.stadler@jku.at>
parents:
13585
diff
changeset
|
689 return parse0(m, getDefaultGraphBuilderSuite()); |
9003
a8fea2979e63
eager infopoint mode (fka debug mode)
Michael Haupt <michael.haupt@oracle.com>
parents:
8637
diff
changeset
|
690 } |
a8fea2979e63
eager infopoint mode (fka debug mode)
Michael Haupt <michael.haupt@oracle.com>
parents:
8637
diff
changeset
|
691 |
a8fea2979e63
eager infopoint mode (fka debug mode)
Michael Haupt <michael.haupt@oracle.com>
parents:
8637
diff
changeset
|
692 /** |
a8fea2979e63
eager infopoint mode (fka debug mode)
Michael Haupt <michael.haupt@oracle.com>
parents:
8637
diff
changeset
|
693 * Parses a Java method in debug mode to produce a graph with extra infopoints. |
a8fea2979e63
eager infopoint mode (fka debug mode)
Michael Haupt <michael.haupt@oracle.com>
parents:
8637
diff
changeset
|
694 */ |
a8fea2979e63
eager infopoint mode (fka debug mode)
Michael Haupt <michael.haupt@oracle.com>
parents:
8637
diff
changeset
|
695 protected StructuredGraph parseDebug(Method m) { |
16573
a2ec1ac769e4
Add simple infopoint nodes which do not contain debugging informations for values. Use them when shouldDebugNonSafepoints is true.
Gilles Duboscq <duboscq@ssw.jku.at>
parents:
16526
diff
changeset
|
696 return parse0(m, getCustomGraphBuilderSuite(GraphBuilderConfiguration.getFullDebugDefault())); |
9003
a8fea2979e63
eager infopoint mode (fka debug mode)
Michael Haupt <michael.haupt@oracle.com>
parents:
8637
diff
changeset
|
697 } |
a8fea2979e63
eager infopoint mode (fka debug mode)
Michael Haupt <michael.haupt@oracle.com>
parents:
8637
diff
changeset
|
698 |
13612
8c019a9beb16
use graph builder suite for compiler tests
Lukas Stadler <lukas.stadler@jku.at>
parents:
13585
diff
changeset
|
699 private StructuredGraph parse0(Method m, PhaseSuite<HighTierContext> graphBuilderSuite) { |
10764
d2f8addaf504
assertion in GraalCompiler (don't parse @Test methods)
Lukas Stadler <lukas.stadler@jku.at>
parents:
10577
diff
changeset
|
700 assert m.getAnnotation(Test.class) == null : "shouldn't parse method with @Test annotation: " + m; |
12362
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
701 ResolvedJavaMethod javaMethod = getMetaAccess().lookupJavaMethod(m); |
16713
47f9c47145fd
added "Parsing" debug scope in GraalCompilerTest.parse0
Doug Simon <doug.simon@oracle.com>
parents:
16573
diff
changeset
|
702 try (Scope ds = Debug.scope("Parsing", javaMethod)) { |
47f9c47145fd
added "Parsing" debug scope in GraalCompilerTest.parse0
Doug Simon <doug.simon@oracle.com>
parents:
16573
diff
changeset
|
703 StructuredGraph graph = new StructuredGraph(javaMethod); |
47f9c47145fd
added "Parsing" debug scope in GraalCompilerTest.parse0
Doug Simon <doug.simon@oracle.com>
parents:
16573
diff
changeset
|
704 graphBuilderSuite.apply(graph, new HighTierContext(providers, null, null, graphBuilderSuite, OptimisticOptimizations.ALL)); |
47f9c47145fd
added "Parsing" debug scope in GraalCompilerTest.parse0
Doug Simon <doug.simon@oracle.com>
parents:
16573
diff
changeset
|
705 return graph; |
47f9c47145fd
added "Parsing" debug scope in GraalCompilerTest.parse0
Doug Simon <doug.simon@oracle.com>
parents:
16573
diff
changeset
|
706 } |
4340
5caca26cb1b9
small fix (missing changes)
Lukas Stadler <lukas.stadler@jku.at>
parents:
4315
diff
changeset
|
707 } |
5caca26cb1b9
small fix (missing changes)
Lukas Stadler <lukas.stadler@jku.at>
parents:
4315
diff
changeset
|
708 |
13585 | 709 protected PhaseSuite<HighTierContext> getDefaultGraphBuilderSuite() { |
710 // defensive copying | |
711 return backend.getSuites().getDefaultGraphBuilderSuite().copy(); | |
9003
a8fea2979e63
eager infopoint mode (fka debug mode)
Michael Haupt <michael.haupt@oracle.com>
parents:
8637
diff
changeset
|
712 } |
a8fea2979e63
eager infopoint mode (fka debug mode)
Michael Haupt <michael.haupt@oracle.com>
parents:
8637
diff
changeset
|
713 |
13612
8c019a9beb16
use graph builder suite for compiler tests
Lukas Stadler <lukas.stadler@jku.at>
parents:
13585
diff
changeset
|
714 protected PhaseSuite<HighTierContext> getCustomGraphBuilderSuite(GraphBuilderConfiguration gbConf) { |
13585 | 715 PhaseSuite<HighTierContext> suite = getDefaultGraphBuilderSuite().copy(); |
716 ListIterator<BasePhase<? super HighTierContext>> iterator = suite.findPhase(GraphBuilderPhase.class); | |
717 iterator.remove(); | |
718 iterator.add(new GraphBuilderPhase(gbConf)); | |
719 return suite; | |
4204
4df4499e0289
Fixed unit tests.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
4203
diff
changeset
|
720 } |
12054
bba234a1670e
grouped provider values/parameters into a Providers object (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12052
diff
changeset
|
721 |
bba234a1670e
grouped provider values/parameters into a Providers object (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12052
diff
changeset
|
722 protected Replacements getReplacements() { |
12362
f53dc8bbb88c
refactored isReexecutable(), getKilledLocations() and canDeoptimize() out of MetaAccessProvider into ForeignCallsProvider (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12054
diff
changeset
|
723 return getProviders().getReplacements(); |
12054
bba234a1670e
grouped provider values/parameters into a Providers object (GRAAL-511)
Doug Simon <doug.simon@oracle.com>
parents:
12052
diff
changeset
|
724 } |
14014
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
725 |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
726 /** |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
727 * Inject a probability for a branch condition into the profiling information of this test case. |
14919
bd08e610e6f3
BaselineCompiler: create BytecodeParser.
Josef Eisl <josef.eisl@jku.at>
parents:
14890
diff
changeset
|
728 * |
14014
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
729 * @param p the probability that cond is true |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
730 * @param cond the condition of the branch |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
731 * @return cond |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
732 */ |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
733 protected static boolean branchProbability(double p, boolean cond) { |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
734 return cond; |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
735 } |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
736 |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
737 /** |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
738 * Inject an iteration count for a loop condition into the profiling information of this test |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
739 * case. |
14919
bd08e610e6f3
BaselineCompiler: create BytecodeParser.
Josef Eisl <josef.eisl@jku.at>
parents:
14890
diff
changeset
|
740 * |
14014
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
741 * @param i the iteration count of the loop |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
742 * @param cond the condition of the loop |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
743 * @return cond |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
744 */ |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
745 protected static boolean iterationCount(double i, boolean cond) { |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
746 return cond; |
ac599fff18dc
Substitution methods for injecting fake profiling data into unit tests.
Roland Schatz <roland.schatz@oracle.com>
parents:
13773
diff
changeset
|
747 } |
16517
cb70055faeeb
[SPARC/AMD64] Ignore AllocatorTest when the platform does not match.
Stefan Anzinger <stefan.anzinger@gmail.com>
parents:
16199
diff
changeset
|
748 |
cb70055faeeb
[SPARC/AMD64] Ignore AllocatorTest when the platform does not match.
Stefan Anzinger <stefan.anzinger@gmail.com>
parents:
16199
diff
changeset
|
749 /** |
cb70055faeeb
[SPARC/AMD64] Ignore AllocatorTest when the platform does not match.
Stefan Anzinger <stefan.anzinger@gmail.com>
parents:
16199
diff
changeset
|
750 * Test if the current test runs on the given platform. The name must match the name given in |
cb70055faeeb
[SPARC/AMD64] Ignore AllocatorTest when the platform does not match.
Stefan Anzinger <stefan.anzinger@gmail.com>
parents:
16199
diff
changeset
|
751 * the {@link Architecture#getName()}. |
cb70055faeeb
[SPARC/AMD64] Ignore AllocatorTest when the platform does not match.
Stefan Anzinger <stefan.anzinger@gmail.com>
parents:
16199
diff
changeset
|
752 * |
cb70055faeeb
[SPARC/AMD64] Ignore AllocatorTest when the platform does not match.
Stefan Anzinger <stefan.anzinger@gmail.com>
parents:
16199
diff
changeset
|
753 * @param name The name to test |
cb70055faeeb
[SPARC/AMD64] Ignore AllocatorTest when the platform does not match.
Stefan Anzinger <stefan.anzinger@gmail.com>
parents:
16199
diff
changeset
|
754 * @return true if we run on the architecture given by name |
cb70055faeeb
[SPARC/AMD64] Ignore AllocatorTest when the platform does not match.
Stefan Anzinger <stefan.anzinger@gmail.com>
parents:
16199
diff
changeset
|
755 */ |
cb70055faeeb
[SPARC/AMD64] Ignore AllocatorTest when the platform does not match.
Stefan Anzinger <stefan.anzinger@gmail.com>
parents:
16199
diff
changeset
|
756 protected boolean isArchitecture(String name) { |
cb70055faeeb
[SPARC/AMD64] Ignore AllocatorTest when the platform does not match.
Stefan Anzinger <stefan.anzinger@gmail.com>
parents:
16199
diff
changeset
|
757 return name.equals(backend.getTarget().arch.getName()); |
cb70055faeeb
[SPARC/AMD64] Ignore AllocatorTest when the platform does not match.
Stefan Anzinger <stefan.anzinger@gmail.com>
parents:
16199
diff
changeset
|
758 } |
3733
e233f5660da4
Added Java files from Maxine project.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
diff
changeset
|
759 } |