src/share/vm/runtime/init.cpp

Mon, 06 Aug 2012 15:54:45 -0400

author
kamg
date
Mon, 06 Aug 2012 15:54:45 -0400
changeset 3992
4ee06e614636
parent 3865
e9140bf80b4a
child 4037
da91efe96a93
permissions
-rw-r--r--

7116786: RFE: Detailed information on VerifyErrors
Summary: Provide additional detail in VerifyError messages
Reviewed-by: sspitsyn, acorn

     1 /*
     2  * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
     3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
     4  *
     5  * This code is free software; you can redistribute it and/or modify it
     6  * under the terms of the GNU General Public License version 2 only, as
     7  * published by the Free Software Foundation.
     8  *
     9  * This code is distributed in the hope that it will be useful, but WITHOUT
    10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
    11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
    12  * version 2 for more details (a copy is included in the LICENSE file that
    13  * accompanied this code).
    14  *
    15  * You should have received a copy of the GNU General Public License version
    16  * 2 along with this work; if not, write to the Free Software Foundation,
    17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
    18  *
    19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
    20  * or visit www.oracle.com if you need additional information or have any
    21  * questions.
    22  *
    23  */
    25 #include "precompiled.hpp"
    26 #include "classfile/symbolTable.hpp"
    27 #include "code/icBuffer.hpp"
    28 #include "gc_interface/collectedHeap.hpp"
    29 #include "interpreter/bytecodes.hpp"
    30 #include "memory/universe.hpp"
    31 #include "prims/methodHandles.hpp"
    32 #include "runtime/handles.inline.hpp"
    33 #include "runtime/icache.hpp"
    34 #include "runtime/init.hpp"
    35 #include "runtime/safepoint.hpp"
    36 #include "runtime/sharedRuntime.hpp"
    38 // Initialization done by VM thread in vm_init_globals()
    39 void check_ThreadShadow();
    40 void eventlog_init();
    41 void mutex_init();
    42 void chunkpool_init();
    43 void perfMemory_init();
    45 // Initialization done by Java thread in init_globals()
    46 void management_init();
    47 void bytecodes_init();
    48 void classLoader_init();
    49 void codeCache_init();
    50 void VM_Version_init();
    51 void os_init_globals();        // depends on VM_Version_init, before universe_init
    52 void stubRoutines_init1();
    53 jint universe_init();          // depends on codeCache_init and stubRoutines_init
    54 void interpreter_init();       // before any methods loaded
    55 void invocationCounter_init(); // before any methods loaded
    56 void marksweep_init();
    57 void accessFlags_init();
    58 void templateTable_init();
    59 void InterfaceSupport_init();
    60 void universe2_init();  // dependent on codeCache_init and stubRoutines_init, loads primordial classes
    61 void referenceProcessor_init();
    62 void jni_handles_init();
    63 void vmStructs_init();
    65 void vtableStubs_init();
    66 void InlineCacheBuffer_init();
    67 void compilerOracle_init();
    68 void compilationPolicy_init();
    69 void compileBroker_init();
    71 // Initialization after compiler initialization
    72 bool universe_post_init();  // must happen after compiler_init
    73 void javaClasses_init();  // must happen after vtable initialization
    74 void stubRoutines_init2(); // note: StubRoutines need 2-phase init
    76 // Do not disable thread-local-storage, as it is important for some
    77 // JNI/JVM/JVMTI functions and signal handlers to work properly
    78 // during VM shutdown
    79 void perfMemory_exit();
    80 void ostream_exit();
    82 void vm_init_globals() {
    83   check_ThreadShadow();
    84   basic_types_init();
    85   eventlog_init();
    86   mutex_init();
    87   chunkpool_init();
    88   perfMemory_init();
    89 }
    92 jint init_globals() {
    93   HandleMark hm;
    94   management_init();
    95   bytecodes_init();
    96   classLoader_init();
    97   codeCache_init();
    98   VM_Version_init();
    99   os_init_globals();
   100   stubRoutines_init1();
   101   jint status = universe_init();  // dependent on codeCache_init and
   102                                   // stubRoutines_init1
   103   if (status != JNI_OK)
   104     return status;
   106   interpreter_init();  // before any methods loaded
   107   invocationCounter_init();  // before any methods loaded
   108   marksweep_init();
   109   accessFlags_init();
   110   templateTable_init();
   111   InterfaceSupport_init();
   112   SharedRuntime::generate_stubs();
   113   universe2_init();  // dependent on codeCache_init and stubRoutines_init1
   114   referenceProcessor_init();
   115   jni_handles_init();
   116 #ifndef VM_STRUCTS_KERNEL
   117   vmStructs_init();
   118 #endif // VM_STRUCTS_KERNEL
   120   vtableStubs_init();
   121   InlineCacheBuffer_init();
   122   compilerOracle_init();
   123   compilationPolicy_init();
   124   compileBroker_init();
   125   VMRegImpl::set_regName();
   127   if (!universe_post_init()) {
   128     return JNI_ERR;
   129   }
   130   javaClasses_init();   // must happen after vtable initialization
   131   stubRoutines_init2(); // note: StubRoutines need 2-phase init
   133   // Although we'd like to, we can't easily do a heap verify
   134   // here because the main thread isn't yet a JavaThread, so
   135   // its TLAB may not be made parseable from the usual interfaces.
   136   if (VerifyBeforeGC && !UseTLAB &&
   137       Universe::heap()->total_collections() >= VerifyGCStartAt) {
   138     Universe::heap()->prepare_for_verify();
   139     Universe::verify();   // make sure we're starting with a clean slate
   140   }
   142   // All the flags that get adjusted by VM_Version_init and os::init_2
   143   // have been set so dump the flags now.
   144   if (PrintFlagsFinal) {
   145     CommandLineFlags::printFlags(tty, false);
   146   }
   148   return JNI_OK;
   149 }
   152 void exit_globals() {
   153   static bool destructorsCalled = false;
   154   if (!destructorsCalled) {
   155     destructorsCalled = true;
   156     perfMemory_exit();
   157     if (PrintSafepointStatistics) {
   158       // Print the collected safepoint statistics.
   159       SafepointSynchronize::print_stat_on_exit();
   160     }
   161     if (PrintStringTableStatistics) {
   162       SymbolTable::dump(tty);
   163       StringTable::dump(tty);
   164     }
   165     ostream_exit();
   166   }
   167 }
   170 static bool _init_completed = false;
   172 bool is_init_completed() {
   173   return _init_completed;
   174 }
   177 void set_init_completed() {
   178   assert(Universe::is_fully_initialized(), "Should have completed initialization");
   179   _init_completed = true;
   180 }

mercurial