From 01353e77874dd02bfd3418a3f7aa09208a838a32 Mon Sep 17 00:00:00 2001 From: Tobias Hartmann Date: Thu, 15 Feb 2018 09:17:56 +0100 Subject: [PATCH] 8197828: Null pointer dereference in MultiNode::proj_out_or_null Added a null check for the return value of AllocateNode::initialization(). Reviewed-by: kvn, shade, dlong --- src/hotspot/share/opto/callnode.cpp | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/hotspot/share/opto/callnode.cpp b/src/hotspot/share/opto/callnode.cpp index d77f451ae0a..28c08022cf6 100644 --- a/src/hotspot/share/opto/callnode.cpp +++ b/src/hotspot/share/opto/callnode.cpp @@ -1441,8 +1441,10 @@ Node *AllocateArrayNode::make_ideal_length(const TypeOopPtr* oop_type, PhaseTran if (!allow_new_nodes) return NULL; // Create a cast which is control dependent on the initialization to // propagate the fact that the array length must be positive. + InitializeNode* init = initialization(); + assert(init != NULL, "initialization not found"); length = new CastIINode(length, narrow_length_type); - length->set_req(0, initialization()->proj_out_or_null(0)); + length->set_req(0, init->proj_out_or_null(0)); } }