mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-28 07:14:30 +02:00
8027572: assert(r != 0) failed: invalid
Null classes should be expected in profiles with conflicts Reviewed-by: kvn, iveresov
This commit is contained in:
parent
a5b4fba397
commit
3fbc683322
6 changed files with 129 additions and 9 deletions
|
@ -77,7 +77,9 @@ public:
|
||||||
static ciKlass* valid_ciklass(intptr_t k) {
|
static ciKlass* valid_ciklass(intptr_t k) {
|
||||||
if (!TypeEntries::is_type_none(k) &&
|
if (!TypeEntries::is_type_none(k) &&
|
||||||
!TypeEntries::is_type_unknown(k)) {
|
!TypeEntries::is_type_unknown(k)) {
|
||||||
return (ciKlass*)TypeEntries::klass_part(k);
|
ciKlass* res = (ciKlass*)TypeEntries::klass_part(k);
|
||||||
|
assert(res != NULL, "invalid");
|
||||||
|
return res;
|
||||||
} else {
|
} else {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2211,6 +2211,10 @@ void InstanceKlass::clean_method_data(BoolObjectClosure* is_alive) {
|
||||||
data = mdo->next_data(data)) {
|
data = mdo->next_data(data)) {
|
||||||
data->clean_weak_klass_links(is_alive);
|
data->clean_weak_klass_links(is_alive);
|
||||||
}
|
}
|
||||||
|
ParametersTypeData* parameters = mdo->parameters_type_data();
|
||||||
|
if (parameters != NULL) {
|
||||||
|
parameters->clean_weak_klass_links(is_alive);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -275,23 +275,23 @@ void VirtualCallTypeData::post_initialize(BytecodeStream* stream, MethodData* md
|
||||||
}
|
}
|
||||||
|
|
||||||
bool TypeEntries::is_loader_alive(BoolObjectClosure* is_alive_cl, intptr_t p) {
|
bool TypeEntries::is_loader_alive(BoolObjectClosure* is_alive_cl, intptr_t p) {
|
||||||
return !is_type_none(p) &&
|
Klass* k = (Klass*)klass_part(p);
|
||||||
!((Klass*)klass_part(p))->is_loader_alive(is_alive_cl);
|
return k != NULL && k->is_loader_alive(is_alive_cl);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TypeStackSlotEntries::clean_weak_klass_links(BoolObjectClosure* is_alive_cl) {
|
void TypeStackSlotEntries::clean_weak_klass_links(BoolObjectClosure* is_alive_cl) {
|
||||||
for (int i = 0; i < _number_of_entries; i++) {
|
for (int i = 0; i < _number_of_entries; i++) {
|
||||||
intptr_t p = type(i);
|
intptr_t p = type(i);
|
||||||
if (is_loader_alive(is_alive_cl, p)) {
|
if (!is_loader_alive(is_alive_cl, p)) {
|
||||||
set_type(i, type_none());
|
set_type(i, with_status((Klass*)NULL, p));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReturnTypeEntry::clean_weak_klass_links(BoolObjectClosure* is_alive_cl) {
|
void ReturnTypeEntry::clean_weak_klass_links(BoolObjectClosure* is_alive_cl) {
|
||||||
intptr_t p = type();
|
intptr_t p = type();
|
||||||
if (is_loader_alive(is_alive_cl, p)) {
|
if (!is_loader_alive(is_alive_cl, p)) {
|
||||||
set_type(type_none());
|
set_type(with_status((Klass*)NULL, p));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -690,7 +690,6 @@ public:
|
||||||
// recorded type: cell without bit 0 and 1
|
// recorded type: cell without bit 0 and 1
|
||||||
static intptr_t klass_part(intptr_t v) {
|
static intptr_t klass_part(intptr_t v) {
|
||||||
intptr_t r = v & type_klass_mask;
|
intptr_t r = v & type_klass_mask;
|
||||||
assert (r != 0, "invalid");
|
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -698,7 +697,9 @@ public:
|
||||||
static Klass* valid_klass(intptr_t k) {
|
static Klass* valid_klass(intptr_t k) {
|
||||||
if (!is_type_none(k) &&
|
if (!is_type_none(k) &&
|
||||||
!is_type_unknown(k)) {
|
!is_type_unknown(k)) {
|
||||||
return (Klass*)klass_part(k);
|
Klass* res = (Klass*)klass_part(k);
|
||||||
|
assert(res != NULL, "invalid");
|
||||||
|
return res;
|
||||||
} else {
|
} else {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
25
hotspot/test/compiler/profiling/unloadingconflict/B.java
Normal file
25
hotspot/test/compiler/profiling/unloadingconflict/B.java
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class B {
|
||||||
|
}
|
|
@ -0,0 +1,88 @@
|
||||||
|
/*
|
||||||
|
* 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 8027572
|
||||||
|
* @summary class unloading resets profile, method compiled after the profile is first set and before class loading sets unknown bit with not recorded class
|
||||||
|
* @build B
|
||||||
|
* @run main/othervm -XX:TypeProfileLevel=222 -XX:-BackgroundCompilation TestProfileConflictClassUnloading
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLClassLoader;
|
||||||
|
import java.nio.file.Paths;
|
||||||
|
|
||||||
|
public class TestProfileConflictClassUnloading {
|
||||||
|
static class A {
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void m1(Object o) {
|
||||||
|
}
|
||||||
|
|
||||||
|
static void m2(Object o) {
|
||||||
|
m1(o);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void m3(A a, boolean do_call) {
|
||||||
|
if (!do_call) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
m2(a);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ClassLoader newClassLoader() {
|
||||||
|
try {
|
||||||
|
return new URLClassLoader(new URL[] {
|
||||||
|
Paths.get(System.getProperty("test.classes",".")).toUri().toURL(),
|
||||||
|
}, null);
|
||||||
|
} catch (MalformedURLException e){
|
||||||
|
throw new RuntimeException("Unexpected URL conversion failure", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
ClassLoader loader = newClassLoader();
|
||||||
|
Object o = loader.loadClass("B").newInstance();
|
||||||
|
// collect conflicting profiles
|
||||||
|
for (int i = 0; i < 5000; i++) {
|
||||||
|
m2(o);
|
||||||
|
}
|
||||||
|
// prepare for conflict
|
||||||
|
A a = new A();
|
||||||
|
for (int i = 0; i < 5000; i++) {
|
||||||
|
m3(a, false);
|
||||||
|
}
|
||||||
|
// unload class in profile
|
||||||
|
o = null;
|
||||||
|
loader = null;
|
||||||
|
System.gc();
|
||||||
|
// record the conflict
|
||||||
|
m3(a, true);
|
||||||
|
// trigger another GC
|
||||||
|
System.gc();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue