src/hotspot/share/jfr/recorder/checkpoint/jfrCheckpointManager.hpp
author mgronlun
Wed, 30 Oct 2019 19:43:52 +0100
changeset 58863 c16ac7a2eba4
parent 58132 caa25ab47aca
permissions -rw-r--r--
8226511: Implement JFR Event Streaming Reviewed-by: egahlin, mseledtsov, mgronlun Contributed-by: erik.gahlin@oracle.com, mikhailo.seledtsov@oracle.com, markus.gronlund@oracle.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     1
/*
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 50703
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
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 50703
diff changeset
    25
#ifndef SHARE_JFR_RECORDER_CHECKPOINT_JFRCHECKPOINTMANAGER_HPP
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 50703
diff changeset
    26
#define SHARE_JFR_RECORDER_CHECKPOINT_JFRCHECKPOINTMANAGER_HPP
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    27
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    28
#include "jfr/recorder/storage/jfrBuffer.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    29
#include "jfr/recorder/storage/jfrMemorySpace.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    30
#include "jfr/recorder/storage/jfrMemorySpaceRetrieval.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    31
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    32
class JfrCheckpointManager;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    33
class JfrChunkWriter;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    34
class JfrSerializer;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    35
class JfrTypeManager;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    36
class Mutex;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    37
class Thread;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    38
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    39
struct JfrCheckpointEntry {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    40
  jlong size;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    41
  jlong start_time;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    42
  jlong duration;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    43
  juint flushpoint;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    44
  juint nof_segments;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    45
};
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    46
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    47
typedef JfrMemorySpace<JfrBuffer, JfrMspaceSequentialRetrieval, JfrCheckpointManager> JfrCheckpointMspace;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    48
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    49
//
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    50
// Responsible for maintaining checkpoints and by implication types.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    51
// A checkpoint is an event that has a payload consisting of constant types.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    52
// A constant type is a binary relation, a set of key-value pairs.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    53
//
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    54
class JfrCheckpointManager : public JfrCHeapObj {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    55
 public:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    56
  typedef JfrCheckpointMspace::Type Buffer;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    57
 private:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    58
  JfrCheckpointMspace* _free_list_mspace;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    59
  JfrCheckpointMspace* _epoch_transition_mspace;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    60
  Mutex* _lock;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    61
  const Thread* _service_thread;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    62
  JfrChunkWriter& _chunkwriter;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    63
  bool _checkpoint_epoch_state;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    64
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    65
  // mspace callback
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    66
  void register_full(Buffer* t, Thread* thread);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    67
  void lock();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    68
  void unlock();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    69
  DEBUG_ONLY(bool is_locked() const;)
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    70
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    71
  JfrCheckpointMspace* lookup(Buffer* old) const;
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    72
  bool use_epoch_transition_mspace(const Thread* t) const;
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    73
  size_t write_epoch_transition_mspace();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    74
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    75
  static Buffer* lease_buffer(Thread* t, size_t size = 0);
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    76
  static Buffer* lease_buffer(Buffer* old, Thread* t, size_t size = 0);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    77
  static Buffer* flush(Buffer* old, size_t used, size_t requested, Thread* t);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    78
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    79
  size_t clear();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    80
  size_t write();
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    81
  size_t flush();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    82
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    83
  bool is_static_type_set_required();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    84
  size_t write_static_type_set();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    85
  size_t write_threads();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    86
  size_t write_static_type_set_and_threads();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    87
  bool is_type_set_required();
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    88
  void write_type_set();
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    89
  static void write_type_set_for_unloaded_classes();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    90
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    91
  void shift_epoch();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    92
  void synchronize_epoch();
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
    93
  void notify_threads();
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    94
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    95
  JfrCheckpointManager(JfrChunkWriter& cw);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    96
  ~JfrCheckpointManager();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    97
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    98
  static JfrCheckpointManager& instance();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    99
  static JfrCheckpointManager* create(JfrChunkWriter& cw);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   100
  bool initialize();
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
   101
  void on_rotation();
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   102
  static void destroy();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   103
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   104
 public:
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
   105
  size_t flush_type_set();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
   106
  void flush_static_type_set();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
   107
  static void create_thread_blob(Thread* t);
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
   108
  static void write_thread_checkpoint(Thread* t);
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   109
  void register_service_thread(const Thread* t);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   110
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 58132
diff changeset
   111
  friend class Jfr;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   112
  friend class JfrRecorder;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   113
  friend class JfrRecorderService;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   114
  friend class JfrCheckpointFlush;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   115
  friend class JfrCheckpointWriter;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   116
  friend class JfrSerializer;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   117
  friend class JfrStackTraceRepository;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   118
  template <typename, template <typename> class, typename>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   119
  friend class JfrMemorySpace;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   120
};
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   121
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 50703
diff changeset
   122
#endif // SHARE_JFR_RECORDER_CHECKPOINT_JFRCHECKPOINTMANAGER_HPP