8210853: JIT: C2 doesn't skip post barrier for new allocated objects
Skip copy Region node when look for last allocation Reviewed-by: thartmann, kvn
This commit is contained in:
parent
0aa4581229
commit
dcb6e1dda8
@ -2116,8 +2116,17 @@ void GraphKit::uncommon_trap(int trap_request,
|
|||||||
// We use this to determine if an object is so "fresh" that
|
// We use this to determine if an object is so "fresh" that
|
||||||
// it does not require card marks.
|
// it does not require card marks.
|
||||||
Node* GraphKit::just_allocated_object(Node* current_control) {
|
Node* GraphKit::just_allocated_object(Node* current_control) {
|
||||||
if (C->recent_alloc_ctl() == current_control)
|
Node* ctrl = current_control;
|
||||||
return C->recent_alloc_obj();
|
// Object::<init> is invoked after allocation, most of invoke nodes
|
||||||
|
// will be reduced, but a region node is kept in parse time, we check
|
||||||
|
// the pattern and skip the region node if it degraded to a copy.
|
||||||
|
if (ctrl != NULL && ctrl->is_Region() && ctrl->req() == 2 &&
|
||||||
|
ctrl->as_Region()->is_copy()) {
|
||||||
|
ctrl = ctrl->as_Region()->is_copy();
|
||||||
|
}
|
||||||
|
if (C->recent_alloc_ctl() == ctrl) {
|
||||||
|
return C->recent_alloc_obj();
|
||||||
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user