--- old/src/hotspot/share/opto/memnode.cpp 2019-01-23 03:49:00.663694958 -0800 +++ new/src/hotspot/share/opto/memnode.cpp 2019-01-23 03:49:00.229654537 -0800 @@ -1532,10 +1532,14 @@ Node* address = in(MemNode::Address); bool progress = false; + bool addr_mark = ((phase->type(address)->isa_oopptr() || phase->type(address)->isa_narrowoop()) && + phase->type(address)->is_ptr()->offset() == oopDesc::mark_offset_in_bytes()); + // Skip up past a SafePoint control. Cannot do this for Stores because // pointer stores & cardmarks must stay on the same side of a SafePoint. if( ctrl != NULL && ctrl->Opcode() == Op_SafePoint && - phase->C->get_alias_index(phase->type(address)->is_ptr()) != Compile::AliasIdxRaw ) { + phase->C->get_alias_index(phase->type(address)->is_ptr()) != Compile::AliasIdxRaw && + !addr_mark ) { ctrl = ctrl->in(0); set_req(MemNode::Control,ctrl); progress = true;