Path: blob/master/src/hotspot/share/services/memReporter.hpp
41144 views
/*1* Copyright (c) 2012, 2019, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*22*/2324#ifndef SHARE_SERVICES_MEMREPORTER_HPP25#define SHARE_SERVICES_MEMREPORTER_HPP2627#if INCLUDE_NMT2829#include "memory/metaspace.hpp"30#include "oops/instanceKlass.hpp"31#include "services/memBaseline.hpp"32#include "services/nmtCommon.hpp"33#include "services/mallocTracker.hpp"34#include "services/virtualMemoryTracker.hpp"3536/*37* Base class that provides helpers38*/39class MemReporterBase : public StackObj {40private:41const size_t _scale; // report in this scale42outputStream* const _output; // destination4344public:4546// Default scale to use if no scale given.47static const size_t default_scale = K;4849MemReporterBase(outputStream* out, size_t scale = default_scale) :50_scale(scale), _output(out)51{}5253protected:54inline outputStream* output() const {55return _output;56}57// Current reporting scale58size_t scale() const {59return _scale;60}61inline const char* current_scale() const {62return NMTUtil::scale_name(_scale);63}64// Convert memory amount in bytes to current reporting scale65inline size_t amount_in_current_scale(size_t amount) const {66return NMTUtil::amount_in_scale(amount, _scale);67}6869// Convert diff amount in bytes to current reporting scale70inline long diff_in_current_scale(size_t s1, size_t s2) const {71long amount = (long)(s1 - s2);72long scale = (long)_scale;73amount = (amount > 0) ? (amount + scale / 2) : (amount - scale / 2);74return amount / scale;75}7677// Helper functions78// Calculate total reserved and committed amount79size_t reserved_total(const MallocMemory* malloc, const VirtualMemory* vm) const;80size_t committed_total(const MallocMemory* malloc, const VirtualMemory* vm) const;8182// Print summary total, malloc and virtual memory83void print_total(size_t reserved, size_t committed) const;84void print_malloc(size_t amount, size_t count, MEMFLAGS flag = mtNone) const;85void print_virtual_memory(size_t reserved, size_t committed) const;8687void print_malloc_line(size_t amount, size_t count) const;88void print_virtual_memory_line(size_t reserved, size_t committed) const;89void print_arena_line(size_t amount, size_t count) const;9091void print_virtual_memory_region(const char* type, address base, size_t size) const;92};9394/*95* The class is for generating summary tracking report.96*/97class MemSummaryReporter : public MemReporterBase {98private:99MallocMemorySnapshot* _malloc_snapshot;100VirtualMemorySnapshot* _vm_snapshot;101size_t _instance_class_count;102size_t _array_class_count;103104public:105// This constructor is for normal reporting from a recent baseline.106MemSummaryReporter(MemBaseline& baseline, outputStream* output,107size_t scale = default_scale) : MemReporterBase(output, scale),108_malloc_snapshot(baseline.malloc_memory_snapshot()),109_vm_snapshot(baseline.virtual_memory_snapshot()),110_instance_class_count(baseline.instance_class_count()),111_array_class_count(baseline.array_class_count()) { }112113114// Generate summary report115virtual void report();116private:117// Report summary for each memory type118void report_summary_of_type(MEMFLAGS type, MallocMemory* malloc_memory,119VirtualMemory* virtual_memory);120121void report_metadata(Metaspace::MetadataType type) const;122};123124/*125* The class is for generating detail tracking report.126*/127class MemDetailReporter : public MemSummaryReporter {128private:129MemBaseline& _baseline;130131public:132MemDetailReporter(MemBaseline& baseline, outputStream* output, size_t scale = default_scale) :133MemSummaryReporter(baseline, output, scale),134_baseline(baseline) { }135136// Generate detail report.137// The report contains summary and detail sections.138virtual void report() {139MemSummaryReporter::report();140report_virtual_memory_map();141report_detail();142}143144private:145// Report detail tracking data.146void report_detail();147// Report virtual memory map148void report_virtual_memory_map();149// Report malloc allocation sites; returns number of omitted sites150int report_malloc_sites();151// Report virtual memory reservation sites; returns number of omitted sites152int report_virtual_memory_allocation_sites();153154// Report a virtual memory region155void report_virtual_memory_region(const ReservedMemoryRegion* rgn);156};157158/*159* The class is for generating summary comparison report.160* It compares current memory baseline against an early baseline.161*/162class MemSummaryDiffReporter : public MemReporterBase {163protected:164MemBaseline& _early_baseline;165MemBaseline& _current_baseline;166167public:168MemSummaryDiffReporter(MemBaseline& early_baseline, MemBaseline& current_baseline,169outputStream* output, size_t scale = default_scale) : MemReporterBase(output, scale),170_early_baseline(early_baseline), _current_baseline(current_baseline) {171assert(early_baseline.baseline_type() != MemBaseline::Not_baselined, "Not baselined");172assert(current_baseline.baseline_type() != MemBaseline::Not_baselined, "Not baselined");173}174175// Generate summary comparison report176virtual void report_diff();177178private:179// report the comparison of each memory type180void diff_summary_of_type(MEMFLAGS type,181const MallocMemory* early_malloc, const VirtualMemory* early_vm,182const MetaspaceCombinedStats& early_ms,183const MallocMemory* current_malloc, const VirtualMemory* current_vm,184const MetaspaceCombinedStats& current_ms) const;185186protected:187void print_malloc_diff(size_t current_amount, size_t current_count,188size_t early_amount, size_t early_count, MEMFLAGS flags) const;189void print_virtual_memory_diff(size_t current_reserved, size_t current_committed,190size_t early_reserved, size_t early_committed) const;191void print_arena_diff(size_t current_amount, size_t current_count,192size_t early_amount, size_t early_count) const;193194void print_metaspace_diff(const MetaspaceCombinedStats& current_ms,195const MetaspaceCombinedStats& early_ms) const;196void print_metaspace_diff(const char* header,197const MetaspaceStats& current_ms,198const MetaspaceStats& early_ms) const;199};200201/*202* The class is for generating detail comparison report.203* It compares current memory baseline against an early baseline,204* both baselines have to be detail baseline.205*/206class MemDetailDiffReporter : public MemSummaryDiffReporter {207public:208MemDetailDiffReporter(MemBaseline& early_baseline, MemBaseline& current_baseline,209outputStream* output, size_t scale = default_scale) :210MemSummaryDiffReporter(early_baseline, current_baseline, output, scale) { }211212// Generate detail comparison report213virtual void report_diff();214215// Malloc allocation site comparison216void diff_malloc_sites() const;217// Virutal memory reservation site comparison218void diff_virtual_memory_sites() const;219220// New malloc allocation site in recent baseline221void new_malloc_site (const MallocSite* site) const;222// The malloc allocation site is not in recent baseline223void old_malloc_site (const MallocSite* site) const;224// Compare malloc allocation site, it is in both baselines225void diff_malloc_site(const MallocSite* early, const MallocSite* current) const;226227// New virtual memory allocation site in recent baseline228void new_virtual_memory_site (const VirtualMemoryAllocationSite* callsite) const;229// The virtual memory allocation site is not in recent baseline230void old_virtual_memory_site (const VirtualMemoryAllocationSite* callsite) const;231// Compare virtual memory allocation site, it is in both baseline232void diff_virtual_memory_site(const VirtualMemoryAllocationSite* early,233const VirtualMemoryAllocationSite* current) const;234235void diff_malloc_site(const NativeCallStack* stack, size_t current_size,236size_t currrent_count, size_t early_size, size_t early_count, MEMFLAGS flags) const;237void diff_virtual_memory_site(const NativeCallStack* stack, size_t current_reserved,238size_t current_committed, size_t early_reserved, size_t early_committed, MEMFLAGS flag) const;239};240241#endif // INCLUDE_NMT242243#endif // SHARE_SERVICES_MEMREPORTER_HPP244245246