src/hotspot/share/jfr/recorder/checkpoint/types/jfrTypeSet.cpp
author mgronlun
Sun, 22 Sep 2019 17:31:57 +0200
branchJEP-349-branch
changeset 58259 b6efcf2217f1
parent 58251 c4067538a0f2
child 58823 6a21dba79b81
permissions -rw-r--r--
clear_artifacts in the correct location
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     1
/*
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
     2
 * Copyright (c) 2016, 2019, Oracle and/or its affiliates. All rights reserved.
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     4
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     7
 * published by the Free Software Foundation.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     8
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    13
 * accompanied this code).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    14
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    18
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    21
 * questions.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    22
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    23
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    24
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    25
#include "precompiled.hpp"
51959
db0c3952de52 8209645: Split ClassLoaderData and ClassLoaderDataGraph into separate files
coleenp
parents: 51444
diff changeset
    26
#include "classfile/classLoaderDataGraph.hpp"
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    27
#include "classfile/javaClasses.inline.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    28
#include "classfile/moduleEntry.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    29
#include "classfile/packageEntry.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    30
#include "classfile/symbolTable.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    31
#include "jfr/jfr.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    32
#include "jfr/jni/jfrGetAllEventClasses.hpp"
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    33
#include "jfr/leakprofiler/checkpoint/objectSampleCheckpoint.hpp"
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    34
#include "jfr/recorder/checkpoint/types/jfrTypeSet.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    35
#include "jfr/recorder/checkpoint/types/jfrTypeSetUtils.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    36
#include "jfr/recorder/checkpoint/types/traceid/jfrTraceId.inline.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    37
#include "jfr/utilities/jfrHashtable.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    38
#include "jfr/utilities/jfrTypes.hpp"
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    39
#include "jfr/writers/jfrTypeWriterHost.hpp"
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    40
#include "memory/iterator.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    41
#include "memory/resourceArea.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    42
#include "oops/instanceKlass.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    43
#include "oops/objArrayKlass.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    44
#include "oops/oop.inline.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    45
#include "utilities/accessFlags.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    46
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    47
typedef const Klass* KlassPtr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    48
typedef const PackageEntry* PkgPtr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    49
typedef const ModuleEntry* ModPtr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    50
typedef const ClassLoaderData* CldPtr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    51
typedef const Method* MethodPtr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    52
typedef const Symbol* SymbolPtr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    53
typedef const JfrSymbolId::SymbolEntry* SymbolEntryPtr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    54
typedef const JfrSymbolId::CStringEntry* CStringEntryPtr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    55
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    56
static JfrCheckpointWriter* _writer = NULL;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    57
static JfrCheckpointWriter* _leakp_writer = NULL;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    58
static JfrArtifactSet* _artifacts = NULL;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    59
static JfrArtifactClosure* _subsystem_callback = NULL;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    60
static bool _class_unload = false;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    61
static bool _flushpoint = false;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    62
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    63
// incremented on each rotation
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    64
static u8 checkpoint_id = 1;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    65
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    66
// creates a unique id by combining a checkpoint relative symbol id (2^24)
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    67
// with the current checkpoint id (2^40)
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    68
#define CREATE_SYMBOL_ID(sym_id) (((u8)((checkpoint_id << 24) | sym_id)))
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    69
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    70
static traceid create_symbol_id(traceid artifact_id) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    71
  return artifact_id != 0 ? CREATE_SYMBOL_ID(artifact_id) : 0;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    72
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    73
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    74
static bool current_epoch() {
57870
00860d9caf4d New metadata system for oldobjects built on top of simplified tagging model. Caching and serialization improvements. Flushpoint checkpoint with chunkheader contents.
mgronlun
parents: 57360
diff changeset
    75
  return _class_unload || _flushpoint;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    76
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    77
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    78
static bool previous_epoch() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    79
  return !current_epoch();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    80
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    81
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    82
static bool is_complete() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    83
  return !_artifacts->has_klass_entries() && current_epoch();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    84
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    85
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    86
static traceid mark_symbol(KlassPtr klass, bool leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    87
  return klass != NULL ? create_symbol_id(_artifacts->mark(klass, leakp)) : 0;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    88
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    89
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    90
static traceid mark_symbol(Symbol* symbol, bool leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    91
  return symbol != NULL ? create_symbol_id(_artifacts->mark(symbol, leakp)) : 0;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    92
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    93
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    94
static traceid get_bootstrap_name(bool leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    95
  return create_symbol_id(_artifacts->bootstrap_name(leakp));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    96
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    97
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    98
template <typename T>
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
    99
static traceid artifact_id(const T* ptr) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   100
  assert(ptr != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   101
  return TRACE_ID(ptr);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   102
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   103
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   104
static traceid package_id(KlassPtr klass, bool leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   105
  assert(klass != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   106
  PkgPtr pkg_entry = klass->package();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   107
  if (pkg_entry == NULL) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   108
    return 0;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   109
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   110
  if (leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   111
    SET_LEAKP(pkg_entry);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   112
  }
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   113
  // package implicitly tagged already
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   114
  return artifact_id(pkg_entry);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   115
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   116
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   117
static traceid module_id(PkgPtr pkg, bool leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   118
  assert(pkg != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   119
  ModPtr module_entry = pkg->module();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   120
  if (module_entry == NULL || !module_entry->is_named()) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   121
    return 0;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   122
  }
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   123
  if (leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   124
    SET_LEAKP(module_entry);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   125
  } else {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   126
    SET_TRANSIENT(module_entry);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   127
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   128
  return artifact_id(module_entry);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   129
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   130
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   131
static traceid method_id(KlassPtr klass, MethodPtr method) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   132
  assert(klass != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   133
  assert(method != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   134
  return METHOD_ID(klass, method);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   135
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   136
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   137
static traceid cld_id(CldPtr cld, bool leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   138
  assert(cld != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   139
  if (cld->is_unsafe_anonymous()) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   140
    return 0;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   141
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   142
  if (leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   143
    SET_LEAKP(cld);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   144
  } else {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   145
    SET_TRANSIENT(cld);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   146
  }
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   147
  return artifact_id(cld);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   148
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   149
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   150
template <typename T>
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   151
static s4 get_flags(const T* ptr) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   152
  assert(ptr != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   153
  return ptr->access_flags().get_flags();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   154
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   155
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   156
template <typename T>
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   157
static void set_serialized(const T* ptr) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   158
  assert(ptr != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   159
  SET_SERIALIZED(ptr);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   160
  assert(IS_SERIALIZED(ptr), "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   161
}
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   162
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   163
/*
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   164
 * In C++03, functions used as template parameters must have external linkage;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   165
 * this restriction was removed in C++11. Change back to "static" and
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   166
 * rename functions when C++11 becomes available.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   167
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   168
 * The weird naming is an effort to decrease the risk of name clashes.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   169
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   170
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   171
static int write_klass(JfrCheckpointWriter* writer, KlassPtr klass, bool leakp) {
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   172
  assert(writer != NULL, "invariant");
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   173
  assert(_artifacts != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   174
  assert(klass != NULL, "invariant");
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   175
  traceid pkg_id = 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   176
  KlassPtr theklass = klass;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   177
  if (theklass->is_objArray_klass()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   178
    const ObjArrayKlass* obj_arr_klass = ObjArrayKlass::cast(klass);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   179
    theklass = obj_arr_klass->bottom_klass();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   180
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   181
  if (theklass->is_instance_klass()) {
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   182
    pkg_id = package_id(theklass, leakp);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   183
  } else {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   184
    assert(theklass->is_typeArray_klass(), "invariant");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   185
  }
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   186
  writer->write(artifact_id(klass));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   187
  writer->write(cld_id(klass->class_loader_data(), leakp));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   188
  writer->write(mark_symbol(klass, leakp));
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   189
  writer->write(pkg_id);
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   190
  writer->write(get_flags(klass));
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   191
  return 1;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   192
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   193
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   194
int write__klass(JfrCheckpointWriter* writer, const void* k) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   195
  assert(k != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   196
  KlassPtr klass = (KlassPtr)k;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   197
  set_serialized(klass);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   198
  return write_klass(writer, klass, false);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   199
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   200
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   201
int write__klass__leakp(JfrCheckpointWriter* writer, const void* k) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   202
  assert(k != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   203
  KlassPtr klass = (KlassPtr)k;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   204
  return write_klass(writer, klass, true);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   205
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   206
58206
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   207
static bool is_implied(const Klass* klass) {
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   208
  assert(klass != NULL, "invariant");
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   209
  return klass->is_subclass_of(SystemDictionary::ClassLoader_klass()) || klass == SystemDictionary::Object_klass();
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   210
}
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   211
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   212
static void do_implied(Klass* klass) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   213
  assert(klass != NULL, "invariant");
58206
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   214
  if (is_implied(klass)) {
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   215
    if (_leakp_writer != NULL) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   216
      SET_LEAKP(klass);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   217
    }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   218
    _subsystem_callback->do_artifact(klass);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   219
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   220
}
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   221
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   222
static void do_unloaded_klass(Klass* klass) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   223
  assert(klass != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   224
  assert(_subsystem_callback != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   225
  if (IS_JDK_JFR_EVENT_SUBKLASS(klass)) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   226
    JfrEventClasses::increment_unloaded_event_class();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   227
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   228
  if (USED_THIS_EPOCH(klass)) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   229
    ObjectSampleCheckpoint::on_klass_unload(klass);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   230
    _subsystem_callback->do_artifact(klass);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   231
    return;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   232
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   233
  do_implied(klass);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   234
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   235
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   236
static void do_klass(Klass* klass) {
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   237
  assert(klass != NULL, "invariant");
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   238
  assert(_subsystem_callback != NULL, "invariant");
57870
00860d9caf4d New metadata system for oldobjects built on top of simplified tagging model. Caching and serialization improvements. Flushpoint checkpoint with chunkheader contents.
mgronlun
parents: 57360
diff changeset
   239
  if (_flushpoint) {
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   240
    if (USED_THIS_EPOCH(klass)) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   241
      _subsystem_callback->do_artifact(klass);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   242
      return;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   243
    }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   244
  } else {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   245
    if (USED_PREV_EPOCH(klass)) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   246
      _subsystem_callback->do_artifact(klass);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   247
      return;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   248
    }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   249
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   250
  do_implied(klass);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   251
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   252
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   253
static void do_klasses() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   254
  if (_class_unload) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   255
    ClassLoaderDataGraph::classes_unloading_do(&do_unloaded_klass);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   256
    return;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   257
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   258
  ClassLoaderDataGraph::classes_do(&do_klass);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   259
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   260
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   261
typedef SerializePredicate<KlassPtr> KlassPredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   262
typedef JfrPredicatedTypeWriterImplHost<KlassPtr, KlassPredicate, write__klass> KlassWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   263
typedef JfrTypeWriterHost<KlassWriterImpl, TYPE_CLASS> KlassWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   264
typedef CompositeFunctor<KlassPtr, KlassWriter, KlassArtifactRegistrator> KlassWriterRegistration;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   265
typedef JfrArtifactCallbackHost<KlassPtr, KlassWriterRegistration> KlassCallback;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   266
58206
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   267
template <>
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   268
class LeakPredicate<const Klass*> {
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   269
public:
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   270
  LeakPredicate(bool class_unload) {}
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   271
  bool operator()(const Klass* klass) {
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   272
    assert(klass != NULL, "invariant");
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   273
    return IS_LEAKP(klass) || is_implied(klass);
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   274
  }
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   275
};
87436c6f681f better leak predicate
mgronlun
parents: 58157
diff changeset
   276
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   277
typedef LeakPredicate<KlassPtr> LeakKlassPredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   278
typedef JfrPredicatedTypeWriterImplHost<KlassPtr, LeakKlassPredicate, write__klass__leakp> LeakKlassWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   279
typedef JfrTypeWriterHost<LeakKlassWriterImpl, TYPE_CLASS> LeakKlassWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   280
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   281
typedef CompositeFunctor<KlassPtr, LeakKlassWriter, KlassWriter> CompositeKlassWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   282
typedef CompositeFunctor<KlassPtr, CompositeKlassWriter, KlassArtifactRegistrator> CompositeKlassWriterRegistration;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   283
typedef JfrArtifactCallbackHost<KlassPtr, CompositeKlassWriterRegistration> CompositeKlassCallback;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   284
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   285
static bool write_klasses() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   286
  assert(!_artifacts->has_klass_entries(), "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   287
  assert(_writer != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   288
  KlassArtifactRegistrator reg(_artifacts);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   289
  KlassWriter kw(_writer, _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   290
  KlassWriterRegistration kwr(&kw, &reg);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   291
  if (_leakp_writer == NULL) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   292
    KlassCallback callback(&kwr);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   293
    _subsystem_callback = &callback;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   294
    do_klasses();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   295
  } else {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   296
    LeakKlassWriter lkw(_leakp_writer, _artifacts, _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   297
    CompositeKlassWriter ckw(&lkw, &kw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   298
    CompositeKlassWriterRegistration ckwr(&ckw, &reg);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   299
    CompositeKlassCallback callback(&ckwr);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   300
    _subsystem_callback = &callback;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   301
    do_klasses();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   302
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   303
  if (is_complete()) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   304
    return false;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   305
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   306
  _artifacts->tally(kw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   307
  return true;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   308
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   309
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   310
template <typename T>
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   311
static void do_previous_epoch_artifact(JfrArtifactClosure* callback, T* value) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   312
  assert(callback != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   313
  assert(value != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   314
  if (USED_PREV_EPOCH(value)) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   315
    callback->do_artifact(value);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   316
    assert(IS_NOT_SERIALIZED(value), "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   317
    return;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   318
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   319
  if (IS_SERIALIZED(value)) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   320
    CLEAR_SERIALIZED(value);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   321
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   322
  assert(IS_NOT_SERIALIZED(value), "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   323
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   324
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   325
static int write_package(JfrCheckpointWriter* writer, PkgPtr pkg, bool leakp) {
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   326
  assert(writer != NULL, "invariant");
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   327
  assert(_artifacts != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   328
  assert(pkg != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   329
  writer->write(artifact_id(pkg));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   330
  writer->write(mark_symbol(pkg->name(), leakp));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   331
  writer->write(module_id(pkg, leakp));
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   332
  writer->write((bool)pkg->is_exported());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   333
  return 1;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   334
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   335
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   336
int write__package(JfrCheckpointWriter* writer, const void* p) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   337
  assert(p != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   338
  PkgPtr pkg = (PkgPtr)p;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   339
  set_serialized(pkg);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   340
  return write_package(writer, pkg, false);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   341
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   342
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   343
int write__package__leakp(JfrCheckpointWriter* writer, const void* p) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   344
  assert(p != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   345
  PkgPtr pkg = (PkgPtr)p;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   346
  CLEAR_LEAKP(pkg);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   347
  return write_package(writer, pkg, true);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   348
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   349
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   350
static void do_package(PackageEntry* entry) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   351
  do_previous_epoch_artifact(_subsystem_callback, entry);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   352
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   353
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   354
static void do_packages() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   355
  ClassLoaderDataGraph::packages_do(&do_package);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   356
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   357
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   358
class PackageFieldSelector {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   359
 public:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   360
  typedef PkgPtr TypePtr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   361
  static TypePtr select(KlassPtr klass) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   362
    assert(klass != NULL, "invariant");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   363
    return ((InstanceKlass*)klass)->package();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   364
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   365
};
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   366
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   367
typedef SerializePredicate<PkgPtr> PackagePredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   368
typedef JfrPredicatedTypeWriterImplHost<PkgPtr, PackagePredicate, write__package> PackageWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   369
typedef JfrTypeWriterHost<PackageWriterImpl, TYPE_PACKAGE> PackageWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   370
typedef CompositeFunctor<PkgPtr, PackageWriter, ClearArtifact<PkgPtr> > PackageWriterWithClear;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   371
typedef KlassToFieldEnvelope<PackageFieldSelector, PackageWriter> KlassPackageWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   372
typedef JfrArtifactCallbackHost<PkgPtr, PackageWriterWithClear> PackageCallback;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   373
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   374
typedef LeakPredicate<PkgPtr> LeakPackagePredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   375
typedef JfrPredicatedTypeWriterImplHost<PkgPtr, LeakPackagePredicate, write__package__leakp> LeakPackageWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   376
typedef JfrTypeWriterHost<LeakPackageWriterImpl, TYPE_PACKAGE> LeakPackageWriter;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   377
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   378
typedef CompositeFunctor<PkgPtr, LeakPackageWriter, PackageWriter> CompositePackageWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   379
typedef KlassToFieldEnvelope<PackageFieldSelector, CompositePackageWriter> KlassCompositePackageWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   380
typedef KlassToFieldEnvelope<PackageFieldSelector, PackageWriterWithClear> KlassPackageWriterWithClear;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   381
typedef CompositeFunctor<PkgPtr, CompositePackageWriter, ClearArtifact<PkgPtr> > CompositePackageWriterWithClear;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   382
typedef JfrArtifactCallbackHost<PkgPtr, CompositePackageWriterWithClear> CompositePackageCallback;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   383
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   384
static void write_packages() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   385
  assert(_writer != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   386
  PackageWriter pw(_writer, _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   387
  KlassPackageWriter kpw(&pw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   388
  if (current_epoch()) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   389
    _artifacts->iterate_klasses(kpw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   390
    _artifacts->tally(pw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   391
    return;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   392
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   393
  assert(previous_epoch(), "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   394
  if (_leakp_writer == NULL) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   395
    _artifacts->iterate_klasses(kpw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   396
    ClearArtifact<PkgPtr> clear;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   397
    PackageWriterWithClear pwwc(&pw, &clear);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   398
    PackageCallback callback(&pwwc);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   399
    _subsystem_callback = &callback;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   400
    do_packages();
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   401
  } else {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   402
    LeakPackageWriter lpw(_leakp_writer, _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   403
    CompositePackageWriter cpw(&lpw, &pw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   404
    KlassCompositePackageWriter kcpw(&cpw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   405
    _artifacts->iterate_klasses(kcpw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   406
    ClearArtifact<PkgPtr> clear;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   407
    CompositePackageWriterWithClear cpwwc(&cpw, &clear);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   408
    CompositePackageCallback callback(&cpwwc);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   409
    _subsystem_callback = &callback;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   410
    do_packages();
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   411
  }
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   412
  _artifacts->tally(pw);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   413
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   414
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   415
static int write_module(JfrCheckpointWriter* writer, ModPtr mod, bool leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   416
  assert(mod != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   417
  assert(_artifacts != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   418
  writer->write(artifact_id(mod));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   419
  writer->write(mark_symbol(mod->name(), leakp));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   420
  writer->write(mark_symbol(mod->version(), leakp));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   421
  writer->write(mark_symbol(mod->location(), leakp));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   422
  writer->write(cld_id(mod->loader_data(), leakp));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   423
  return 1;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   424
}
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   425
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   426
int write__module(JfrCheckpointWriter* writer, const void* m) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   427
  assert(m != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   428
  ModPtr mod = (ModPtr)m;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   429
  set_serialized(mod);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   430
  return write_module(writer, mod, false);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   431
}
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   432
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   433
int write__module__leakp(JfrCheckpointWriter* writer, const void* m) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   434
  assert(m != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   435
  ModPtr mod = (ModPtr)m;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   436
  CLEAR_LEAKP(mod);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   437
  return write_module(writer, mod, true);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   438
}
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   439
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   440
static void do_module(ModuleEntry* entry) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   441
  do_previous_epoch_artifact(_subsystem_callback, entry);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   442
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   443
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   444
static void do_modules() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   445
  ClassLoaderDataGraph::modules_do(&do_module);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   446
}
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   447
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   448
class ModuleFieldSelector {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   449
 public:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   450
  typedef ModPtr TypePtr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   451
  static TypePtr select(KlassPtr klass) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   452
    assert(klass != NULL, "invariant");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   453
    PkgPtr pkg = klass->package();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   454
    return pkg != NULL ? pkg->module() : NULL;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   455
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   456
};
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   457
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   458
typedef SerializePredicate<ModPtr> ModulePredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   459
typedef JfrPredicatedTypeWriterImplHost<ModPtr, ModulePredicate, write__module> ModuleWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   460
typedef JfrTypeWriterHost<ModuleWriterImpl, TYPE_MODULE> ModuleWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   461
typedef CompositeFunctor<ModPtr, ModuleWriter, ClearArtifact<ModPtr> > ModuleWriterWithClear;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   462
typedef JfrArtifactCallbackHost<ModPtr, ModuleWriterWithClear> ModuleCallback;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   463
typedef KlassToFieldEnvelope<ModuleFieldSelector, ModuleWriter> KlassModuleWriter;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   464
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   465
typedef LeakPredicate<ModPtr> LeakModulePredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   466
typedef JfrPredicatedTypeWriterImplHost<ModPtr, LeakModulePredicate, write__module__leakp> LeakModuleWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   467
typedef JfrTypeWriterHost<LeakModuleWriterImpl, TYPE_MODULE> LeakModuleWriter;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   468
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   469
typedef CompositeFunctor<ModPtr, LeakModuleWriter, ModuleWriter> CompositeModuleWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   470
typedef KlassToFieldEnvelope<ModuleFieldSelector, CompositeModuleWriter> KlassCompositeModuleWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   471
typedef CompositeFunctor<ModPtr, CompositeModuleWriter, ClearArtifact<ModPtr> > CompositeModuleWriterWithClear;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   472
typedef JfrArtifactCallbackHost<ModPtr, CompositeModuleWriterWithClear> CompositeModuleCallback;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   473
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   474
static void write_modules() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   475
  assert(_writer != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   476
  ModuleWriter mw(_writer, _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   477
  KlassModuleWriter kmw(&mw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   478
  if (current_epoch()) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   479
    _artifacts->iterate_klasses(kmw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   480
    _artifacts->tally(mw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   481
    return;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   482
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   483
  assert(previous_epoch(), "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   484
  if (_leakp_writer == NULL) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   485
    _artifacts->iterate_klasses(kmw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   486
    ClearArtifact<ModPtr> clear;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   487
    ModuleWriterWithClear mwwc(&mw, &clear);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   488
    ModuleCallback callback(&mwwc);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   489
    _subsystem_callback = &callback;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   490
    do_modules();
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   491
  } else {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   492
    LeakModuleWriter lmw(_leakp_writer, _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   493
    CompositeModuleWriter cmw(&lmw, &mw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   494
    KlassCompositeModuleWriter kcpw(&cmw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   495
    _artifacts->iterate_klasses(kcpw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   496
    ClearArtifact<ModPtr> clear;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   497
    CompositeModuleWriterWithClear cmwwc(&cmw, &clear);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   498
    CompositeModuleCallback callback(&cmwwc);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   499
    _subsystem_callback = &callback;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   500
    do_modules();
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   501
  }
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   502
  _artifacts->tally(mw);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   503
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   504
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   505
static int write_classloader(JfrCheckpointWriter* writer, CldPtr cld, bool leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   506
  assert(cld != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   507
  assert(!cld->is_unsafe_anonymous(), "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   508
  // class loader type
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   509
  const Klass* class_loader_klass = cld->class_loader_klass();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   510
  if (class_loader_klass == NULL) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   511
    // (primordial) boot class loader
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   512
    writer->write(artifact_id(cld)); // class loader instance id
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   513
    writer->write((traceid)0);  // class loader type id (absence of)
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   514
    writer->write(get_bootstrap_name(leakp)); // maps to synthetic name -> "bootstrap"
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   515
  } else {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   516
    writer->write(artifact_id(cld)); // class loader instance id
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   517
    writer->write(artifact_id(class_loader_klass)); // class loader type id
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   518
    writer->write(mark_symbol(cld->name(), leakp)); // class loader instance name
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   519
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   520
  return 1;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   521
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   522
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   523
int write__classloader(JfrCheckpointWriter* writer, const void* c) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   524
  assert(c != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   525
  CldPtr cld = (CldPtr)c;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   526
  set_serialized(cld);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   527
  return write_classloader(writer, cld, false);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   528
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   529
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   530
int write__classloader__leakp(JfrCheckpointWriter* writer, const void* c) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   531
  assert(c != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   532
  CldPtr cld = (CldPtr)c;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   533
  CLEAR_LEAKP(cld);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   534
  return write_classloader(writer, cld, true);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   535
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   536
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   537
static void do_class_loader_data(ClassLoaderData* cld) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   538
  do_previous_epoch_artifact(_subsystem_callback, cld);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   539
}
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   540
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   541
class CldFieldSelector {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   542
 public:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   543
  typedef CldPtr TypePtr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   544
  static TypePtr select(KlassPtr klass) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   545
    assert(klass != NULL, "invariant");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   546
    CldPtr cld = klass->class_loader_data();
51444
3e5d28e6de32 8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents: 50634
diff changeset
   547
    return cld->is_unsafe_anonymous() ? NULL : cld;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   548
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   549
};
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   550
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   551
class CLDCallback : public CLDClosure {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   552
 public:
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   553
  CLDCallback() {}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   554
  void do_cld(ClassLoaderData* cld) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   555
    assert(cld != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   556
    if (cld->is_unsafe_anonymous()) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   557
      return;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   558
    }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   559
    do_class_loader_data(cld);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   560
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   561
};
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   562
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   563
static void do_class_loaders() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   564
  CLDCallback cld_cb;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   565
  ClassLoaderDataGraph::loaded_cld_do(&cld_cb);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   566
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   567
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   568
typedef SerializePredicate<CldPtr> CldPredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   569
typedef JfrPredicatedTypeWriterImplHost<CldPtr, CldPredicate, write__classloader> CldWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   570
typedef JfrTypeWriterHost<CldWriterImpl, TYPE_CLASSLOADER> CldWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   571
typedef CompositeFunctor<CldPtr, CldWriter, ClearArtifact<CldPtr> > CldWriterWithClear;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   572
typedef JfrArtifactCallbackHost<CldPtr, CldWriterWithClear> CldCallback;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   573
typedef KlassToFieldEnvelope<CldFieldSelector, CldWriter> KlassCldWriter;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   574
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   575
typedef LeakPredicate<CldPtr> LeakCldPredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   576
typedef JfrPredicatedTypeWriterImplHost<CldPtr, LeakCldPredicate, write__classloader__leakp> LeakCldWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   577
typedef JfrTypeWriterHost<LeakCldWriterImpl, TYPE_CLASSLOADER> LeakCldWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   578
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   579
typedef CompositeFunctor<CldPtr, LeakCldWriter, CldWriter> CompositeCldWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   580
typedef KlassToFieldEnvelope<CldFieldSelector, CompositeCldWriter> KlassCompositeCldWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   581
typedef CompositeFunctor<CldPtr, CompositeCldWriter, ClearArtifact<CldPtr> > CompositeCldWriterWithClear;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   582
typedef JfrArtifactCallbackHost<CldPtr, CompositeCldWriterWithClear> CompositeCldCallback;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   583
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   584
static void write_classloaders() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   585
  assert(_writer != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   586
  CldWriter cldw(_writer, _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   587
  KlassCldWriter kcw(&cldw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   588
  if (current_epoch()) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   589
    _artifacts->iterate_klasses(kcw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   590
    _artifacts->tally(cldw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   591
    return;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   592
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   593
  assert(previous_epoch(), "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   594
  if (_leakp_writer == NULL) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   595
    _artifacts->iterate_klasses(kcw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   596
    ClearArtifact<CldPtr> clear;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   597
    CldWriterWithClear cldwwc(&cldw, &clear);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   598
    CldCallback callback(&cldwwc);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   599
    _subsystem_callback = &callback;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   600
    do_class_loaders();
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   601
  } else {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   602
    LeakCldWriter lcldw(_leakp_writer, _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   603
    CompositeCldWriter ccldw(&lcldw, &cldw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   604
    KlassCompositeCldWriter kccldw(&ccldw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   605
    _artifacts->iterate_klasses(kccldw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   606
    ClearArtifact<CldPtr> clear;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   607
    CompositeCldWriterWithClear ccldwwc(&ccldw, &clear);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   608
    CompositeCldCallback callback(&ccldwwc);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   609
    _subsystem_callback = &callback;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   610
    do_class_loaders();
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   611
  }
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   612
  _artifacts->tally(cldw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   613
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   614
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   615
static u1 get_visibility(MethodPtr method) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   616
  assert(method != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   617
  return const_cast<Method*>(method)->is_hidden() ? (u1)1 : (u1)0;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   618
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   619
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   620
template <>
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   621
void set_serialized<Method>(MethodPtr method) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   622
  assert(method != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   623
  SET_METHOD_SERIALIZED(method);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   624
  assert(IS_METHOD_SERIALIZED(method), "invariant");
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   625
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   626
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   627
static int write_method(JfrCheckpointWriter* writer, MethodPtr method, bool leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   628
  assert(writer != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   629
  assert(method != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   630
  assert(_artifacts != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   631
  KlassPtr klass = method->method_holder();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   632
  assert(klass != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   633
  writer->write(method_id(klass, method));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   634
  writer->write(artifact_id(klass));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   635
  writer->write(mark_symbol(method->name(), leakp));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   636
  writer->write(mark_symbol(method->signature(), leakp));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   637
  writer->write((u2)get_flags(method));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   638
  writer->write(get_visibility(method));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   639
  return 1;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   640
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   641
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   642
int write__method(JfrCheckpointWriter* writer, const void* m) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   643
  assert(m != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   644
  MethodPtr method = (MethodPtr)m;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   645
  set_serialized(method);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   646
  return write_method(writer, method, false);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   647
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   648
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   649
int write__method__leakp(JfrCheckpointWriter* writer, const void* m) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   650
  assert(m != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   651
  MethodPtr method = (MethodPtr)m;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   652
  return write_method(writer, method, true);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   653
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   654
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   655
template <typename MethodCallback, typename KlassCallback, bool leakp>
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   656
class MethodIteratorHost {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   657
 private:
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   658
  MethodCallback _method_cb;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   659
  KlassCallback _klass_cb;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   660
  MethodUsedPredicate<leakp> _method_used_predicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   661
  MethodFlagPredicate<leakp> _method_flag_predicate;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   662
 public:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   663
  MethodIteratorHost(JfrCheckpointWriter* writer,
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   664
                     bool current_epoch = false,
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   665
                     bool class_unload = false,
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   666
                     bool skip_header = false) :
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   667
    _method_cb(writer, class_unload, skip_header),
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   668
    _klass_cb(writer, class_unload, skip_header),
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   669
    _method_used_predicate(current_epoch),
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   670
    _method_flag_predicate(current_epoch) {}
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   671
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   672
  bool operator()(KlassPtr klass) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   673
    if (_method_used_predicate(klass)) {
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   674
      const InstanceKlass* const ik = InstanceKlass::cast(klass);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   675
      const int len = ik->methods()->length();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   676
      for (int i = 0; i < len; ++i) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   677
        MethodPtr method = ik->methods()->at(i);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   678
        if (_method_flag_predicate(method)) {
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   679
          _method_cb(method);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   680
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   681
      }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   682
    }
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   683
    return _klass_cb(klass);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   684
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   685
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   686
  int count() const { return _method_cb.count(); }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   687
  void add(int count) { _method_cb.add(count); }
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   688
};
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   689
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   690
template <typename T, template <typename> class Impl>
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   691
class Wrapper {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   692
  Impl<T> _t;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   693
 public:
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   694
  Wrapper(JfrCheckpointWriter*, bool, bool) : _t() {}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   695
  bool operator()(T const& value) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   696
    return _t(value);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   697
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   698
};
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   699
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   700
typedef SerializePredicate<MethodPtr> MethodPredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   701
typedef JfrPredicatedTypeWriterImplHost<MethodPtr, MethodPredicate, write__method> MethodWriterImplTarget;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   702
typedef Wrapper<KlassPtr, Stub> KlassCallbackStub;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   703
typedef JfrTypeWriterHost<MethodWriterImplTarget, TYPE_METHOD> MethodWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   704
typedef MethodIteratorHost<MethodWriterImpl, KlassCallbackStub, false> MethodWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   705
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   706
typedef LeakPredicate<MethodPtr> LeakMethodPredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   707
typedef JfrPredicatedTypeWriterImplHost<MethodPtr, LeakMethodPredicate, write__method__leakp> LeakMethodWriterImplTarget;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   708
typedef JfrTypeWriterHost<LeakMethodWriterImplTarget, TYPE_METHOD> LeakMethodWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   709
typedef MethodIteratorHost<LeakMethodWriterImpl, KlassCallbackStub, true> LeakMethodWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   710
typedef CompositeFunctor<KlassPtr, LeakMethodWriter, MethodWriter> CompositeMethodWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   711
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   712
static void write_methods() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   713
  assert(_writer != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   714
  MethodWriter mw(_writer, current_epoch(), _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   715
  if (_leakp_writer == NULL) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   716
    _artifacts->iterate_klasses(mw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   717
  } else {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   718
    LeakMethodWriter lpmw(_leakp_writer, current_epoch(), _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   719
    CompositeMethodWriter cmw(&lpmw, &mw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   720
    _artifacts->iterate_klasses(cmw);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   721
  }
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   722
  _artifacts->tally(mw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   723
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   724
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   725
template <>
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   726
void set_serialized<JfrSymbolId::SymbolEntry>(SymbolEntryPtr ptr) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   727
  assert(ptr != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   728
  ptr->set_serialized();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   729
  assert(ptr->is_serialized(), "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   730
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   731
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   732
template <>
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   733
void set_serialized<JfrSymbolId::CStringEntry>(CStringEntryPtr ptr) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   734
  assert(ptr != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   735
  ptr->set_serialized();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   736
  assert(ptr->is_serialized(), "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   737
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   738
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   739
static int write_symbol(JfrCheckpointWriter* writer, SymbolEntryPtr entry, bool leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   740
  assert(writer != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   741
  assert(entry != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   742
  ResourceMark rm;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   743
  writer->write(create_symbol_id(entry->id()));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   744
  writer->write(entry->value()->as_C_string());
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   745
  return 1;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   746
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   747
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   748
int write__symbol(JfrCheckpointWriter* writer, const void* e) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   749
  assert(e != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   750
  SymbolEntryPtr entry = (SymbolEntryPtr)e;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   751
  set_serialized(entry);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   752
  return write_symbol(writer, entry, false);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   753
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   754
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   755
int write__symbol__leakp(JfrCheckpointWriter* writer, const void* e) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   756
  assert(e != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   757
  SymbolEntryPtr entry = (SymbolEntryPtr)e;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   758
  return write_symbol(writer, entry, true);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   759
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   760
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   761
static int write_cstring(JfrCheckpointWriter* writer, CStringEntryPtr entry, bool leakp) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   762
  assert(writer != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   763
  assert(entry != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   764
  writer->write(create_symbol_id(entry->id()));
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   765
  writer->write(entry->value());
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   766
  return 1;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   767
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   768
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   769
int write__cstring(JfrCheckpointWriter* writer, const void* e) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   770
  assert(e != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   771
  CStringEntryPtr entry = (CStringEntryPtr)e;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   772
  set_serialized(entry);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   773
  return write_cstring(writer, entry, false);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   774
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   775
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   776
int write__cstring__leakp(JfrCheckpointWriter* writer, const void* e) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   777
  assert(e != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   778
  CStringEntryPtr entry = (CStringEntryPtr)e;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   779
  return write_cstring(writer, entry, true);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   780
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   781
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   782
typedef SymbolPredicate<SymbolEntryPtr, false> SymPredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   783
typedef JfrPredicatedTypeWriterImplHost<SymbolEntryPtr, SymPredicate, write__symbol> SymbolEntryWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   784
typedef JfrTypeWriterHost<SymbolEntryWriterImpl, TYPE_SYMBOL> SymbolEntryWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   785
typedef SymbolPredicate<CStringEntryPtr, false> CStringPredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   786
typedef JfrPredicatedTypeWriterImplHost<CStringEntryPtr, CStringPredicate, write__cstring> CStringEntryWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   787
typedef JfrTypeWriterHost<CStringEntryWriterImpl, TYPE_SYMBOL> CStringEntryWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   788
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   789
typedef SymbolPredicate<SymbolEntryPtr, true> LeakSymPredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   790
typedef JfrPredicatedTypeWriterImplHost<SymbolEntryPtr, LeakSymPredicate, write__symbol__leakp> LeakSymbolEntryWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   791
typedef JfrTypeWriterHost<LeakSymbolEntryWriterImpl, TYPE_SYMBOL> LeakSymbolEntryWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   792
typedef CompositeFunctor<SymbolEntryPtr, LeakSymbolEntryWriter, SymbolEntryWriter> CompositeSymbolWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   793
typedef SymbolPredicate<CStringEntryPtr, true> LeakCStringPredicate;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   794
typedef JfrPredicatedTypeWriterImplHost<CStringEntryPtr, LeakCStringPredicate, write__cstring__leakp> LeakCStringEntryWriterImpl;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   795
typedef JfrTypeWriterHost<LeakCStringEntryWriterImpl, TYPE_SYMBOL> LeakCStringEntryWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   796
typedef CompositeFunctor<CStringEntryPtr, LeakCStringEntryWriter, CStringEntryWriter> CompositeCStringWriter;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   797
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   798
static void write_symbols_with_leakp() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   799
  assert(_leakp_writer != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   800
  SymbolEntryWriter sw(_writer, _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   801
  LeakSymbolEntryWriter lsw(_leakp_writer, _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   802
  CompositeSymbolWriter csw(&lsw, &sw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   803
  _artifacts->iterate_symbols(csw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   804
  CStringEntryWriter ccsw(_writer, _class_unload, true); // skip header
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   805
  LeakCStringEntryWriter lccsw(_leakp_writer, _class_unload, true); // skip header
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   806
  CompositeCStringWriter cccsw(&lccsw, &ccsw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   807
  _artifacts->iterate_cstrings(cccsw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   808
  sw.add(ccsw.count());
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   809
  lsw.add(lccsw.count());
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   810
  _artifacts->tally(sw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   811
}
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   812
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   813
static void write_symbols() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   814
  assert(_writer != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   815
  if (_leakp_writer != NULL) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   816
    write_symbols_with_leakp();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   817
    return;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   818
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   819
  SymbolEntryWriter sw(_writer, _class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   820
  _artifacts->iterate_symbols(sw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   821
  CStringEntryWriter csw(_writer, _class_unload, true); // skip header
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   822
  _artifacts->iterate_cstrings(csw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   823
  sw.add(csw.count());
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   824
  _artifacts->tally(sw);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   825
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   826
58251
c4067538a0f2 Missing object id in pool jdk.types.Symbol. All ids should reference object
mgronlun
parents: 58206
diff changeset
   827
static bool clear_artifacts = false;
c4067538a0f2 Missing object id in pool jdk.types.Symbol. All ids should reference object
mgronlun
parents: 58206
diff changeset
   828
c4067538a0f2 Missing object id in pool jdk.types.Symbol. All ids should reference object
mgronlun
parents: 58206
diff changeset
   829
void JfrTypeSet::clear() {
c4067538a0f2 Missing object id in pool jdk.types.Symbol. All ids should reference object
mgronlun
parents: 58206
diff changeset
   830
  clear_artifacts = true;
c4067538a0f2 Missing object id in pool jdk.types.Symbol. All ids should reference object
mgronlun
parents: 58206
diff changeset
   831
}
c4067538a0f2 Missing object id in pool jdk.types.Symbol. All ids should reference object
mgronlun
parents: 58206
diff changeset
   832
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   833
typedef Wrapper<KlassPtr, ClearArtifact> ClearKlassBits;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   834
typedef Wrapper<MethodPtr, ClearArtifact> ClearMethodFlag;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   835
typedef MethodIteratorHost<ClearMethodFlag, ClearKlassBits, false> ClearKlassAndMethods;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   836
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   837
static size_t teardown() {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   838
  assert(_artifacts != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   839
  const size_t total_count = _artifacts->total_count();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   840
  if (previous_epoch()) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   841
    assert(_writer != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   842
    ClearKlassAndMethods clear(_writer);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   843
    _artifacts->iterate_klasses(clear);
58251
c4067538a0f2 Missing object id in pool jdk.types.Symbol. All ids should reference object
mgronlun
parents: 58206
diff changeset
   844
    JfrTypeSet::clear();
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   845
    ++checkpoint_id;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   846
  }
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   847
  return total_count;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   848
}
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   849
57983
a57907813a83 old object sample blob:ification and serialization support
mgronlun
parents: 57870
diff changeset
   850
static void setup(JfrCheckpointWriter* writer, JfrCheckpointWriter* leakp_writer, bool class_unload, bool flushpoint) {
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   851
  _writer = writer;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   852
  _leakp_writer = leakp_writer;
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   853
  _class_unload = class_unload;
57870
00860d9caf4d New metadata system for oldobjects built on top of simplified tagging model. Caching and serialization improvements. Flushpoint checkpoint with chunkheader contents.
mgronlun
parents: 57360
diff changeset
   854
  _flushpoint = flushpoint;
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   855
  if (_artifacts == NULL) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   856
    _artifacts = new JfrArtifactSet(class_unload);
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   857
  } else {
58251
c4067538a0f2 Missing object id in pool jdk.types.Symbol. All ids should reference object
mgronlun
parents: 58206
diff changeset
   858
    _artifacts->initialize(class_unload, clear_artifacts);
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   859
  }
58259
b6efcf2217f1 clear_artifacts in the correct location
mgronlun
parents: 58251
diff changeset
   860
  clear_artifacts = false;
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   861
  assert(_artifacts != NULL, "invariant");
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   862
  assert(!_artifacts->has_klass_entries(), "invariant");
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   863
}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   864
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   865
/**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   866
 * Write all "tagged" (in-use) constant artifacts and their dependencies.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   867
 */
57983
a57907813a83 old object sample blob:ification and serialization support
mgronlun
parents: 57870
diff changeset
   868
size_t JfrTypeSet::serialize(JfrCheckpointWriter* writer, JfrCheckpointWriter* leakp_writer, bool class_unload, bool flushpoint) {
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   869
  assert(writer != NULL, "invariant");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   870
  ResourceMark rm;
57983
a57907813a83 old object sample blob:ification and serialization support
mgronlun
parents: 57870
diff changeset
   871
  setup(writer, leakp_writer, class_unload, flushpoint);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   872
  // write order is important because an individual write step
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   873
  // might tag an artifact to be written in a subsequent step
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   874
  if (!write_klasses()) {
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   875
    return 0;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   876
  }
58132
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   877
  write_packages();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   878
  write_modules();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   879
  write_classloaders();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   880
  write_methods();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   881
  write_symbols();
caa25ab47aca 8225797: OldObjectSample event creates unexpected amount of checkpoint data
mgronlun
parents: 52586
diff changeset
   882
  return teardown();
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   883
}