test/jdk/jdk/jfr/event/compiler/TestCodeSweeper.java
author egahlin
Tue, 15 May 2018 20:24:34 +0200
changeset 50113 caf115bb98ad
child 51214 67736b4846a0
permissions -rw-r--r--
8199712: Flight Recorder Reviewed-by: coleenp, ihse, erikj, dsamersoff, mseledtsov, egahlin, mgronlun Contributed-by: erik.gahlin@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) 2014, 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
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    26
package jdk.jfr.event.compiler;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    27
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    28
import java.lang.management.MemoryPoolMXBean;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    29
import java.lang.reflect.Method;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    30
import java.time.Instant;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    31
import java.util.ArrayList;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    32
import java.util.List;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    33
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    34
import jdk.jfr.Recording;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    35
import jdk.jfr.consumer.RecordedEvent;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    36
import jdk.test.lib.Asserts;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    37
import jdk.test.lib.jfr.EventNames;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    38
import jdk.test.lib.jfr.Events;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    39
import sun.hotspot.WhiteBox;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    40
import sun.hotspot.code.BlobType;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    41
import sun.hotspot.code.CodeBlob;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    42
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    43
/**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    44
 * Test for events: vm/code_sweeper/sweep vm/code_cache/full vm/compiler/failure
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    45
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    46
 * We verify: 1. That sweptCount >= flushedCount + zombifiedCount 2. That
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    47
 * sweepIndex increases by 1. 3. We should get at least one of each of the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    48
 * events listed above.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    49
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    50
 * NOTE! The test is usually able to trigger the events but not always. If an
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    51
 * event is received, the event is verified. If an event is missing, we do NOT
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    52
 * fail.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    53
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    54
/*
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    55
 * @test TestCodeSweeper
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    56
 * @key jfr
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    57
 * @library /test/lib
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    58
 * @build sun.hotspot.WhiteBox
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    59
 * @run driver ClassFileInstaller sun.hotspot.WhiteBox
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    60
 *                                sun.hotspot.WhiteBox$WhiteBoxPermission
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    61
 * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:-SegmentedCodeCache -XX:+WhiteBoxAPI jdk.jfr.event.compiler.TestCodeSweeper
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    62
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    63
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    64
public class TestCodeSweeper {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    65
    private static final WhiteBox WHITE_BOX = WhiteBox.getWhiteBox();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    66
    private static final int COMP_LEVEL_SIMPLE = 1;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    67
    private static final int COMP_LEVEL_FULL_OPTIMIZATION = 4;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    68
    private static final int SIZE = 1;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    69
    private static final String METHOD_NAME = "verifyFullEvent";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    70
    private static final String pathSweep = EventNames.SweepCodeCache;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    71
    private static final String pathFull = EventNames.CodeCacheFull;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    72
    private static final String pathFailure = EventNames.CompilationFailure;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    73
    public static final long SEGMENT_SIZE = WhiteBox.getWhiteBox().getUintxVMFlag("CodeCacheSegmentSize");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    74
    public static final long MIN_BLOCK_LENGTH = WhiteBox.getWhiteBox().getUintxVMFlag("CodeCacheMinBlockLength");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    75
    public static final long MIN_ALLOCATION = SEGMENT_SIZE * MIN_BLOCK_LENGTH;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    76
    private static final double CACHE_USAGE_COEF = 0.95d;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    77
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    78
    public static void main(String[] args) throws Throwable {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    79
        Asserts.assertTrue(BlobType.getAvailable().contains(BlobType.All), "Test does not support SegmentedCodeCache");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    80
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    81
        System.out.println("************************************************");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    82
        System.out.println("This test will warn that the code cache is full.");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    83
        System.out.println("That is expected and is the purpose of the test.");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    84
        System.out.println("************************************************");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    85
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    86
        Recording r = new Recording();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    87
        r.enable(pathSweep);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    88
        r.enable(pathFull);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    89
        r.enable(pathFailure);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    90
        r.start();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    91
        provokeEvents();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    92
        r.stop();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    93
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    94
        int countEventSweep = 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    95
        int countEventFull = 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    96
        int countEventFailure = 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    97
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    98
        List<RecordedEvent> events = Events.fromRecording(r);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    99
        Events.hasEvents(events);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   100
        for (RecordedEvent event : events) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   101
            switch (event.getEventType().getName()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   102
            case pathSweep:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   103
                countEventSweep++;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   104
                verifySingleSweepEvent(event);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   105
                break;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   106
            case pathFull:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   107
                countEventFull++;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   108
                verifyFullEvent(event);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   109
                break;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   110
            case pathFailure:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   111
                countEventFailure++;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   112
                verifyFailureEvent(event);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   113
                break;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   114
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   115
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   116
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   117
        System.out.println(String.format("eventCount: %d, %d, %d", countEventSweep, countEventFull, countEventFailure));
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
    private static boolean canAllocate(double size, long maxSize, MemoryPoolMXBean bean) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   121
        // Don't fill too much to have space for adapters. So, stop after crossing 95% and
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   122
        // don't allocate in case we'll cross 97% on next allocation.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   123
        double used = bean.getUsage().getUsed();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   124
        return (used <= CACHE_USAGE_COEF * maxSize) &&
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   125
               (used + size <= (CACHE_USAGE_COEF + 0.02d)  * maxSize);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   126
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   127
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   128
    private static void provokeEvents() throws NoSuchMethodException, InterruptedException {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   129
        // Prepare for later, since we don't want to trigger any compilation
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   130
        // setting this up.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   131
        Method method = TestCodeSweeper.class.getDeclaredMethod(METHOD_NAME, new Class[] { RecordedEvent.class });
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   132
        String directive = "[{ match: \"" + TestCodeSweeper.class.getName().replace('.', '/')
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   133
                + "." + METHOD_NAME + "\", " + "BackgroundCompilation: false }]";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   134
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   135
        // Fill up code heaps until they are almost full
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   136
        // to trigger the vm/code_sweeper/sweep event.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   137
        ArrayList<Long> blobs = new ArrayList<>();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   138
        MemoryPoolMXBean bean = BlobType.All.getMemoryPool();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   139
        long max = bean.getUsage().getMax();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   140
        long headerSize = getHeaderSize(BlobType.All);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   141
        long minAllocationUnit = Math.max(1, MIN_ALLOCATION - headerSize);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   142
        long stopAt = max - minAllocationUnit;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   143
        long addr = 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   144
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   145
        // First allocate big blobs to speed things up
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   146
        for (long size = 100_000 * minAllocationUnit; size > 0; size /= 10) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   147
            while (canAllocate(size, max, bean) &&
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   148
                   (addr = WHITE_BOX.allocateCodeBlob(size, BlobType.All.id)) != 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   149
                blobs.add(addr);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   150
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   151
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   152
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   153
        // Now allocate small blobs until the heap is almost full
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   154
        while (bean.getUsage().getUsed() < stopAt &&
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   155
               (addr = WHITE_BOX.allocateCodeBlob(SIZE, BlobType.All.id)) != 0) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   156
            blobs.add(addr);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   157
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   158
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   159
        // Trigger the vm/code_cache/full event by compiling one more
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   160
        // method. This also triggers the vm/compiler/failure event.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   161
        Asserts.assertTrue(WHITE_BOX.addCompilerDirective(directive) == 1);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   162
        try {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   163
            if (!WHITE_BOX.enqueueMethodForCompilation(method, COMP_LEVEL_FULL_OPTIMIZATION)) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   164
                WHITE_BOX.enqueueMethodForCompilation(method, COMP_LEVEL_SIMPLE);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   165
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   166
        } finally {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   167
            WHITE_BOX.removeCompilerDirective(1);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   168
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   169
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   170
        // Free memory
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   171
        for (Long blob : blobs) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   172
            WHITE_BOX.freeCodeBlob(blob);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   173
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   174
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   175
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   176
    private static void verifyFullEvent(RecordedEvent event) throws Throwable {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   177
        Events.assertField(event, "codeBlobType").notEmpty();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   178
        Events.assertField(event, "unallocatedCapacity").atLeast(0L);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   179
        Events.assertField(event, "entryCount").atLeast(0);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   180
        Events.assertField(event, "methodCount").atLeast(0);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   181
        Events.assertField(event, "adaptorCount").atLeast(0);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   182
        Events.assertField(event, "fullCount").atLeast(0);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   183
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   184
        // Verify startAddress <= commitedTopAddress <= reservedTopAddress.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   185
        // Addresses may be so big that they overflow a long (treated as a
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   186
        // negative value), convert value to an octal string and compare the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   187
        // string.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   188
        String startAddress = Long.toOctalString(Events.assertField(event, "startAddress").getValue());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   189
        String commitedTopAddress = Long.toOctalString(Events.assertField(event, "commitedTopAddress").getValue());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   190
        String reservedTopAddress = Long.toOctalString(Events.assertField(event, "reservedTopAddress").getValue());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   191
        Asserts.assertTrue(isOctalLessOrEqual(startAddress, commitedTopAddress), "startAddress<=commitedTopAddress: " + startAddress + "<=" + commitedTopAddress);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   192
        Asserts.assertTrue(isOctalLessOrEqual(commitedTopAddress, reservedTopAddress), "commitedTopAddress<=reservedTopAddress: " + commitedTopAddress + "<=" + reservedTopAddress);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   193
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   194
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   195
    private static void verifyFailureEvent(RecordedEvent event) throws Throwable {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   196
        Events.assertField(event, "failureMessage").notEmpty();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   197
        Events.assertField(event, "compileId").atLeast(0);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   198
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   199
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   200
    private static void verifySingleSweepEvent(RecordedEvent event) throws Throwable {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   201
        int flushedCount = Events.assertField(event, "flushedCount").atLeast(0).getValue();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   202
        int zombifiedCount = Events.assertField(event, "zombifiedCount").atLeast(0).getValue();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   203
        Events.assertField(event, "sweptCount").atLeast(flushedCount + zombifiedCount);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   204
        Events.assertField(event, "sweepId").atLeast(0);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   205
        Asserts.assertGreaterThanOrEqual(event.getStartTime(), Instant.EPOCH, "startTime was < 0");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   206
        Asserts.assertGreaterThanOrEqual(event.getEndTime(), event.getStartTime(), "startTime was > endTime");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   207
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   208
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   209
    /** Returns true if less <= bigger. */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   210
    private static boolean isOctalLessOrEqual(String less, String bigger) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   211
        if (less.length() > bigger.length()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   212
            return false;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   213
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   214
        if (less.length() < bigger.length()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   215
            return true;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   216
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   217
        return less.compareTo(bigger) <= 0;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   218
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   219
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   220
    public static final long getHeaderSize(BlobType btype) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   221
        long addr = WHITE_BOX.allocateCodeBlob(0, btype.id);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   222
        int size = CodeBlob.getCodeBlob(addr).size;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   223
        WHITE_BOX.freeCodeBlob(addr);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   224
        return size;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   225
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   226
}