src/hotspot/share/gc/shared/stringdedup/stringDedupStat.cpp
author tschatzl
Thu, 06 Dec 2018 15:44:40 +0100
changeset 52877 9e041366c764
parent 50574 fa727a4d7934
permissions -rw-r--r--
8214850: Rename vm_operations.?pp files to vmOperations.?pp files Reviewed-by: dholmes, coleenp
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50574
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
     1
/*
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
     2
 * Copyright (c) 2014, 2018, Oracle and/or its affiliates. All rights reserved.
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
     4
 *
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
     7
 * published by the Free Software Foundation.
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
     8
 *
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    13
 * accompanied this code).
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    14
 *
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    18
 *
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    21
 * questions.
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    22
 *
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    23
 */
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    24
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    25
#include "precompiled.hpp"
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    26
#include "gc/shared/stringdedup/stringDedupStat.hpp"
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    27
#include "logging/log.hpp"
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    28
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    29
StringDedupStat::StringDedupStat() :
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    30
  _inspected(0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    31
  _skipped(0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    32
  _hashed(0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    33
  _known(0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    34
  _new(0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    35
  _new_bytes(0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    36
  _deduped(0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    37
  _deduped_bytes(0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    38
  _idle(0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    39
  _exec(0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    40
  _block(0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    41
  _start_concurrent(0.0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    42
  _end_concurrent(0.0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    43
  _start_phase(0.0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    44
  _idle_elapsed(0.0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    45
  _exec_elapsed(0.0),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    46
  _block_elapsed(0.0) {
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    47
}
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    48
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    49
void StringDedupStat::add(const StringDedupStat* const stat) {
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    50
  _inspected           += stat->_inspected;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    51
  _skipped             += stat->_skipped;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    52
  _hashed              += stat->_hashed;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    53
  _known               += stat->_known;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    54
  _new                 += stat->_new;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    55
  _new_bytes           += stat->_new_bytes;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    56
  _deduped             += stat->_deduped;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    57
  _deduped_bytes       += stat->_deduped_bytes;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    58
  _idle                += stat->_idle;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    59
  _exec                += stat->_exec;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    60
  _block               += stat->_block;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    61
  _idle_elapsed        += stat->_idle_elapsed;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    62
  _exec_elapsed        += stat->_exec_elapsed;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    63
  _block_elapsed       += stat->_block_elapsed;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    64
}
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    65
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    66
void StringDedupStat::print_start(const StringDedupStat* last_stat) {
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    67
  log_info(gc, stringdedup)(
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    68
     "Concurrent String Deduplication (" STRDEDUP_TIME_FORMAT ")",
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    69
     STRDEDUP_TIME_PARAM(last_stat->_start_concurrent));
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    70
}
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    71
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    72
void StringDedupStat::print_end(const StringDedupStat* last_stat, const StringDedupStat* total_stat) {
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    73
  double total_deduped_bytes_percent = 0.0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    74
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    75
  if (total_stat->_new_bytes > 0) {
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    76
    // Avoid division by zero
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    77
    total_deduped_bytes_percent = percent_of(total_stat->_deduped_bytes, total_stat->_new_bytes);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    78
  }
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    79
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    80
  log_info(gc, stringdedup)(
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    81
    "Concurrent String Deduplication "
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    82
    STRDEDUP_BYTES_FORMAT_NS "->" STRDEDUP_BYTES_FORMAT_NS "(" STRDEDUP_BYTES_FORMAT_NS ") "
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    83
    "avg " STRDEDUP_PERCENT_FORMAT_NS " "
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    84
    "(" STRDEDUP_TIME_FORMAT ", " STRDEDUP_TIME_FORMAT ") " STRDEDUP_TIME_FORMAT_MS,
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    85
    STRDEDUP_BYTES_PARAM(last_stat->_new_bytes),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    86
    STRDEDUP_BYTES_PARAM(last_stat->_new_bytes - last_stat->_deduped_bytes),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    87
    STRDEDUP_BYTES_PARAM(last_stat->_deduped_bytes),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    88
    total_deduped_bytes_percent,
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    89
    STRDEDUP_TIME_PARAM(last_stat->_start_concurrent),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    90
    STRDEDUP_TIME_PARAM(last_stat->_end_concurrent),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    91
    STRDEDUP_TIME_PARAM_MS(last_stat->_exec_elapsed));
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    92
}
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    93
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    94
void StringDedupStat::reset() {
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    95
  _inspected = 0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    96
  _skipped = 0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    97
  _hashed = 0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    98
  _known = 0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
    99
  _new = 0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   100
  _new_bytes = 0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   101
  _deduped = 0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   102
  _deduped_bytes = 0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   103
  _idle = 0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   104
  _exec = 0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   105
  _block = 0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   106
  _start_concurrent = 0.0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   107
  _end_concurrent = 0.0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   108
  _start_phase = 0.0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   109
  _idle_elapsed = 0.0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   110
  _exec_elapsed = 0.0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   111
  _block_elapsed = 0.0;
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   112
}
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   113
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   114
void StringDedupStat::print_statistics(bool total) const {
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   115
  double skipped_percent             = percent_of(_skipped, _inspected);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   116
  double hashed_percent              = percent_of(_hashed, _inspected);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   117
  double known_percent               = percent_of(_known, _inspected);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   118
  double new_percent                 = percent_of(_new, _inspected);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   119
  double deduped_percent             = percent_of(_deduped, _new);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   120
  double deduped_bytes_percent       = percent_of(_deduped_bytes, _new_bytes);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   121
/*
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   122
  double deduped_young_percent       = percent_of(stat._deduped_young, stat._deduped);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   123
  double deduped_young_bytes_percent = percent_of(stat._deduped_young_bytes, stat._deduped_bytes);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   124
  double deduped_old_percent         = percent_of(stat._deduped_old, stat._deduped);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   125
  double deduped_old_bytes_percent   = percent_of(stat._deduped_old_bytes, stat._deduped_bytes);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   126
*/
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   127
  if (total) {
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   128
    log_debug(gc, stringdedup)(
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   129
      "  Total Exec: " UINTX_FORMAT "/" STRDEDUP_TIME_FORMAT_MS
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   130
      ", Idle: " UINTX_FORMAT "/" STRDEDUP_TIME_FORMAT_MS
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   131
      ", Blocked: " UINTX_FORMAT "/" STRDEDUP_TIME_FORMAT_MS,
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   132
      _exec, STRDEDUP_TIME_PARAM_MS(_exec_elapsed),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   133
      _idle, STRDEDUP_TIME_PARAM_MS(_idle_elapsed),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   134
      _block, STRDEDUP_TIME_PARAM_MS(_block_elapsed));
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   135
  } else {
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   136
    log_debug(gc, stringdedup)(
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   137
      "  Last Exec: " STRDEDUP_TIME_FORMAT_MS
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   138
      ", Idle: " STRDEDUP_TIME_FORMAT_MS
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   139
      ", Blocked: " UINTX_FORMAT "/" STRDEDUP_TIME_FORMAT_MS,
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   140
      STRDEDUP_TIME_PARAM_MS(_exec_elapsed),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   141
      STRDEDUP_TIME_PARAM_MS(_idle_elapsed),
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   142
      _block, STRDEDUP_TIME_PARAM_MS(_block_elapsed));
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   143
  }
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   144
  log_debug(gc, stringdedup)("    Inspected:    " STRDEDUP_OBJECTS_FORMAT, _inspected);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   145
  log_debug(gc, stringdedup)("      Skipped:    " STRDEDUP_OBJECTS_FORMAT "(" STRDEDUP_PERCENT_FORMAT ")", _skipped, skipped_percent);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   146
  log_debug(gc, stringdedup)("      Hashed:     " STRDEDUP_OBJECTS_FORMAT "(" STRDEDUP_PERCENT_FORMAT ")", _hashed, hashed_percent);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   147
  log_debug(gc, stringdedup)("      Known:      " STRDEDUP_OBJECTS_FORMAT "(" STRDEDUP_PERCENT_FORMAT ")", _known, known_percent);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   148
  log_debug(gc, stringdedup)("      New:        " STRDEDUP_OBJECTS_FORMAT "(" STRDEDUP_PERCENT_FORMAT ") " STRDEDUP_BYTES_FORMAT,
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   149
                             _new, new_percent, STRDEDUP_BYTES_PARAM(_new_bytes));
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   150
  log_debug(gc, stringdedup)("    Deduplicated: " STRDEDUP_OBJECTS_FORMAT "(" STRDEDUP_PERCENT_FORMAT ") " STRDEDUP_BYTES_FORMAT "(" STRDEDUP_PERCENT_FORMAT ")",
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   151
                             _deduped, deduped_percent, STRDEDUP_BYTES_PARAM(_deduped_bytes), deduped_bytes_percent);
fa727a4d7934 8203641: Refactor String Deduplication into shared
zgu
parents:
diff changeset
   152
}