From 5ce7a44cf0a51522a64d8f4c97a7aa3192ddcfb7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Markus=20Gr=C3=B6nlund?= Date: Thu, 27 Oct 2016 11:14:30 +0200 Subject: [PATCH] 8168662: Intrinsic support for event based tracing needs explicit control dependency Reviewed-by: kvn, rehn --- hotspot/src/share/vm/opto/library_call.cpp | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/hotspot/src/share/vm/opto/library_call.cpp b/hotspot/src/share/vm/opto/library_call.cpp index fff1e13f8fb..7700f2af4dd 100644 --- a/hotspot/src/share/vm/opto/library_call.cpp +++ b/hotspot/src/share/vm/opto/library_call.cpp @@ -3213,24 +3213,23 @@ bool LibraryCallKit::inline_native_getBufferWriter() { Node* test_jobj_eq_null = _gvn.transform( new BoolNode(jobj_cmp_null, BoolTest::eq) ); IfNode* iff_jobj_null = - create_and_map_if(control(), test_jobj_eq_null, PROB_NEVER, COUNT_UNKNOWN); + create_and_map_if(control(), test_jobj_eq_null, PROB_MIN, COUNT_UNKNOWN); - enum { _normal_path = 1, - _null_path = 2, - PATH_LIMIT }; + enum { _normal_path = 1, + _null_path = 2, + PATH_LIMIT }; RegionNode* result_rgn = new RegionNode(PATH_LIMIT); PhiNode* result_val = new PhiNode(result_rgn, TypePtr::BOTTOM); - record_for_igvn(result_rgn); - Node* jobj_is_null = _gvn.transform( new IfTrueNode(iff_jobj_null) ); + Node* jobj_is_null = _gvn.transform(new IfTrueNode(iff_jobj_null)); result_rgn->init_req(_null_path, jobj_is_null); result_val->init_req(_null_path, null()); - Node* jobj_is_not_null = _gvn.transform( new IfFalseNode(iff_jobj_null) ); + Node* jobj_is_not_null = _gvn.transform(new IfFalseNode(iff_jobj_null)); result_rgn->init_req(_normal_path, jobj_is_not_null); - Node* res = make_load(NULL, jobj, TypeInstPtr::BOTTOM, T_OBJECT, MemNode::unordered); + Node* res = make_load(jobj_is_not_null, jobj, TypeInstPtr::NOTNULL, T_OBJECT, MemNode::unordered); result_val->init_req(_normal_path, res); set_result(result_rgn, result_val);