src/share/vm/services/memReporter.hpp

Wed, 23 Jan 2013 13:02:39 -0500

author
jprovino
date
Wed, 23 Jan 2013 13:02:39 -0500
changeset 4542
db9981fd3124
parent 4376
79f492f184d0
child 6198
55fb97c4c58d
permissions
-rw-r--r--

8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
Summary: Rename INCLUDE_ALTERNATE_GCS to INCLUDE_ALL_GCS and replace SERIALGC with INCLUDE_ALL_GCS.
Reviewed-by: coleenp, stefank

zgu@3900 1 /*
katleman@4376 2 * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
zgu@3900 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
zgu@3900 4 *
zgu@3900 5 * This code is free software; you can redistribute it and/or modify it
zgu@3900 6 * under the terms of the GNU General Public License version 2 only, as
zgu@3900 7 * published by the Free Software Foundation.
zgu@3900 8 *
zgu@3900 9 * This code is distributed in the hope that it will be useful, but WITHOUT
zgu@3900 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
zgu@3900 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
zgu@3900 12 * version 2 for more details (a copy is included in the LICENSE file that
zgu@3900 13 * accompanied this code).
zgu@3900 14 *
zgu@3900 15 * You should have received a copy of the GNU General Public License version
zgu@3900 16 * 2 along with this work; if not, write to the Free Software Foundation,
zgu@3900 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
zgu@3900 18 *
zgu@3900 19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
zgu@3900 20 * or visit www.oracle.com if you need additional information or have any
zgu@3900 21 * questions.
zgu@3900 22 *
zgu@3900 23 */
zgu@3900 24
zgu@3900 25 #ifndef SHARE_VM_SERVICES_MEM_REPORTER_HPP
zgu@3900 26 #define SHARE_VM_SERVICES_MEM_REPORTER_HPP
zgu@3900 27
zgu@3900 28 #include "runtime/mutexLocker.hpp"
zgu@3900 29 #include "services/memBaseline.hpp"
zgu@3900 30 #include "services/memTracker.hpp"
zgu@3900 31 #include "utilities/ostream.hpp"
jprovino@4542 32 #include "utilities/macros.hpp"
zgu@3900 33
jprovino@4165 34 #if INCLUDE_NMT
jprovino@4165 35
zgu@3900 36 /*
zgu@3900 37 * MemBaselineReporter reports data to this outputer class,
zgu@3900 38 * ReportOutputer is responsible for format, store and redirect
zgu@3900 39 * the data to the final destination.
zgu@3900 40 */
zgu@3900 41 class BaselineOutputer : public StackObj {
zgu@3900 42 public:
zgu@3900 43 // start to report memory usage in specified scale.
zgu@3900 44 // if report_diff = true, the reporter reports baseline comparison
zgu@3900 45 // information.
zgu@3900 46
zgu@3900 47 virtual void start(size_t scale, bool report_diff = false) = 0;
zgu@3900 48 // Done reporting
zgu@3900 49 virtual void done() = 0;
zgu@3900 50
zgu@3900 51 /* report baseline summary information */
zgu@3900 52 virtual void total_usage(size_t total_reserved,
zgu@3900 53 size_t total_committed) = 0;
zgu@3900 54 virtual void num_of_classes(size_t classes) = 0;
zgu@3900 55 virtual void num_of_threads(size_t threads) = 0;
zgu@3900 56
zgu@3900 57 virtual void thread_info(size_t stack_reserved_amt, size_t stack_committed_amt) = 0;
zgu@3900 58
zgu@3900 59 /* report baseline summary comparison */
zgu@3900 60 virtual void diff_total_usage(size_t total_reserved,
zgu@3900 61 size_t total_committed,
zgu@3900 62 int reserved_diff,
zgu@3900 63 int committed_diff) = 0;
zgu@3900 64 virtual void diff_num_of_classes(size_t classes, int diff) = 0;
zgu@3900 65 virtual void diff_num_of_threads(size_t threads, int diff) = 0;
zgu@3900 66
zgu@3900 67 virtual void diff_thread_info(size_t stack_reserved, size_t stack_committed,
zgu@3900 68 int stack_reserved_diff, int stack_committed_diff) = 0;
zgu@3900 69
zgu@3900 70
zgu@3900 71 /*
zgu@3900 72 * memory summary by memory types.
zgu@3900 73 * for each memory type, following summaries are reported:
zgu@3900 74 * - reserved amount, committed amount
zgu@3900 75 * - malloc'd amount, malloc count
zgu@3900 76 * - arena amount, arena count
zgu@3900 77 */
zgu@3900 78
zgu@3900 79 // start reporting memory summary by memory type
zgu@3900 80 virtual void start_category_summary() = 0;
zgu@3900 81
zgu@3900 82 virtual void category_summary(MEMFLAGS type, size_t reserved_amt,
zgu@3900 83 size_t committed_amt,
zgu@3900 84 size_t malloc_amt, size_t malloc_count,
zgu@3900 85 size_t arena_amt, size_t arena_count) = 0;
zgu@3900 86
zgu@3900 87 virtual void diff_category_summary(MEMFLAGS type, size_t cur_reserved_amt,
zgu@3900 88 size_t cur_committed_amt,
zgu@3900 89 size_t cur_malloc_amt, size_t cur_malloc_count,
zgu@3900 90 size_t cur_arena_amt, size_t cur_arena_count,
zgu@3900 91 int reserved_diff, int committed_diff, int malloc_diff,
zgu@3900 92 int malloc_count_diff, int arena_diff,
zgu@3900 93 int arena_count_diff) = 0;
zgu@3900 94
zgu@3900 95 virtual void done_category_summary() = 0;
zgu@3900 96
zgu@4193 97 virtual void start_virtual_memory_map() = 0;
zgu@4193 98 virtual void reserved_memory_region(MEMFLAGS type, address base, address end, size_t size, address pc) = 0;
zgu@4193 99 virtual void committed_memory_region(address base, address end, size_t size, address pc) = 0;
zgu@4193 100 virtual void done_virtual_memory_map() = 0;
zgu@4193 101
zgu@3900 102 /*
zgu@3900 103 * Report callsite information
zgu@3900 104 */
zgu@3900 105 virtual void start_callsite() = 0;
zgu@3900 106 virtual void malloc_callsite(address pc, size_t malloc_amt, size_t malloc_count) = 0;
zgu@3900 107 virtual void virtual_memory_callsite(address pc, size_t reserved_amt, size_t committed_amt) = 0;
zgu@3900 108
zgu@3900 109 virtual void diff_malloc_callsite(address pc, size_t cur_malloc_amt, size_t cur_malloc_count,
zgu@3900 110 int malloc_diff, int malloc_count_diff) = 0;
zgu@3900 111 virtual void diff_virtual_memory_callsite(address pc, size_t cur_reserved_amt, size_t cur_committed_amt,
zgu@3900 112 int reserved_diff, int committed_diff) = 0;
zgu@3900 113
zgu@3900 114 virtual void done_callsite() = 0;
zgu@3900 115
zgu@3900 116 // return current scale in "KB", "MB" or "GB"
zgu@3900 117 static const char* memory_unit(size_t scale);
zgu@3900 118 };
zgu@3900 119
zgu@3900 120 /*
zgu@3900 121 * This class reports processed data from a baseline or
zgu@3900 122 * the changes between the two baseline.
zgu@3900 123 */
zgu@3900 124 class BaselineReporter : public StackObj {
zgu@3900 125 private:
zgu@3900 126 BaselineOutputer& _outputer;
zgu@3900 127 size_t _scale;
zgu@3900 128
zgu@3900 129 public:
zgu@3900 130 // construct a reporter that reports memory usage
zgu@3900 131 // in specified scale
zgu@3900 132 BaselineReporter(BaselineOutputer& outputer, size_t scale = K):
zgu@3900 133 _outputer(outputer) {
zgu@3900 134 _scale = scale;
zgu@3900 135 }
zgu@3900 136 virtual void report_baseline(const MemBaseline& baseline, bool summary_only = false);
zgu@3900 137 virtual void diff_baselines(const MemBaseline& cur, const MemBaseline& prev,
zgu@3900 138 bool summary_only = false);
zgu@3900 139
zgu@3900 140 void set_scale(size_t scale);
zgu@3900 141 size_t scale() const { return _scale; }
zgu@3900 142
zgu@3900 143 private:
zgu@3900 144 void report_summaries(const MemBaseline& baseline);
zgu@4193 145 void report_virtual_memory_map(const MemBaseline& baseline);
zgu@3900 146 void report_callsites(const MemBaseline& baseline);
zgu@3900 147
zgu@3900 148 void diff_summaries(const MemBaseline& cur, const MemBaseline& prev);
zgu@3900 149 void diff_callsites(const MemBaseline& cur, const MemBaseline& prev);
zgu@3900 150
zgu@3900 151 // calculate memory size in current memory scale
zgu@3900 152 size_t amount_in_current_scale(size_t amt) const;
zgu@3900 153 // diff two unsigned values in current memory scale
zgu@3900 154 int diff_in_current_scale(size_t value1, size_t value2) const;
zgu@3900 155 // diff two unsigned value
zgu@3900 156 int diff(size_t value1, size_t value2) const;
zgu@3900 157 };
zgu@3900 158
zgu@3900 159 /*
zgu@3900 160 * tty output implementation. Native memory tracking
zgu@3900 161 * DCmd uses this outputer.
zgu@3900 162 */
zgu@3900 163 class BaselineTTYOutputer : public BaselineOutputer {
zgu@3900 164 private:
zgu@3900 165 size_t _scale;
zgu@3900 166
zgu@3900 167 size_t _num_of_classes;
zgu@3900 168 size_t _num_of_threads;
zgu@3900 169 size_t _thread_stack_reserved;
zgu@3900 170 size_t _thread_stack_committed;
zgu@3900 171
zgu@3900 172 int _num_of_classes_diff;
zgu@3900 173 int _num_of_threads_diff;
zgu@3900 174 int _thread_stack_reserved_diff;
zgu@3900 175 int _thread_stack_committed_diff;
zgu@3900 176
zgu@3900 177 outputStream* _output;
zgu@3900 178
zgu@3900 179 public:
zgu@3900 180 BaselineTTYOutputer(outputStream* st) {
zgu@3900 181 _scale = K;
zgu@3900 182 _num_of_classes = 0;
zgu@3900 183 _num_of_threads = 0;
zgu@3900 184 _thread_stack_reserved = 0;
zgu@3900 185 _thread_stack_committed = 0;
zgu@3900 186 _num_of_classes_diff = 0;
zgu@3900 187 _num_of_threads_diff = 0;
zgu@3900 188 _thread_stack_reserved_diff = 0;
zgu@3900 189 _thread_stack_committed_diff = 0;
zgu@3900 190 _output = st;
zgu@3900 191 }
zgu@3900 192
zgu@3900 193 // begin reporting memory usage in specified scale
zgu@3900 194 void start(size_t scale, bool report_diff = false);
zgu@3900 195 // done reporting
zgu@3900 196 void done();
zgu@3900 197
zgu@3900 198 // total memory usage
zgu@3900 199 void total_usage(size_t total_reserved,
zgu@3900 200 size_t total_committed);
zgu@3900 201 // report total loaded classes
zgu@3900 202 void num_of_classes(size_t classes) {
zgu@3900 203 _num_of_classes = classes;
zgu@3900 204 }
zgu@3900 205
zgu@3900 206 void num_of_threads(size_t threads) {
zgu@3900 207 _num_of_threads = threads;
zgu@3900 208 }
zgu@3900 209
zgu@3900 210 void thread_info(size_t stack_reserved_amt, size_t stack_committed_amt) {
zgu@3900 211 _thread_stack_reserved = stack_reserved_amt;
zgu@3900 212 _thread_stack_committed = stack_committed_amt;
zgu@3900 213 }
zgu@3900 214
zgu@3900 215 void diff_total_usage(size_t total_reserved,
zgu@3900 216 size_t total_committed,
zgu@3900 217 int reserved_diff,
zgu@3900 218 int committed_diff);
zgu@3900 219
zgu@3900 220 void diff_num_of_classes(size_t classes, int diff) {
zgu@3900 221 _num_of_classes = classes;
zgu@3900 222 _num_of_classes_diff = diff;
zgu@3900 223 }
zgu@3900 224
zgu@3900 225 void diff_num_of_threads(size_t threads, int diff) {
zgu@3900 226 _num_of_threads = threads;
zgu@3900 227 _num_of_threads_diff = diff;
zgu@3900 228 }
zgu@3900 229
zgu@3900 230 void diff_thread_info(size_t stack_reserved_amt, size_t stack_committed_amt,
zgu@3900 231 int stack_reserved_diff, int stack_committed_diff) {
zgu@3900 232 _thread_stack_reserved = stack_reserved_amt;
zgu@3900 233 _thread_stack_committed = stack_committed_amt;
zgu@3900 234 _thread_stack_reserved_diff = stack_reserved_diff;
zgu@3900 235 _thread_stack_committed_diff = stack_committed_diff;
zgu@3900 236 }
zgu@3900 237
zgu@3900 238 /*
zgu@3900 239 * Report memory summary categoriuzed by memory types.
zgu@3900 240 * For each memory type, following summaries are reported:
zgu@3900 241 * - reserved amount, committed amount
zgu@3900 242 * - malloc-ed amount, malloc count
zgu@3900 243 * - arena amount, arena count
zgu@3900 244 */
zgu@3900 245 // start reporting memory summary by memory type
zgu@3900 246 void start_category_summary();
zgu@3900 247 void category_summary(MEMFLAGS type, size_t reserved_amt, size_t committed_amt,
zgu@3900 248 size_t malloc_amt, size_t malloc_count,
zgu@3900 249 size_t arena_amt, size_t arena_count);
zgu@3900 250
zgu@3900 251 void diff_category_summary(MEMFLAGS type, size_t cur_reserved_amt,
zgu@3900 252 size_t cur_committed_amt,
zgu@3900 253 size_t cur_malloc_amt, size_t cur_malloc_count,
zgu@3900 254 size_t cur_arena_amt, size_t cur_arena_count,
zgu@3900 255 int reserved_diff, int committed_diff, int malloc_diff,
zgu@3900 256 int malloc_count_diff, int arena_diff,
zgu@3900 257 int arena_count_diff);
zgu@3900 258
zgu@3900 259 void done_category_summary();
zgu@3900 260
zgu@4193 261 // virtual memory map
zgu@4193 262 void start_virtual_memory_map();
zgu@4193 263 void reserved_memory_region(MEMFLAGS type, address base, address end, size_t size, address pc);
zgu@4193 264 void committed_memory_region(address base, address end, size_t size, address pc);
zgu@4193 265 void done_virtual_memory_map();
zgu@4193 266
zgu@4193 267
zgu@3900 268 /*
zgu@3900 269 * Report callsite information
zgu@3900 270 */
zgu@3900 271 void start_callsite();
zgu@3900 272 void malloc_callsite(address pc, size_t malloc_amt, size_t malloc_count);
zgu@3900 273 void virtual_memory_callsite(address pc, size_t reserved_amt, size_t committed_amt);
zgu@3900 274
zgu@3900 275 void diff_malloc_callsite(address pc, size_t cur_malloc_amt, size_t cur_malloc_count,
zgu@3900 276 int malloc_diff, int malloc_count_diff);
zgu@3900 277 void diff_virtual_memory_callsite(address pc, size_t cur_reserved_amt, size_t cur_committed_amt,
zgu@3900 278 int reserved_diff, int committed_diff);
zgu@3900 279
zgu@3900 280 void done_callsite();
zgu@3900 281 };
zgu@3900 282
zgu@3900 283
jprovino@4165 284 #endif // INCLUDE_NMT
jprovino@4165 285
zgu@3900 286 #endif // SHARE_VM_SERVICES_MEM_REPORTER_HPP

mercurial