8079825: Uninitialised variable in hotspot/src/share/vm & cpu/x86/vm (runtime)
authorccheung
Fri, 17 Jul 2015 12:07:49 -0700
changeset 31851 ec2f9350c499
parent 31850 cee76595e1bb
child 31852 931bfc606dff
child 31854 49b89f076293
8079825: Uninitialised variable in hotspot/src/share/vm & cpu/x86/vm (runtime) Summary: initialized local variables in classFileParser.cpp and rframe.cpp Reviewed-by: dholmes, minqi
hotspot/src/share/vm/classfile/classFileParser.cpp
hotspot/src/share/vm/runtime/rframe.cpp
--- a/hotspot/src/share/vm/classfile/classFileParser.cpp	Thu Jul 16 15:01:12 2015 +0200
+++ b/hotspot/src/share/vm/classfile/classFileParser.cpp	Fri Jul 17 12:07:49 2015 -0700
@@ -2023,10 +2023,10 @@
   bool lvt_allocated = false;
   u2 max_lvt_cnt = INITIAL_MAX_LVT_NUMBER;
   u2 max_lvtt_cnt = INITIAL_MAX_LVT_NUMBER;
-  u2* localvariable_table_length;
-  u2** localvariable_table_start;
-  u2* localvariable_type_table_length;
-  u2** localvariable_type_table_start;
+  u2* localvariable_table_length = NULL;
+  u2** localvariable_table_start = NULL;
+  u2* localvariable_type_table_length = NULL;
+  u2** localvariable_type_table_start = NULL;
   int method_parameters_length = -1;
   u1* method_parameters_data = NULL;
   bool method_parameters_seen = false;
--- a/hotspot/src/share/vm/runtime/rframe.cpp	Thu Jul 16 15:01:12 2015 +0200
+++ b/hotspot/src/share/vm/runtime/rframe.cpp	Fri Jul 17 12:07:49 2015 -0700
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  *
  * This code is free software; you can redistribute it and/or modify it
@@ -81,7 +81,7 @@
 : InterpretedRFrame(fr, thread, callee) {}
 
 RFrame* RFrame::new_RFrame(frame fr, JavaThread* thread, RFrame*const  callee) {
-  RFrame* rf;
+  RFrame* rf = NULL;
   int dist = callee ? callee->distance() : -1;
   if (fr.is_interpreted_frame()) {
     rf = new InterpretedRFrame(fr, thread, callee);
@@ -93,8 +93,10 @@
   } else {
     assert(false, "Unhandled frame type");
   }
-  rf->set_distance(dist);
-  rf->init();
+  if (rf != NULL) {
+    rf->set_distance(dist);
+    rf->init();
+  }
   return rf;
 }