6610906: inexplicable IncompatibleClassChangeError
Dependency check must treat polymorphic interfaces consistently Reviewed-by: kvn, never, sgoldman
This commit is contained in:
parent
9f1a8ede80
commit
73fa03eafc
@ -882,6 +882,14 @@ klassOop ClassHierarchyWalker::find_witness_in(DepChange& changes,
|
|||||||
// Must not move the class hierarchy during this check:
|
// Must not move the class hierarchy during this check:
|
||||||
assert_locked_or_safepoint(Compile_lock);
|
assert_locked_or_safepoint(Compile_lock);
|
||||||
|
|
||||||
|
int nof_impls = instanceKlass::cast(context_type)->nof_implementors();
|
||||||
|
if (nof_impls > 1) {
|
||||||
|
// Avoid this case: *I.m > { A.m, C }; B.m > C
|
||||||
|
// %%% Until this is fixed more systematically, bail out.
|
||||||
|
// See corresponding comment in find_witness_anywhere.
|
||||||
|
return context_type;
|
||||||
|
}
|
||||||
|
|
||||||
assert(!is_participant(new_type), "only old classes are participants");
|
assert(!is_participant(new_type), "only old classes are participants");
|
||||||
if (participants_hide_witnesses) {
|
if (participants_hide_witnesses) {
|
||||||
// If the new type is a subtype of a participant, we are done.
|
// If the new type is a subtype of a participant, we are done.
|
||||||
|
@ -1971,7 +1971,7 @@ void nmethod::print_dependencies() {
|
|||||||
if (ctxk != NULL) {
|
if (ctxk != NULL) {
|
||||||
Klass* k = Klass::cast(ctxk);
|
Klass* k = Klass::cast(ctxk);
|
||||||
if (k->oop_is_instance() && ((instanceKlass*)k)->is_dependent_nmethod(this)) {
|
if (k->oop_is_instance() && ((instanceKlass*)k)->is_dependent_nmethod(this)) {
|
||||||
tty->print(" [nmethod<=klass]%s", k->external_name());
|
tty->print_cr(" [nmethod<=klass]%s", k->external_name());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
deps.log_dependency(); // put it into the xml log also
|
deps.log_dependency(); // put it into the xml log also
|
||||||
|
Loading…
Reference in New Issue
Block a user