test/hotspot/gtest/gc/g1/test_g1IHOPControl.cpp
author erikj
Tue, 12 Sep 2017 19:03:39 +0200
changeset 47216 71c04702a3d5
parent 41316 hotspot/test/native/gc/g1/test_g1IHOPControl.cpp@216f4f645fd8
permissions -rw-r--r--
8187443: Forest Consolidation: Move files to unified layout Reviewed-by: darcy, ihse
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
41316
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
     1
/*
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
     2
 * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
     4
 *
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
     7
 * published by the Free Software Foundation.
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
     8
 *
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    13
 * accompanied this code).
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    14
 *
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    18
 *
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    21
 * questions.
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    22
 */
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    23
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    24
#include "precompiled.hpp"
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    25
#include "gc/g1/g1CollectedHeap.inline.hpp"
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    26
#include "gc/g1/g1IHOPControl.hpp"
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    27
#include "gc/g1/g1Predictions.hpp"
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    28
#include "unittest.hpp"
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    29
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    30
static void test_update(G1IHOPControl* ctrl, double alloc_time,
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    31
                        size_t alloc_amount, size_t young_size,
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    32
                        double mark_time) {
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    33
  for (int i = 0; i < 100; i++) {
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    34
    ctrl->update_allocation_info(alloc_time, alloc_amount, young_size);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    35
    ctrl->update_marking_length(mark_time);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    36
  }
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    37
}
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    38
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    39
// @requires UseG1GC
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    40
TEST_VM(G1StaticIHOPControl, simple) {
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    41
  // Test requires G1
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    42
  if (!UseG1GC) {
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    43
    return;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    44
  }
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    45
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    46
  const size_t initial_ihop = 45;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    47
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    48
  G1StaticIHOPControl ctrl(initial_ihop);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    49
  ctrl.update_target_occupancy(100);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    50
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    51
  size_t threshold = ctrl.get_conc_mark_start_threshold();
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    52
  EXPECT_EQ(initial_ihop, threshold);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    53
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    54
  ctrl.update_allocation_info(100.0, 100, 100);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    55
  threshold = ctrl.get_conc_mark_start_threshold();
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    56
  EXPECT_EQ(initial_ihop, threshold);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    57
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    58
  ctrl.update_marking_length(1000.0);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    59
  threshold = ctrl.get_conc_mark_start_threshold();
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    60
  EXPECT_EQ(initial_ihop, threshold);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    61
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    62
  // Whatever we pass, the IHOP value must stay the same.
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    63
  test_update(&ctrl, 2, 10, 10, 3);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    64
  threshold = ctrl.get_conc_mark_start_threshold();
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    65
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    66
  EXPECT_EQ(initial_ihop, threshold);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    67
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    68
  test_update(&ctrl, 12, 10, 10, 3);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    69
  threshold = ctrl.get_conc_mark_start_threshold();
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    70
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    71
  EXPECT_EQ(initial_ihop, threshold);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    72
}
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    73
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    74
// @requires UseG1GC
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    75
TEST_VM(G1AdaptiveIHOPControl, simple) {
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    76
  // Test requires G1
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    77
  if (!UseG1GC) {
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    78
    return;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    79
  }
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    80
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    81
  const size_t initial_threshold = 45;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    82
  const size_t young_size = 10;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    83
  const size_t target_size = 100;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    84
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    85
  // The final IHOP value is always
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    86
  // target_size - (young_size + alloc_amount/alloc_time * marking_time)
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    87
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    88
  G1Predictions pred(0.95);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    89
  G1AdaptiveIHOPControl ctrl(initial_threshold, &pred, 0, 0);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    90
  ctrl.update_target_occupancy(target_size);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    91
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    92
  // First "load".
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    93
  const size_t alloc_time1 = 2;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    94
  const size_t alloc_amount1 = 10;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    95
  const size_t marking_time1 = 2;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    96
  const size_t settled_ihop1 = target_size
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    97
          - (young_size + alloc_amount1 / alloc_time1 * marking_time1);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    98
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
    99
  size_t threshold;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   100
  threshold = ctrl.get_conc_mark_start_threshold();
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   101
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   102
  EXPECT_EQ(initial_threshold, threshold);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   103
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   104
  for (size_t i = 0; i < G1AdaptiveIHOPNumInitialSamples - 1; i++) {
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   105
    ctrl.update_allocation_info(alloc_time1, alloc_amount1, young_size);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   106
    ctrl.update_marking_length(marking_time1);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   107
    // Not enough data yet.
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   108
    threshold = ctrl.get_conc_mark_start_threshold();
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   109
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   110
    ASSERT_EQ(initial_threshold, threshold) << "on step " << i;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   111
  }
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   112
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   113
  test_update(&ctrl, alloc_time1, alloc_amount1, young_size, marking_time1);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   114
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   115
  threshold = ctrl.get_conc_mark_start_threshold();
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   116
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   117
  EXPECT_EQ(settled_ihop1, threshold);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   118
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   119
  // Second "load". A bit higher allocation rate.
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   120
  const size_t alloc_time2 = 2;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   121
  const size_t alloc_amount2 = 30;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   122
  const size_t marking_time2 = 2;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   123
  const size_t settled_ihop2 = target_size
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   124
          - (young_size + alloc_amount2 / alloc_time2 * marking_time2);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   125
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   126
  test_update(&ctrl, alloc_time2, alloc_amount2, young_size, marking_time2);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   127
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   128
  threshold = ctrl.get_conc_mark_start_threshold();
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   129
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   130
  EXPECT_LT(threshold, settled_ihop1);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   131
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   132
  // Third "load". Very high (impossible) allocation rate.
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   133
  const size_t alloc_time3 = 1;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   134
  const size_t alloc_amount3 = 50;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   135
  const size_t marking_time3 = 2;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   136
  const size_t settled_ihop3 = 0;
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   137
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   138
  test_update(&ctrl, alloc_time3, alloc_amount3, young_size, marking_time3);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   139
  threshold = ctrl.get_conc_mark_start_threshold();
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   140
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   141
  EXPECT_EQ(settled_ihop3, threshold);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   142
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   143
  // And back to some arbitrary value.
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   144
  test_update(&ctrl, alloc_time2, alloc_amount2, young_size, marking_time2);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   145
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   146
  threshold = ctrl.get_conc_mark_start_threshold();
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   147
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   148
  EXPECT_GT(threshold, settled_ihop3);
216f4f645fd8 8159818: Convert IHOP_test to GTest
kzhaldyb
parents:
diff changeset
   149
}