annotate graal/GraalCompiler/src/com/sun/c1x/ir/Merge.java @ 2828:d6f3dbb4e3b5

merge
author Lukas Stadler <lukas.stadler@jku.at>
date Mon, 30 May 2011 18:47:33 +0200
parents bd17ac598c6e d54ea877a302
children 7596ae867a7b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
1 /*
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
2 * Copyright (c) 2009, 2011, Oracle and/or its affiliates. All rights reserved.
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
4 *
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
7 * published by the Free Software Foundation.
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
8 *
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
13 * accompanied this code).
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
14 *
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
18 *
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
21 * questions.
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
22 */
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
23 package com.sun.c1x.ir;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
24
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
25 import com.oracle.graal.graph.*;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
26 import com.sun.c1x.debug.*;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
27 import com.sun.c1x.util.*;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
28 import com.sun.c1x.value.*;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
29 import com.sun.cri.ci.*;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
30
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
31 /**
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
32 * Denotes the beginning of a basic block, and holds information
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
33 * about the basic block, including the successor and
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
34 * predecessor blocks, exception handlers, liveness information, etc.
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
35 */
2799
e1dad0edd57a first part of loop reworking
Lukas Stadler <lukas.stadler@jku.at>
parents: 2795
diff changeset
36 public class Merge extends StateSplit {
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
37
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
38 private static final int INPUT_COUNT = 0;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
39
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
40 private static final int SUCCESSOR_COUNT = 0;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
41
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
42 @Override
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
43 protected int inputCount() {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
44 return super.inputCount() + INPUT_COUNT;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
45 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
46
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
47 @Override
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
48 protected int successorCount() {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
49 return super.successorCount() + SUCCESSOR_COUNT;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
50 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
51
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
52 @Override
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
53 public boolean needsStateAfter() {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
54 return false;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
55 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
56
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
57 /**
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
58 * Constructs a new Merge at the specified bytecode index.
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
59 * @param bci the bytecode index of the start
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
60 * @param blockID the ID of the block
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
61 * @param graph
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
62 */
2799
e1dad0edd57a first part of loop reworking
Lukas Stadler <lukas.stadler@jku.at>
parents: 2795
diff changeset
63 public Merge(Graph graph) {
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
64 super(CiKind.Illegal, INPUT_COUNT, SUCCESSOR_COUNT, graph);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
65 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
66
2799
e1dad0edd57a first part of loop reworking
Lukas Stadler <lukas.stadler@jku.at>
parents: 2795
diff changeset
67 protected Merge(int inputCount, int successorCount, Graph graph) {
e1dad0edd57a first part of loop reworking
Lukas Stadler <lukas.stadler@jku.at>
parents: 2795
diff changeset
68 super(CiKind.Illegal, inputCount + INPUT_COUNT, successorCount + SUCCESSOR_COUNT, graph);
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
69 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
70
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
71 @Override
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
72 public void accept(ValueVisitor v) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
73 v.visitMerge(this);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
74 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
75
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
76 @Override
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
77 public String toString() {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
78 StringBuilder builder = new StringBuilder();
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
79 builder.append("merge #");
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
80 builder.append(id());
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
81 builder.append(" [");
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
82
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
83 builder.append("]");
2800
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
84
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
85 builder.append(" -> ");
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
86 boolean hasSucc = false;
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
87 for (Node s : this.successors()) {
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
88 if (hasSucc) {
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
89 builder.append(", ");
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
90 }
2800
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
91 builder.append("#");
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
92 if (s != null) {
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
93 builder.append(s.id());
2800
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
94 } else {
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
95 builder.append("null");
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
96 }
2800
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
97 hasSucc = true;
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
98 }
e3a0630a1dab added code for computing dominators.
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2795
diff changeset
99
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
100 return builder.toString();
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
101 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
102
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
103 public void printWithoutPhis(LogStream out) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
104 // print block id
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
105 out.print("B").print(id()).print(" ");
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
106
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
107 // print flags
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
108 StringBuilder sb = new StringBuilder(8);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
109 if (sb.length() != 0) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
110 out.print('(').print(sb.toString()).print(')');
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
111 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
112
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
113 // print block bci range
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
114 out.print('[').print(-1).print(", ").print(-1).print(']');
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
115
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
116 // print block successors
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
117 //if (end != null && end.blockSuccessors().size() > 0) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
118 out.print(" .");
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
119 for (Node successor : this.successors()) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
120 if (successor instanceof Value) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
121 out.print((Value) successor);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
122 } else {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
123 out.print(successor.toString());
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
124 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
125 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
126 //}
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
127
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
128 // print predecessors
2805
c3f64b66fc78 Towards removing the next pointer from Constant and ArithmeticOp
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2804
diff changeset
129 // if (!blockPredecessors().isEmpty()) {
c3f64b66fc78 Towards removing the next pointer from Constant and ArithmeticOp
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2804
diff changeset
130 // out.print(" pred:");
c3f64b66fc78 Towards removing the next pointer from Constant and ArithmeticOp
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2804
diff changeset
131 // for (Instruction pred : blockPredecessors()) {
c3f64b66fc78 Towards removing the next pointer from Constant and ArithmeticOp
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2804
diff changeset
132 // out.print(pred.block());
c3f64b66fc78 Towards removing the next pointer from Constant and ArithmeticOp
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2804
diff changeset
133 // }
c3f64b66fc78 Towards removing the next pointer from Constant and ArithmeticOp
Thomas Wuerthinger <thomas@wuerthinger.net>
parents: 2804
diff changeset
134 // }
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
135 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
136
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
137 @Override
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
138 public void print(LogStream out) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
139
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
140 printWithoutPhis(out);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
141
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
142 // print phi functions
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
143 boolean hasPhisInLocals = false;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
144 boolean hasPhisOnStack = false;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
145
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
146 //if (end() != null && end().stateAfter() != null) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
147 FrameState state = stateBefore();
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
148
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
149 int i = 0;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
150 while (!hasPhisOnStack && i < state.stackSize()) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
151 Value value = state.stackAt(i);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
152 hasPhisOnStack = isPhiAtBlock(value);
2821
015be60afcf3 removed flags from Value class
Lukas Stadler <lukas.stadler@jku.at>
parents: 2805
diff changeset
153 if (value != null && !(value instanceof Phi && ((Phi) value).isDead())) {
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
154 i += value.kind.sizeInSlots();
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
155 } else {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
156 i++;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
157 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
158 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
159
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
160 for (i = 0; !hasPhisInLocals && i < state.localsSize();) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
161 Value value = state.localAt(i);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
162 hasPhisInLocals = isPhiAtBlock(value);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
163 // also ignore illegal HiWords
2821
015be60afcf3 removed flags from Value class
Lukas Stadler <lukas.stadler@jku.at>
parents: 2805
diff changeset
164 if (value != null && !(value instanceof Phi && ((Phi) value).isDead())) {
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
165 i += value.kind.sizeInSlots();
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
166 } else {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
167 i++;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
168 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
169 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
170 //}
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
171
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
172 // print values in locals
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
173 if (hasPhisInLocals) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
174 out.println();
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
175 out.println("Locals:");
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
176
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
177 int j = 0;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
178 while (j < state.localsSize()) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
179 Value value = state.localAt(j);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
180 if (value != null) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
181 out.println(stateString(j, value));
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
182 // also ignore illegal HiWords
2821
015be60afcf3 removed flags from Value class
Lukas Stadler <lukas.stadler@jku.at>
parents: 2805
diff changeset
183 if (value instanceof Phi && ((Phi) value).isDead()) {
015be60afcf3 removed flags from Value class
Lukas Stadler <lukas.stadler@jku.at>
parents: 2805
diff changeset
184 j += 1;
015be60afcf3 removed flags from Value class
Lukas Stadler <lukas.stadler@jku.at>
parents: 2805
diff changeset
185 } else {
015be60afcf3 removed flags from Value class
Lukas Stadler <lukas.stadler@jku.at>
parents: 2805
diff changeset
186 j += value.kind.sizeInSlots();
015be60afcf3 removed flags from Value class
Lukas Stadler <lukas.stadler@jku.at>
parents: 2805
diff changeset
187 }
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
188 } else {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
189 j++;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
190 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
191 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
192 out.println();
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
193 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
194
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
195 // print values on stack
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
196 if (hasPhisOnStack) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
197 out.println();
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
198 out.println("Stack:");
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
199 int j = 0;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
200 while (j < stateBefore().stackSize()) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
201 Value value = stateBefore().stackAt(j);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
202 if (value != null) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
203 out.println(stateString(j, value));
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
204 j += value.kind.sizeInSlots();
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
205 } else {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
206 j++;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
207 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
208 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
209 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
210
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
211 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
212
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
213 /**
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
214 * Determines if a given instruction is a phi whose {@linkplain Phi#block() join block} is a given block.
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
215 *
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
216 * @param value the instruction to test
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
217 * @param block the block that may be the join block of {@code value} if {@code value} is a phi
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
218 * @return {@code true} if {@code value} is a phi and its join block is {@code block}
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
219 */
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
220 private boolean isPhiAtBlock(Value value) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
221 return value instanceof Phi && ((Phi) value).block() == this;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
222 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
223
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
224
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
225 /**
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
226 * Formats a given instruction as a value in a {@linkplain FrameState frame state}. If the instruction is a phi defined at a given
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
227 * block, its {@linkplain Phi#valueCount() inputs} are appended to the returned string.
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
228 *
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
229 * @param index the index of the value in the frame state
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
230 * @param value the frame state value
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
231 * @param block if {@code value} is a phi, then its inputs are formatted if {@code block} is its
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
232 * {@linkplain Phi#block() join point}
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
233 * @return the instruction representation as a string
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
234 */
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
235 public String stateString(int index, Value value) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
236 StringBuilder sb = new StringBuilder(30);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
237 sb.append(String.format("%2d %s", index, Util.valueString(value)));
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
238 if (value instanceof Phi) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
239 Phi phi = (Phi) value;
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
240 // print phi operands
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
241 if (phi.block() == this) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
242 sb.append(" [");
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
243 for (int j = 0; j < phi.valueCount(); j++) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
244 sb.append(' ');
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
245 Value operand = phi.valueAt(j);
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
246 if (operand != null) {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
247 sb.append(Util.valueString(operand));
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
248 } else {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
249 sb.append("NULL");
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
250 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
251 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
252 sb.append("] ");
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
253 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
254 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
255 return sb.toString();
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
256 }
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
257
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
258 @Override
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
259 public String shortName() {
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
260 return "Merge #" + id();
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
261 }
2828
Lukas Stadler <lukas.stadler@jku.at>
parents: 2827 2826
diff changeset
262
Lukas Stadler <lukas.stadler@jku.at>
parents: 2827 2826
diff changeset
263 @Override
2827
bd17ac598c6e Graph cloning, initial version (not completely working)
Lukas Stadler <lukas.stadler@jku.at>
parents: 2821
diff changeset
264 public Node copy(Graph into) {
bd17ac598c6e Graph cloning, initial version (not completely working)
Lukas Stadler <lukas.stadler@jku.at>
parents: 2821
diff changeset
265 assert getClass() == Merge.class : "copy of " + getClass();
bd17ac598c6e Graph cloning, initial version (not completely working)
Lukas Stadler <lukas.stadler@jku.at>
parents: 2821
diff changeset
266 Merge x = new Merge(into);
bd17ac598c6e Graph cloning, initial version (not completely working)
Lukas Stadler <lukas.stadler@jku.at>
parents: 2821
diff changeset
267 x.setNonNull(isNonNull());
bd17ac598c6e Graph cloning, initial version (not completely working)
Lukas Stadler <lukas.stadler@jku.at>
parents: 2821
diff changeset
268 return x;
bd17ac598c6e Graph cloning, initial version (not completely working)
Lukas Stadler <lukas.stadler@jku.at>
parents: 2821
diff changeset
269 }
2795
0fd105ff30f1 Add merge
Gilles Duboscq <gilles.duboscq@oracle.com>
parents:
diff changeset
270 }