test/lib/jdk/test/lib/jfr/GCHelper.java
author mgronlun
Wed, 30 Oct 2019 19:43:52 +0100
changeset 58863 c16ac7a2eba4
parent 54956 43340a79840d
child 59053 ba6c248cae19
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
/*
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     2
 * Copyright (c) 2013, 2018, Oracle and/or its affiliates. All rights reserved.
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.  Oracle designates this
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    10
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    15
 * accompanied this code).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    16
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    20
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    23
 * questions.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    24
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    25
package jdk.test.lib.jfr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    26
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    27
import static jdk.test.lib.Asserts.assertEquals;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    28
import static jdk.test.lib.Asserts.assertNotEquals;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    29
import static jdk.test.lib.Asserts.assertNotNull;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    30
import static jdk.test.lib.Asserts.assertNull;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    31
import static jdk.test.lib.Asserts.fail;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    32
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    33
import java.io.FileOutputStream;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    34
import java.io.IOException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    35
import java.io.PrintStream;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    36
import java.lang.management.GarbageCollectorMXBean;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    37
import java.lang.management.ManagementFactory;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    38
import java.time.Instant;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    39
import java.util.ArrayList;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    40
import java.util.Arrays;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    41
import java.util.Collections;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    42
import java.util.HashMap;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    43
import java.util.HashSet;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    44
import java.util.List;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    45
import java.util.Map;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    46
import java.util.Set;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    47
import java.util.Stack;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    48
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    49
import jdk.jfr.ValueDescriptor;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    50
import jdk.jfr.consumer.RecordedEvent;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    51
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    52
/**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    53
 * Mixed helper classes to test GC events.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    54
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    55
public class GCHelper {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    56
    public static final String event_garbage_collection = EventNames.GarbageCollection;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    57
    public static final String event_young_garbage_collection = EventNames.YoungGarbageCollection;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    58
    public static final String event_old_garbage_collection = EventNames.OldGarbageCollection;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    59
    public static final String event_parold_garbage_collection = EventNames.ParallelOldCollection;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    60
    public static final String event_g1_garbage_collection = EventNames.G1GarbageCollection;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    61
    public static final String event_heap_summary = EventNames.GCHeapSummary;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    62
    public static final String event_heap_ps_summary = EventNames.PSHeapSummary;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    63
    public static final String event_heap_metaspace_summary = EventNames.MetaspaceSummary;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    64
    public static final String event_reference_statistics = EventNames.GCReferenceStatistics;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    65
    public static final String event_phases_pause = EventNames.GCPhasePause;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    66
    public static final String event_phases_level_1 = EventNames.GCPhasePauseLevel1;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    67
    public static final String event_phases_level_2 = EventNames.GCPhasePauseLevel2;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    68
    public static final String event_phases_level_3 = EventNames.GCPhasePauseLevel3;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    69
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    70
    public static final String gcG1New = "G1New";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    71
    public static final String gcParNew = "ParNew";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    72
    public static final String gcDefNew = "DefNew";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    73
    public static final String gcParallelScavenge = "ParallelScavenge";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    74
    public static final String gcG1Old = "G1Old";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    75
    public static final String gcG1Full = "G1Full";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    76
    public static final String gcConcurrentMarkSweep = "ConcurrentMarkSweep";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    77
    public static final String gcSerialOld = "SerialOld";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    78
    public static final String gcPSMarkSweep = "PSMarkSweep";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    79
    public static final String gcParallelOld = "ParallelOld";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    80
    public static final String pauseLevelEvent = "GCPhasePauseLevel";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    81
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    82
    private static final List<String> g1HeapRegionTypes;
54956
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
    83
    private static final List<String> shenandoahHeapRegionStates;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    84
    private static PrintStream defaultErrorLog = null;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    85
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    86
    public static int getGcId(RecordedEvent event) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    87
        return Events.assertField(event, "gcId").getValue();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    88
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    89
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    90
    public static boolean isGcEvent(RecordedEvent event) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    91
        for (ValueDescriptor v : event.getFields()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    92
            if ("gcId".equals(v.getName())) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    93
                return true;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    94
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    95
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    96
        return false;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    97
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    98
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    99
//    public static String getEventDesc(RecordedEvent event) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   100
//      final String path = event.getEventType().getName();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   101
//        if (!isGcEvent(event)) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   102
//            return path;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   103
//        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   104
//        if (event_garbage_collection.equals(path)) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   105
//            String name = Events.assertField(event, "name").getValue();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   106
//            String cause = Events.assertField(event, "cause").getValue();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   107
//            return String.format("path=%s, gcId=%d, endTime=%d, name=%s, cause=%s, startTime=%d",
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   108
//                    path, getGcId(event), event.getEndTime(), name, cause, event.getStartTime());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   109
//        } else {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   110
//            return String.format("path=%s, gcId=%d, endTime=%d", path, getGcId(event), event.getEndTime());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   111
//        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   112
//    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   114
    public static RecordedEvent getConfigEvent(List<RecordedEvent> events) throws Exception {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   115
        for (RecordedEvent event : events) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   116
            if (EventNames.GCConfiguration.equals(event.getEventType().getName())) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   117
                return event;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   118
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   119
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   120
        fail("Could not find event " + EventNames.GCConfiguration);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   121
        return null;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   122
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   123
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   124
    public static void callSystemGc(int num, boolean withGarbage) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   125
        for (int i = 0; i < num; i++) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   126
            if (withGarbage) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   127
                makeGarbage();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   128
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   129
            System.gc();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   130
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   131
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   132
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   133
    private static void makeGarbage() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   134
        Object[] garbage = new Object[1024];
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   135
        for (int i = 0; i < 1024; i++) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   136
            garbage[i] = new Object();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   137
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   138
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   139
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   140
    // Removes gcEvents with lowest and highest gcID. This is used to filter out
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   141
    // any incomplete GCs if the recording started/stopped in the middle of a GC.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   142
    // We also filters out events without gcId. Those events are not needed.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   143
    public static List<RecordedEvent> removeFirstAndLastGC(List<RecordedEvent> events) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   144
        int minGcId = Integer.MAX_VALUE;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   145
        int maxGcId = Integer.MIN_VALUE;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   146
        // Find min/max gcId
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   147
        for (RecordedEvent event : events) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   148
            if (Events.hasField(event, "gcId")) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   149
                int gcId = Events.assertField(event, "gcId").getValue();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   150
                minGcId = Math.min(gcId, minGcId);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   151
                maxGcId = Math.max(gcId, maxGcId);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   152
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   153
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   154
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   155
        // Add all events except those with gcId = min/max gcId
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   156
        List<RecordedEvent> filteredEvents = new ArrayList<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   157
        for (RecordedEvent event : events) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   158
            if (Events.hasField(event, "gcId")) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   159
                int gcId = Events.assertField(event, "gcId").getValue();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   160
                if (gcId != minGcId && gcId != maxGcId) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   161
                    filteredEvents.add(event);
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
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   165
        return filteredEvents;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   166
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   167
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   168
    public static Map<String, Boolean> beanCollectorTypes = new HashMap<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   169
    public static Set<String> collectorOverrides = new HashSet<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   170
    public static Map<String, String[]> requiredEvents = new HashMap<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   171
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   172
    static {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   173
        // young GarbageCollectionMXBeans.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   174
        beanCollectorTypes.put("G1 Young Generation", true);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   175
        beanCollectorTypes.put("Copy", true);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   176
        beanCollectorTypes.put("PS Scavenge", true);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   177
        beanCollectorTypes.put("ParNew", true);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   178
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   179
        // old GarbageCollectionMXBeans.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   180
        beanCollectorTypes.put("G1 Old Generation", false);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   181
        beanCollectorTypes.put("ConcurrentMarkSweep", false);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   182
        beanCollectorTypes.put("PS MarkSweep", false);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   183
        beanCollectorTypes.put("MarkSweepCompact", false);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   184
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   185
        // List of expected collector overrides. "A.B" means that collector A may use collector B.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   186
        collectorOverrides.add("G1Old.G1Full");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   187
        collectorOverrides.add("ConcurrentMarkSweep.SerialOld");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   188
        collectorOverrides.add("SerialOld.PSMarkSweep");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   189
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   190
        requiredEvents.put(gcG1New, new String[] {event_heap_summary, event_young_garbage_collection});
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   191
        requiredEvents.put(gcParNew, new String[] {event_heap_summary, event_heap_metaspace_summary, event_phases_pause, event_phases_level_1, event_young_garbage_collection});
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   192
        requiredEvents.put(gcDefNew, new String[] {event_heap_summary, event_heap_metaspace_summary, event_phases_pause, event_phases_level_1, event_young_garbage_collection});
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   193
        requiredEvents.put(gcParallelScavenge, new String[] {event_heap_summary, event_heap_ps_summary, event_heap_metaspace_summary, event_reference_statistics, event_phases_pause, event_phases_level_1, event_young_garbage_collection});
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   194
        requiredEvents.put(gcG1Old, new String[] {event_heap_summary, event_old_garbage_collection});
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   195
        requiredEvents.put(gcG1Full, new String[] {event_heap_summary, event_heap_metaspace_summary, event_phases_pause, event_phases_level_1, event_old_garbage_collection});
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   196
        requiredEvents.put(gcConcurrentMarkSweep, new String[] {event_phases_pause, event_phases_level_1, event_old_garbage_collection});
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   197
        requiredEvents.put(gcSerialOld, new String[] {event_heap_summary, event_heap_metaspace_summary, event_phases_pause, event_phases_level_1, event_old_garbage_collection});
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   198
        requiredEvents.put(gcParallelOld, new String[] {event_heap_summary, event_heap_ps_summary, event_heap_metaspace_summary, event_reference_statistics, event_phases_pause, event_phases_level_1, event_old_garbage_collection, event_parold_garbage_collection});
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   199
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   200
        String[] g1HeapRegionTypeLiterals = new String[] {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   201
                                                           "Free",
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   202
                                                           "Eden",
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   203
                                                           "Survivor",
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   204
                                                           "Starts Humongous",
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   205
                                                           "Continues Humongous",
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   206
                                                           "Old",
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   207
                                                           "Archive"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   208
                                                         };
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   209
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   210
        g1HeapRegionTypes = Collections.unmodifiableList(Arrays.asList(g1HeapRegionTypeLiterals));
54956
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   211
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   212
        String[] shenandoahHeapRegionStateLiterals = new String[] {
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   213
                                                                    "Empty Uncommitted",
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   214
                                                                    "Empty Committed",
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   215
                                                                    "Regular",
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   216
                                                                    "Humongous Start",
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   217
                                                                    "Humongous Continuation",
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   218
                                                                    "Humongous Start, Pinned",
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   219
                                                                    "Collection Set",
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   220
                                                                    "Pinned",
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   221
                                                                    "Collection Set, Pinned",
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   222
                                                                    "Trash"
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   223
        };
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   224
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   225
        shenandoahHeapRegionStates = Collections.unmodifiableList(Arrays.asList(shenandoahHeapRegionStateLiterals));
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   226
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   227
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   228
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   229
     * Contains all GC events belonging to the same GC (same gcId).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   230
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   231
    public static class GcBatch {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   232
        private List<RecordedEvent> events = new ArrayList<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   233
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   234
        public int getGcId() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   235
            if (events.isEmpty()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   236
                return -1;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   237
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   238
            return GCHelper.getGcId(events.get(0));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   239
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   240
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   241
        public String getName() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   242
            RecordedEvent endEvent = getEndEvent();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   243
            String name = endEvent == null ? null : Events.assertField(endEvent, "name").getValue();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   244
            return name == null ? "null" : name;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   245
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   246
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   247
        public RecordedEvent getEndEvent() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   248
            return getEvent(event_garbage_collection);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   249
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   250
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   251
        public boolean addEvent(RecordedEvent event) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   252
            if (!events.isEmpty()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   253
                assertEquals(getGcId(), GCHelper.getGcId(event), "Wrong gcId in event. Error in test code.");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   254
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   255
            boolean isEndEvent = event_garbage_collection.equals(event.getEventType().getName());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   256
            if (isEndEvent) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   257
                // Verify that we have not already got a garbage_collection event with this gcId.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   258
                assertNull(getEndEvent(), String.format("Multiple %s for gcId %d", event_garbage_collection, getGcId()));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   259
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   260
            events.add(event);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   261
            return isEndEvent;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   262
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   263
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   264
        public boolean isYoungCollection() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   265
            boolean isYoung = containsEvent(event_young_garbage_collection);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   266
            boolean isOld = containsEvent(event_old_garbage_collection);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   267
            assertNotEquals(isYoung, isOld, "isYoung and isOld was same for batch: " + toString());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   268
            return isYoung;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   269
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   270
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   271
        public int getEventCount() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   272
            return events.size();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   273
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   274
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   275
        public RecordedEvent getEvent(int index) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   276
            return events.get(index);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   277
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   278
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   279
        public List<RecordedEvent> getEvents() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   280
            return events;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   281
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   282
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   283
        public RecordedEvent getEvent(String eventPath) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   284
            for (RecordedEvent event : events) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   285
                if (eventPath.equals(event.getEventType().getName())) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   286
                    return event;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   287
                }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   288
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   289
            return null;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   290
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   291
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   292
        public boolean containsEvent(String eventPath) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   293
            return getEvent(eventPath) != null;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   294
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   295
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   296
        public String toString() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   297
            RecordedEvent endEvent = getEndEvent();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   298
            Instant startTime = Instant.EPOCH;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   299
            String cause = "?";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   300
            String name = "?";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   301
            if (endEvent != null) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   302
                name = getName();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   303
                startTime = endEvent.getStartTime();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   304
                cause = Events.assertField(endEvent, "cause").getValue();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   305
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   306
            return String.format("GcEvent: gcId=%d, method=%s, cause=%s, startTime=%s",
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   307
                    getGcId(), name, cause, startTime);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   308
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   309
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   310
        public String getLog() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   311
            StringBuilder sb = new StringBuilder();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   312
            sb.append(this.toString() + System.getProperty("line.separator"));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   313
            for (RecordedEvent event : events) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   314
                sb.append(String.format("event: %s%n", event));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   315
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   316
            return sb.toString();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   317
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   318
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   319
        // Group all events info batches.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   320
        public static List<GcBatch> createFromEvents(List<RecordedEvent> events) throws Exception {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   321
            Stack<Integer> openGcIds = new Stack<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   322
            List<GcBatch> batches = new ArrayList<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   323
            GcBatch currBatch = null;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   324
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   325
            for (RecordedEvent event : events) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   326
                if (!isGcEvent(event)) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   327
                    continue;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   328
                }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   329
                int gcId = GCHelper.getGcId(event);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   330
                if (currBatch == null || currBatch.getGcId() != gcId) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   331
                    currBatch = null;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   332
                    // Search for existing batch
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   333
                    for (GcBatch loopBatch : batches) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   334
                        if (gcId == loopBatch.getGcId()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   335
                            currBatch = loopBatch;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   336
                            break;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   337
                        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   338
                    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   339
                    if (currBatch == null) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   340
                        // No existing batch. Create new.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   341
                        currBatch = new GcBatch();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   342
                        batches.add(currBatch);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   343
                        openGcIds.push(new Integer(gcId));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   344
                    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   345
                }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   346
                boolean isEndEvent = currBatch.addEvent(event);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   347
                if (isEndEvent) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   348
                    openGcIds.pop();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   349
                }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   350
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   351
            // Verify that all start_garbage_collection events have received a corresponding "garbage_collection" event.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   352
            for (GcBatch batch : batches) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   353
                if (batch.getEndEvent() == null) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   354
                    System.out.println(batch.getLog());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   355
                }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   356
                assertNotNull(batch.getEndEvent(), "GcBatch has no end event");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   357
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   358
            return batches;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   359
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   360
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   361
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   362
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   363
     * Contains number of collections and sum pause time for young and old collections.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   364
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   365
    public static class CollectionSummary {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   366
        public long collectionCountOld;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   367
        public long collectionCountYoung;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   368
        public long collectionTimeOld;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   369
        public long collectionTimeYoung;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   370
        private Set<String> names = new HashSet<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   371
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   372
        public void add(String collectorName, boolean isYoung, long count, long time) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   373
            if (isYoung) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   374
                collectionCountYoung += count;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   375
                collectionTimeYoung += time;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   376
            } else {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   377
                collectionCountOld += count;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   378
                collectionTimeOld += time;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   379
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   380
            if (!names.contains(collectorName)) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   381
                names.add(collectorName);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   382
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   383
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   384
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   385
        public long sum() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   386
            return collectionCountOld + collectionCountYoung;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   387
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   388
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   389
        public CollectionSummary calcDelta(CollectionSummary prev) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   390
            CollectionSummary delta = new CollectionSummary();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   391
            delta.collectionCountOld = this.collectionCountOld - prev.collectionCountOld;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   392
            delta.collectionTimeOld = this.collectionTimeOld - prev.collectionTimeOld;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   393
            delta.collectionCountYoung = this.collectionCountYoung - prev.collectionCountYoung;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   394
            delta.collectionTimeYoung = this.collectionTimeYoung - prev.collectionTimeYoung;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   395
            delta.names.addAll(this.names);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   396
            delta.names.addAll(prev.names);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   397
            return delta;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   398
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   399
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   400
        public static CollectionSummary createFromMxBeans() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   401
            CollectionSummary summary = new CollectionSummary();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   402
            List<GarbageCollectorMXBean> gcBeans = ManagementFactory.getGarbageCollectorMXBeans();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   403
            for (int c=0; c<gcBeans.size(); c++) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   404
                GarbageCollectorMXBean currBean = gcBeans.get(c);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   405
                Boolean isYoung = beanCollectorTypes.get(currBean.getName());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   406
                assertNotNull(isYoung, "Unknown MXBean name: " + currBean.getName());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   407
                long collectionTime = currBean.getCollectionTime() * 1000; // Convert from millis to micros.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   408
                summary.add(currBean.getName(), isYoung.booleanValue(), currBean.getCollectionCount(), collectionTime);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   409
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   410
            return summary;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   411
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   412
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   413
        public static CollectionSummary createFromEvents(List<GcBatch> batches) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   414
            CollectionSummary summary = new CollectionSummary();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   415
            for (GcBatch batch : batches) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   416
                RecordedEvent endEvent = batch.getEndEvent();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   417
                assertNotNull(endEvent, "No end event in batch with gcId " + batch.getGcId());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   418
                String name = batch.getName();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   419
                summary.add(name, batch.isYoungCollection(), 1, Events.assertField(endEvent, "sumOfPauses").getValue());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   420
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   421
            return summary;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   422
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   423
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   424
        public String toString() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   425
            StringBuilder collectorNames = new StringBuilder();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   426
            for (String s : names) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   427
                if (collectorNames.length() > 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   428
                    collectorNames.append(", ");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   429
                }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   430
                collectorNames.append(s);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   431
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   432
            return String.format("CollectionSummary: young.collections=%d, young.time=%d, old.collections=%d, old.time=%d, collectors=(%s)",
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   433
                    collectionCountYoung, collectionTimeYoung, collectionCountOld, collectionTimeOld, collectorNames);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   434
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   435
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   436
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   437
    public static PrintStream getDefaultErrorLog() {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   438
        if (defaultErrorLog == null) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   439
            try {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   440
                defaultErrorLog = new PrintStream(new FileOutputStream("error.log", true));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   441
            } catch (IOException e) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   442
                e.printStackTrace();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   443
                defaultErrorLog = System.err;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   444
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   445
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   446
        return defaultErrorLog;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   447
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   448
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   449
    public static void log(Object msg) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   450
        log(msg, System.err);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   451
        log(msg, getDefaultErrorLog());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   452
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   453
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   454
    public static void log(Object msg, PrintStream ps) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   455
        ps.println(msg);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   456
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   457
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   458
    public static boolean isValidG1HeapRegionType(final String type) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   459
        return g1HeapRegionTypes.contains(type);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   460
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   461
54956
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   462
    public static boolean assertIsValidShenandoahHeapRegionState(final String state) {
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   463
        if (!shenandoahHeapRegionStates.contains(state)) {
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   464
            throw new AssertionError("Unknown state '" + state + "', valid heap region states are " + shenandoahHeapRegionStates);
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   465
        }
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   466
        return true;
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   467
    }
43340a79840d 8221507: Implement JFR Events for Shenandoah
kdobson
parents: 50113
diff changeset
   468
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   469
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   470
     * Helper function to align heap size up.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   471
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   472
     * @param value
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   473
     * @param alignment
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   474
     * @return aligned value
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   475
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   476
    public static long alignUp(long value, long alignment) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   477
        return (value + alignment - 1) & ~(alignment - 1);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   478
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   479
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   480
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   481
     * Helper function to align heap size down.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   482
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   483
     * @param value
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   484
     * @param alignment
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   485
     * @return aligned value
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   486
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   487
    public static long alignDown(long value, long alignment) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   488
        return value & ~(alignment - 1);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   489
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   490
}