src/share/vm/jfr/support/jfrFlush.cpp

Mon, 19 Aug 2019 10:11:31 +0200

author
neugens
date
Mon, 19 Aug 2019 10:11:31 +0200
changeset 9861
a248d0be1309
parent 9858
b985cbb00e68
child 9882
3dd83d893bfc
permissions
-rw-r--r--

8229401: Fix JFR code cache test failures
8223689: Add JFR Thread Sampling Support
8223690: Add JFR BiasedLock Event Support
8223691: Add JFR G1 Region Type Change Event Support
8223692: Add JFR G1 Heap Summary Event Support
Summary: Backport JFR from JDK11, additional fixes
Reviewed-by: neugens, apetushkov
Contributed-by: denghui.ddh@alibaba-inc.com

apetushkov@9858 1 /*
apetushkov@9858 2 * Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved.
apetushkov@9858 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
apetushkov@9858 4 *
apetushkov@9858 5 * This code is free software; you can redistribute it and/or modify it
apetushkov@9858 6 * under the terms of the GNU General Public License version 2 only, as
apetushkov@9858 7 * published by the Free Software Foundation.
apetushkov@9858 8 *
apetushkov@9858 9 * This code is distributed in the hope that it will be useful, but WITHOUT
apetushkov@9858 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
apetushkov@9858 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
apetushkov@9858 12 * version 2 for more details (a copy is included in the LICENSE file that
apetushkov@9858 13 * accompanied this code).
apetushkov@9858 14 *
apetushkov@9858 15 * You should have received a copy of the GNU General Public License version
apetushkov@9858 16 * 2 along with this work; if not, write to the Free Software Foundation,
apetushkov@9858 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
apetushkov@9858 18 *
apetushkov@9858 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
apetushkov@9858 20 * or visit www.oracle.com if you need additional information or have any
apetushkov@9858 21 * questions.
apetushkov@9858 22 *
apetushkov@9858 23 */
apetushkov@9858 24
apetushkov@9858 25 #include "precompiled.hpp"
apetushkov@9858 26 #include "jfr/recorder/jfrEventSetting.inline.hpp"
apetushkov@9858 27 #include "jfr/recorder/storage/jfrStorage.hpp"
apetushkov@9858 28 #include "jfr/recorder/stacktrace/jfrStackTraceRepository.hpp"
apetushkov@9858 29 #include "jfr/support/jfrFlush.hpp"
apetushkov@9858 30 #include "jfr/support/jfrThreadLocal.hpp"
apetushkov@9858 31 #include "runtime/thread.inline.hpp"
apetushkov@9858 32 #include "utilities/debug.hpp"
apetushkov@9858 33
apetushkov@9858 34 JfrFlush::JfrFlush(JfrStorage::Buffer* old, size_t used, size_t requested, Thread* t) :
apetushkov@9858 35 _result(JfrStorage::flush(old, used, requested, true, t)) {
apetushkov@9858 36 }
apetushkov@9858 37
apetushkov@9858 38 template <typename T>
apetushkov@9858 39 class LessThanHalfBufferSize : AllStatic {
apetushkov@9858 40 public:
apetushkov@9858 41 static bool evaluate(T* t) {
apetushkov@9858 42 assert(t != NULL, "invariant");
apetushkov@9858 43 return t->free_size() < t->size() / 2;
apetushkov@9858 44 }
apetushkov@9858 45 };
apetushkov@9858 46
apetushkov@9858 47 template <typename T>
apetushkov@9858 48 class LessThanSize : AllStatic {
apetushkov@9858 49 public:
apetushkov@9858 50 static bool evaluate(T* t, size_t size) {
apetushkov@9858 51 assert(t != NULL, "invariant");
apetushkov@9858 52 return t->free_size() < size;
apetushkov@9858 53 }
apetushkov@9858 54 };
apetushkov@9858 55
apetushkov@9858 56 bool jfr_is_event_enabled(JfrEventId id) {
apetushkov@9858 57 return JfrEventSetting::is_enabled(id);
apetushkov@9858 58 }
apetushkov@9858 59
apetushkov@9858 60 bool jfr_has_stacktrace_enabled(JfrEventId id) {
apetushkov@9858 61 return JfrEventSetting::has_stacktrace(id);
apetushkov@9858 62 }
apetushkov@9858 63
apetushkov@9858 64 void jfr_conditional_flush(JfrEventId id, size_t size, Thread* t) {
apetushkov@9858 65 assert(jfr_is_event_enabled(id), "invariant");
apetushkov@9858 66 if (t->jfr_thread_local()->has_native_buffer()) {
apetushkov@9858 67 JfrStorage::Buffer* const buffer = t->jfr_thread_local()->native_buffer();
apetushkov@9858 68 if (LessThanSize<JfrStorage::Buffer>::evaluate(buffer, size)) {
apetushkov@9858 69 JfrFlush f(buffer, 0, 0, t);
apetushkov@9858 70 }
apetushkov@9858 71 }
apetushkov@9858 72 }
apetushkov@9858 73
apetushkov@9858 74 bool jfr_save_stacktrace(Thread* t) {
apetushkov@9858 75 JfrThreadLocal* const tl = t->jfr_thread_local();
apetushkov@9858 76 if (tl->has_cached_stack_trace()) {
apetushkov@9858 77 return false; // no ownership
apetushkov@9858 78 }
apetushkov@9858 79 tl->set_cached_stack_trace_id(JfrStackTraceRepository::record(t));
apetushkov@9858 80 return true;
apetushkov@9858 81 }
apetushkov@9858 82
apetushkov@9858 83 void jfr_clear_stacktrace(Thread* t) {
apetushkov@9858 84 t->jfr_thread_local()->clear_cached_stack_trace();
apetushkov@9858 85 }

mercurial