8020215: Different execution plan when using JIT vs interpreter
Fix bytecode analyzer Reviewed-by: twisti
This commit is contained in:
parent
93d49935a9
commit
2d3b117249
@ -138,6 +138,16 @@ bool BCEscapeAnalyzer::is_arg_stack(ArgumentMap vars){
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// return true if all argument elements of vars are returned
|
||||||
|
bool BCEscapeAnalyzer::returns_all(ArgumentMap vars) {
|
||||||
|
for (int i = 0; i < _arg_size; i++) {
|
||||||
|
if (vars.contains(i) && !_arg_returned.test(i)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
void BCEscapeAnalyzer::clear_bits(ArgumentMap vars, VectorSet &bm) {
|
void BCEscapeAnalyzer::clear_bits(ArgumentMap vars, VectorSet &bm) {
|
||||||
for (int i = 0; i < _arg_size; i++) {
|
for (int i = 0; i < _arg_size; i++) {
|
||||||
if (vars.contains(i)) {
|
if (vars.contains(i)) {
|
||||||
@ -166,6 +176,11 @@ void BCEscapeAnalyzer::set_global_escape(ArgumentMap vars, bool merge) {
|
|||||||
if (vars.contains_unknown() || vars.contains_vars()) {
|
if (vars.contains_unknown() || vars.contains_vars()) {
|
||||||
_return_allocated = false;
|
_return_allocated = false;
|
||||||
}
|
}
|
||||||
|
if (_return_local && vars.contains_vars() && !returns_all(vars)) {
|
||||||
|
// Return result should be invalidated if args in new
|
||||||
|
// state are not recorded in return state.
|
||||||
|
_return_local = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -80,6 +80,7 @@ class BCEscapeAnalyzer : public ResourceObj {
|
|||||||
void set_returned(ArgumentMap vars);
|
void set_returned(ArgumentMap vars);
|
||||||
bool is_argument(ArgumentMap vars);
|
bool is_argument(ArgumentMap vars);
|
||||||
bool is_arg_stack(ArgumentMap vars);
|
bool is_arg_stack(ArgumentMap vars);
|
||||||
|
bool returns_all(ArgumentMap vars);
|
||||||
void clear_bits(ArgumentMap vars, VectorSet &bs);
|
void clear_bits(ArgumentMap vars, VectorSet &bs);
|
||||||
void set_method_escape(ArgumentMap vars);
|
void set_method_escape(ArgumentMap vars);
|
||||||
void set_global_escape(ArgumentMap vars, bool merge = false);
|
void set_global_escape(ArgumentMap vars, bool merge = false);
|
||||||
|
82
hotspot/test/compiler/EscapeAnalysis/Test8020215.java
Normal file
82
hotspot/test/compiler/EscapeAnalysis/Test8020215.java
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2013, Oracle and/or its affiliates. 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 8020215
|
||||||
|
* @summary Different execution plan when using JIT vs interpreter
|
||||||
|
* @run main Test8020215
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class Test8020215 {
|
||||||
|
public static class NamedObject {
|
||||||
|
public int id;
|
||||||
|
public String name;
|
||||||
|
public NamedObject(int id, String name) {
|
||||||
|
this.id = id;
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class NamedObjectList {
|
||||||
|
public List<NamedObject> namedObjectList = new ArrayList<NamedObject>();
|
||||||
|
|
||||||
|
public NamedObject getBest(int id) {
|
||||||
|
NamedObject bestObject = null;
|
||||||
|
for (NamedObject o : namedObjectList) {
|
||||||
|
bestObject = id==o.id ? getBetter(bestObject, o) : bestObject;
|
||||||
|
}
|
||||||
|
return (bestObject != null) ? bestObject : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static NamedObject getBetter(NamedObject p1, NamedObject p2) {
|
||||||
|
return (p1 == null) ? p2 : (p2 == null) ? p1 : (p2.name.compareTo(p1.name) >= 0) ? p2 : p1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test(NamedObjectList b, int i) {
|
||||||
|
NamedObject x = b.getBest(2);
|
||||||
|
// test
|
||||||
|
if (x == null) {
|
||||||
|
throw new RuntimeException("x should never be null here! (i=" + i + ")");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
// setup
|
||||||
|
NamedObjectList b = new NamedObjectList();
|
||||||
|
for (int i = 0; i < 10000; i++) {
|
||||||
|
b.namedObjectList.add(new NamedObject(1, "2012-12-31"));
|
||||||
|
}
|
||||||
|
b.namedObjectList.add(new NamedObject(2, "2013-12-31"));
|
||||||
|
|
||||||
|
// execution
|
||||||
|
for (int i = 0; i < 12000; i++) {
|
||||||
|
test(b, i);
|
||||||
|
}
|
||||||
|
System.out.println("PASSED");
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user