2018-05-15 20:24:34 +02:00
|
|
|
/*
|
2019-09-14 14:40:09 +02:00
|
|
|
* Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
|
2018-05-15 20:24:34 +02:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "precompiled.hpp"
|
|
|
|
#include "jfr/jfr.hpp"
|
|
|
|
#include "jfr/leakprofiler/leakProfiler.hpp"
|
|
|
|
#include "jfr/periodic/sampling/jfrThreadSampler.hpp"
|
|
|
|
#include "jfr/recorder/jfrRecorder.hpp"
|
|
|
|
#include "jfr/recorder/checkpoint/jfrCheckpointManager.hpp"
|
|
|
|
#include "jfr/recorder/repository/jfrEmergencyDump.hpp"
|
2018-07-08 11:54:08 +02:00
|
|
|
#include "jfr/recorder/service/jfrOptionSet.hpp"
|
2018-05-15 20:24:34 +02:00
|
|
|
#include "jfr/support/jfrThreadLocal.hpp"
|
|
|
|
#include "runtime/java.hpp"
|
|
|
|
|
|
|
|
bool Jfr::is_enabled() {
|
|
|
|
return JfrRecorder::is_enabled();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Jfr::is_disabled() {
|
|
|
|
return JfrRecorder::is_disabled();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Jfr::is_recording() {
|
|
|
|
return JfrRecorder::is_recording();
|
|
|
|
}
|
|
|
|
|
2019-11-25 18:38:01 +01:00
|
|
|
void Jfr::on_create_vm_1() {
|
|
|
|
if (!JfrRecorder::on_create_vm_1()) {
|
|
|
|
vm_exit_during_initialization("Failure when starting JFR on_create_vm_1");
|
2018-05-15 20:24:34 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-25 18:38:01 +01:00
|
|
|
void Jfr::on_create_vm_2() {
|
|
|
|
if (!JfrRecorder::on_create_vm_2()) {
|
|
|
|
vm_exit_during_initialization("Failure when starting JFR on_create_vm_2");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void Jfr::on_create_vm_3() {
|
|
|
|
if (!JfrRecorder::on_create_vm_3()) {
|
|
|
|
vm_exit_during_initialization("Failure when starting JFR on_create_vm_3");
|
2018-05-15 20:24:34 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void Jfr::on_unloading_classes() {
|
|
|
|
if (JfrRecorder::is_created()) {
|
|
|
|
JfrCheckpointManager::write_type_set_for_unloaded_classes();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-15 11:10:04 +01:00
|
|
|
void Jfr::on_thread_start(Thread* t) {
|
|
|
|
JfrThreadLocal::on_start(t);
|
2018-05-15 20:24:34 +02:00
|
|
|
}
|
|
|
|
|
2018-11-15 11:10:04 +01:00
|
|
|
void Jfr::on_thread_exit(Thread* t) {
|
|
|
|
JfrThreadLocal::on_exit(t);
|
|
|
|
}
|
|
|
|
|
2019-10-30 19:43:52 +01:00
|
|
|
void Jfr::exclude_thread(Thread* t) {
|
|
|
|
JfrThreadLocal::exclude(t);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Jfr::include_thread(Thread* t) {
|
|
|
|
JfrThreadLocal::include(t);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Jfr::is_excluded(Thread* t) {
|
|
|
|
return t != NULL && t->jfr_thread_local()->is_excluded();
|
|
|
|
}
|
|
|
|
|
2018-11-15 11:10:04 +01:00
|
|
|
void Jfr::on_java_thread_dismantle(JavaThread* jt) {
|
|
|
|
if (JfrRecorder::is_recording()) {
|
|
|
|
JfrCheckpointManager::write_thread_checkpoint(jt);
|
2018-05-15 20:24:34 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void Jfr::on_vm_shutdown(bool exception_handler) {
|
|
|
|
if (JfrRecorder::is_recording()) {
|
|
|
|
JfrEmergencyDump::on_vm_shutdown(exception_handler);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void Jfr::weak_oops_do(BoolObjectClosure* is_alive, OopClosure* f) {
|
2019-09-14 14:40:09 +02:00
|
|
|
if (LeakProfiler::is_running()) {
|
2019-12-10 13:50:10 +00:00
|
|
|
LeakProfiler::weak_oops_do(is_alive, f);
|
2019-09-14 14:40:09 +02:00
|
|
|
}
|
2018-05-15 20:24:34 +02:00
|
|
|
}
|
|
|
|
|
2018-06-28 11:37:02 +02:00
|
|
|
bool Jfr::on_flight_recorder_option(const JavaVMOption** option, char* delimiter) {
|
|
|
|
return JfrOptionSet::parse_flight_recorder_option(option, delimiter);
|
2018-05-15 20:24:34 +02:00
|
|
|
}
|
|
|
|
|
2018-06-28 11:37:02 +02:00
|
|
|
bool Jfr::on_start_flight_recording_option(const JavaVMOption** option, char* delimiter) {
|
|
|
|
return JfrOptionSet::parse_start_flight_recording_option(option, delimiter);
|
2018-05-15 20:24:34 +02:00
|
|
|
}
|