diff --git a/src/hotspot/share/jfr/recorder/checkpoint/types/jfrTypeSet.cpp b/src/hotspot/share/jfr/recorder/checkpoint/types/jfrTypeSet.cpp index db3c8f5ce3f..1792602489c 100644 --- a/src/hotspot/share/jfr/recorder/checkpoint/types/jfrTypeSet.cpp +++ b/src/hotspot/share/jfr/recorder/checkpoint/types/jfrTypeSet.cpp @@ -761,6 +761,7 @@ int write__method(JfrCheckpointWriter* writer, const void* m) { int write__method__leakp(JfrCheckpointWriter* writer, const void* m) { assert(m != NULL, "invariant"); MethodPtr method = (MethodPtr)m; + CLEAR_LEAKP_METHOD(method); return write_method(writer, method, true); } diff --git a/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceId.cpp b/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceId.cpp index 9ea39ae0ff7..138a85ed005 100644 --- a/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceId.cpp +++ b/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceId.cpp @@ -170,6 +170,13 @@ void JfrTraceId::remove(const Klass* k) { k->set_trace_id(EVENT_KLASS_MASK(k)); } +// used by CDS / APPCDS as part of "remove_unshareable_info" +void JfrTraceId::remove(const Method* method) { + assert(method != NULL, "invariant"); + // Clear all bits. + method->set_trace_flags(0); +} + // used by CDS / APPCDS as part of "restore_unshareable_info" void JfrTraceId::restore(const Klass* k) { assert(k != NULL, "invariant"); diff --git a/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceId.hpp b/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceId.hpp index 9110f7d5554..2a67e57de8a 100644 --- a/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceId.hpp +++ b/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceId.hpp @@ -106,6 +106,7 @@ class JfrTraceId : public AllStatic { static traceid load_raw(const ClassLoaderData* cld); static void remove(const Klass* klass); + static void remove(const Method* method); static void restore(const Klass* klass); // set of event classes made visible to java diff --git a/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceIdMacros.hpp b/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceIdMacros.hpp index b25500afc70..14b008b1d51 100644 --- a/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceIdMacros.hpp +++ b/src/hotspot/share/jfr/recorder/checkpoint/types/traceid/jfrTraceIdMacros.hpp @@ -145,6 +145,7 @@ #define CLEAR_SERIALIZED_METHOD(method) (METHOD_META_MASK_CLEAR(method, META_MASK)) #define SET_PREVIOUS_EPOCH_METHOD_CLEARED_BIT(ptr) (METHOD_META_TAG(ptr, PREVIOUS_EPOCH_BIT)) #define CLEAR_LEAKP(ptr) (TRACE_ID_META_MASK_CLEAR(ptr, (~(LEAKP_META_BIT)))) +#define CLEAR_LEAKP_METHOD(method) (METHOD_META_MASK_CLEAR(method, (~(LEAKP_META_BIT)))) #define CLEAR_THIS_EPOCH_CLEARED_BIT(ptr) (TRACE_ID_META_MASK_CLEAR(ptr,(~(THIS_EPOCH_BIT)))) #define CLEAR_THIS_EPOCH_METHOD_CLEARED_BIT(ptr) (METHOD_META_MASK_CLEAR(ptr,(~(THIS_EPOCH_BIT)))) #define IS_THIS_EPOCH_METHOD_CLEARED(ptr) (METHOD_FLAG_PREDICATE(method, THIS_EPOCH_BIT)) diff --git a/src/hotspot/share/jfr/recorder/jfrRecorder.cpp b/src/hotspot/share/jfr/recorder/jfrRecorder.cpp index b7c4e46732b..257c17d2d29 100644 --- a/src/hotspot/share/jfr/recorder/jfrRecorder.cpp +++ b/src/hotspot/share/jfr/recorder/jfrRecorder.cpp @@ -172,8 +172,8 @@ static void log_jdk_jfr_module_resolution_error(TRAPS) { } static bool is_cds_dump_requested() { - // we will not be able to launch recordings if a cds dump is being requested - if (Arguments::is_dumping_archive() && (JfrOptionSet::start_flight_recording_options() != NULL)) { + // we will not be able to launch recordings on startup if a cds dump is being requested + if (Arguments::is_dumping_archive()) { warning("JFR will be disabled during CDS dumping"); teardown_startup_support(); return true; @@ -213,7 +213,7 @@ bool JfrRecorder::on_create_vm_2() { bool JfrRecorder::on_create_vm_3() { assert(JvmtiEnvBase::get_phase() == JVMTI_PHASE_LIVE, "invalid init sequence"); - return launch_command_line_recordings(Thread::current()); + return Arguments::is_dumping_archive() || launch_command_line_recordings(Thread::current()); } static bool _created = false; diff --git a/src/hotspot/share/jfr/support/jfrTraceIdExtension.hpp b/src/hotspot/share/jfr/support/jfrTraceIdExtension.hpp index 98cac9e35c0..f21e9fdd37d 100644 --- a/src/hotspot/share/jfr/support/jfrTraceIdExtension.hpp +++ b/src/hotspot/share/jfr/support/jfrTraceIdExtension.hpp @@ -1,5 +1,5 @@ /* -* Copyright (c) 2012, 2019, Oracle and/or its affiliates. All rights reserved. +* Copyright (c) 2012, 2020, 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 @@ -40,6 +40,7 @@ #define INIT_ID(data) JfrTraceId::assign(data) #define REMOVE_ID(k) JfrTraceId::remove(k); +#define REMOVE_METHOD_ID(method) JfrTraceId::remove(method); #define RESTORE_ID(k) JfrTraceId::restore(k); class JfrTraceFlag { diff --git a/src/hotspot/share/oops/method.cpp b/src/hotspot/share/oops/method.cpp index 8e256305fd9..3d8ade5496c 100644 --- a/src/hotspot/share/oops/method.cpp +++ b/src/hotspot/share/oops/method.cpp @@ -357,6 +357,7 @@ void Method::metaspace_pointers_do(MetaspaceClosure* it) { void Method::remove_unshareable_info() { unlink_method(); + JFR_ONLY(REMOVE_METHOD_ID(this);) } void Method::set_vtable_index(int index) {