7106944: assert(_pc == *pc_addr) failed may be too strong

Reviewed-by: kvn, never
This commit is contained in:
Christian Thalinger 2011-11-03 04:12:49 -07:00
parent 5a4de97cf0
commit 9740abac58

View File

@ -234,10 +234,12 @@ bool frame::safe_for_sender(JavaThread *thread) {
void frame::patch_pc(Thread* thread, address pc) { void frame::patch_pc(Thread* thread, address pc) {
address* pc_addr = &(((address*) sp())[-1]); address* pc_addr = &(((address*) sp())[-1]);
if (TracePcPatching) { if (TracePcPatching) {
tty->print_cr("patch_pc at address " INTPTR_FORMAT " [" INTPTR_FORMAT " -> " INTPTR_FORMAT "] ", tty->print_cr("patch_pc at address " INTPTR_FORMAT " [" INTPTR_FORMAT " -> " INTPTR_FORMAT "]",
pc_addr, *pc_addr, pc); pc_addr, *pc_addr, pc);
} }
assert(_pc == *pc_addr, err_msg("must be: " INTPTR_FORMAT " == " INTPTR_FORMAT, _pc, *pc_addr)); // Either the return address is the original one or we are going to
// patch in the same address that's already there.
assert(_pc == *pc_addr || pc == *pc_addr, "must be");
*pc_addr = pc; *pc_addr = pc;
_cb = CodeCache::find_blob(pc); _cb = CodeCache::find_blob(pc);
address original_pc = nmethod::get_deopt_original_pc(this); address original_pc = nmethod::get_deopt_original_pc(this);