1 /*
  2  * Copyright (c) 2012, 2019, 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  */
 24 
 25 #ifndef SHARE_CI_CIREPLAY_HPP
 26 #define SHARE_CI_CIREPLAY_HPP
 27 
 28 #include "ci/ciMethod.hpp"
 29 
 30 // ciReplay
 31 
 32 //
 33 // Replay compilation of a java method by using an information in replay file.
 34 // Replay inlining decisions during compilation by using an information in inline file.
 35 //
 36 // NOTE: these replay functions only exist in debug version of VM.
 37 //
 38 // Replay compilation.
 39 // -------------------
 40 //
 41 // Replay data file replay.txt can be created by Serviceability Agent
 42 // from a core file, see agent/doc/cireplay.html
 43 //
 44 // $ java -cp <jdk>/lib/sa-jdi.jar sun.jvm.hotspot.CLHSDB
 45 // hsdb> attach <jdk>/bin/java ./core
 46 // hsdb> threads
 47 // t@10 Service Thread
 48 // t@9 C2 CompilerThread0
 49 // t@8 Signal Dispatcher
 50 // t@7 Finalizer
 51 // t@6 Reference Handler
 52 // t@2 main
 53 // hsdb> dumpreplaydata t@9 > replay.txt
 54 // hsdb> quit
 55 //
 56 // (Note: SA could be also used to extract app.jar and boot.jar files
 57 //  from core file to replay compilation if only core file is available)
 58 //
 59 // Replay data file replay_pid%p.log is also created when VM crashes
 60 // in Compiler thread during compilation. It is controlled by
 61 // DumpReplayDataOnError flag which is ON by default.
 62 //
 63 // Replay file replay_pid%p_compid%d.log can be created
 64 // for the specified java method during normal execution using
 65 // CompileCommand option DumpReplay:
 66 //
 67 // -XX:CompileCommand=option,Benchmark::test,DumpReplay
 68 //
 69 // In this case the file name has additional compilation id "_compid%d"
 70 // because the method could be compiled several times.
 71 //
 72 // To replay compilation the replay file should be specified:
 73 //
 74 // -XX:+ReplayCompiles -XX:ReplayDataFile=replay_pid2133.log
 75 //
 76 // VM thread reads data from the file immediately after VM initialization
 77 // and puts the compilation task on compile queue. After that it goes into
 78 // wait state (BackgroundCompilation flag is set to false) since there is no
 79 // a program to execute. VM exits when the compilation is finished.
 80 //
 81 //
 82 // Replay inlining.
 83 // ----------------
 84 //
 85 // Replay inlining file inline_pid%p_compid%d.log is created for
 86 // a specific java method during normal execution of a java program
 87 // using CompileCommand option DumpInline:
 88 //
 89 // -XX:CompileCommand=option,Benchmark::test,DumpInline
 90 //
 91 // To replay inlining the replay file and the method should be specified:
 92 //
 93 // -XX:CompileCommand=option,Benchmark::test,ReplayInline -XX:InlineDataFile=inline_pid3244_compid6.log
 94 //
 95 // The difference from replay compilation is that replay inlining
 96 // is performed during normal java program execution.
 97 //
 98 
 99 class ciReplay {
100   CI_PACKAGE_ACCESS
101 
102  private:
103   static int replay_impl(TRAPS);
104 
105  public:
106   // Replay specified compilation and exit VM.
107   static void replay(TRAPS);
108   static bool no_replay_state();
109   // Load inlining decisions from file and use them
110   // during compilation of specified method.
111   static void* load_inline_data(ciMethod* method, int entry_bci, int comp_level);
112 
113   // These are used by the CI to fill in the cached data from the
114   // replay file when replaying compiles.
115   static void initialize(ciMethodData* method);
116   static void initialize(ciMethod* method);
117   static void initialize(ciInstanceKlass* ciKlass, InstanceKlass* ik);
118 
119   static bool is_klass_unresolved(const InstanceKlass* klass);
120   static bool is_loaded(Method* method);
121 
122   static bool should_not_inline(ciMethod* method);
123   static bool should_inline(void* data, ciMethod* method, int bci, int inline_depth, bool& should_delay);
124   static bool should_not_inline(void* data, ciMethod* method, int bci, int inline_depth);
125 
126  public:
127   static oop obj_field(oop obj, Symbol* name);
128   static oop obj_field(oop obj, const char *name);
129 
130 };
131 
132 // Replay file format version history
133 // 0: legacy (no version number)
134 // 1: first instanceKlass sets protection domain (8275868)
135 //    replace current_mileage with invocation_count (8276095)
136 // 2: incremental inlining support (8254108)
137 #define REPLAY_VERSION 2 // current version, bump up for incompatible changes
138 
139 #endif // SHARE_CI_CIREPLAY_HPP