mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-21 11:34:38 +02:00
6901572: JVM 1.6.16 crash on loops: assert(has_node(i),"")
Skip the secondary induction variable handling if it is dead Reviewed-by: never, kvn
This commit is contained in:
parent
b5e3a7a597
commit
8a9580b1a1
2 changed files with 57 additions and 1 deletions
|
@ -1279,7 +1279,8 @@ void IdealLoopTree::counted_loop( PhaseIdealLoop *phase ) {
|
||||||
// Visit all children, looking for Phis
|
// Visit all children, looking for Phis
|
||||||
for (DUIterator i = cl->outs(); cl->has_out(i); i++) {
|
for (DUIterator i = cl->outs(); cl->has_out(i); i++) {
|
||||||
Node *out = cl->out(i);
|
Node *out = cl->out(i);
|
||||||
if (!out->is_Phi() || out == phi) continue; // Looking for other phis
|
// Look for other phis (secondary IVs). Skip dead ones
|
||||||
|
if (!out->is_Phi() || out == phi || !phase->has_node(out)) continue;
|
||||||
PhiNode* phi2 = out->as_Phi();
|
PhiNode* phi2 = out->as_Phi();
|
||||||
Node *incr2 = phi2->in( LoopNode::LoopBackControl );
|
Node *incr2 = phi2->in( LoopNode::LoopBackControl );
|
||||||
// Look for induction variables of the form: X += constant
|
// Look for induction variables of the form: X += constant
|
||||||
|
|
55
hotspot/test/compiler/6901572/Test.java
Normal file
55
hotspot/test/compiler/6901572/Test.java
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2009 Sun Microsystems, Inc. All Rights Reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||||
|
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||||
|
* have any questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @bug 6901572
|
||||||
|
* @summary JVM 1.6.16 crash on loops: assert(has_node(i),"")
|
||||||
|
*
|
||||||
|
* @run main/othervm Test
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
public class Test {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
for (int i = 0; i < 2; i++)
|
||||||
|
NestedLoop();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static long NestedLoop() {
|
||||||
|
final int n = 50;
|
||||||
|
long startTime = System.currentTimeMillis();
|
||||||
|
int x = 0;
|
||||||
|
for(int a = 0; a < n; a++)
|
||||||
|
for(int b = 0; b < n; b++)
|
||||||
|
for(int c = 0; c < n; c++)
|
||||||
|
for(int d = 0; d < n; d++)
|
||||||
|
for(int e = 0; e < n; e++)
|
||||||
|
for(int f = 0; f < n; f++)
|
||||||
|
x++;
|
||||||
|
long stopTime = System.currentTimeMillis();
|
||||||
|
|
||||||
|
return stopTime - startTime;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue