8191861: Move and refactor hSpaceCounters

Reviewed-by: pliden, ehelin, rkennke
This commit is contained in:
Stefan Karlsson 2017-11-24 15:48:01 +01:00
parent dbc915dcb9
commit 677e5bdaed
5 changed files with 73 additions and 55 deletions

View File

@ -42,11 +42,11 @@
#include "gc/g1/g1SATBCardTableModRefBS.hpp" #include "gc/g1/g1SATBCardTableModRefBS.hpp"
#include "gc/g1/g1SurvivorRegions.hpp" #include "gc/g1/g1SurvivorRegions.hpp"
#include "gc/g1/g1YCTypes.hpp" #include "gc/g1/g1YCTypes.hpp"
#include "gc/g1/hSpaceCounters.hpp"
#include "gc/g1/heapRegionManager.hpp" #include "gc/g1/heapRegionManager.hpp"
#include "gc/g1/heapRegionSet.hpp" #include "gc/g1/heapRegionSet.hpp"
#include "gc/shared/barrierSet.hpp" #include "gc/shared/barrierSet.hpp"
#include "gc/shared/collectedHeap.hpp" #include "gc/shared/collectedHeap.hpp"
#include "gc/shared/gcHeapSummary.hpp"
#include "gc/shared/plab.hpp" #include "gc/shared/plab.hpp"
#include "gc/shared/preservedMarks.hpp" #include "gc/shared/preservedMarks.hpp"
#include "memory/memRegion.hpp" #include "memory/memRegion.hpp"

View File

@ -26,6 +26,7 @@
#include "gc/g1/g1CollectedHeap.inline.hpp" #include "gc/g1/g1CollectedHeap.inline.hpp"
#include "gc/g1/g1MonitoringSupport.hpp" #include "gc/g1/g1MonitoringSupport.hpp"
#include "gc/g1/g1Policy.hpp" #include "gc/g1/g1Policy.hpp"
#include "gc/shared/hSpaceCounters.hpp"
G1GenerationCounters::G1GenerationCounters(G1MonitoringSupport* g1mm, G1GenerationCounters::G1GenerationCounters(G1MonitoringSupport* g1mm,
const char* name, const char* name,
@ -128,10 +129,10 @@ G1MonitoringSupport::G1MonitoringSupport(G1CollectedHeap* g1h) :
// name "generation.1.space.0" // name "generation.1.space.0"
// Counters are created from maxCapacity, capacity, initCapacity, // Counters are created from maxCapacity, capacity, initCapacity,
// and used. // and used.
_old_space_counters = new HSpaceCounters("space", 0 /* ordinal */, _old_space_counters = new HSpaceCounters(_old_collection_counters->name_space(),
"space", 0 /* ordinal */,
pad_capacity(overall_reserved()) /* max_capacity */, pad_capacity(overall_reserved()) /* max_capacity */,
pad_capacity(old_space_committed()) /* init_capacity */, pad_capacity(old_space_committed()) /* init_capacity */);
_old_collection_counters);
// Young collection set // Young collection set
// name "generation.0". This is logically the young generation. // name "generation.0". This is logically the young generation.
@ -139,27 +140,29 @@ G1MonitoringSupport::G1MonitoringSupport(G1CollectedHeap* g1h) :
// See _old_collection_counters for additional counters // See _old_collection_counters for additional counters
_young_collection_counters = new G1YoungGenerationCounters(this, "young"); _young_collection_counters = new G1YoungGenerationCounters(this, "young");
const char* young_collection_name_space = _young_collection_counters->name_space();
// name "generation.0.space.0" // name "generation.0.space.0"
// See _old_space_counters for additional counters // See _old_space_counters for additional counters
_eden_counters = new HSpaceCounters("eden", 0 /* ordinal */, _eden_counters = new HSpaceCounters(young_collection_name_space,
"eden", 0 /* ordinal */,
pad_capacity(overall_reserved()) /* max_capacity */, pad_capacity(overall_reserved()) /* max_capacity */,
pad_capacity(eden_space_committed()) /* init_capacity */, pad_capacity(eden_space_committed()) /* init_capacity */);
_young_collection_counters);
// name "generation.0.space.1" // name "generation.0.space.1"
// See _old_space_counters for additional counters // See _old_space_counters for additional counters
// Set the arguments to indicate that this survivor space is not used. // Set the arguments to indicate that this survivor space is not used.
_from_counters = new HSpaceCounters("s0", 1 /* ordinal */, _from_counters = new HSpaceCounters(young_collection_name_space,
"s0", 1 /* ordinal */,
pad_capacity(0) /* max_capacity */, pad_capacity(0) /* max_capacity */,
pad_capacity(0) /* init_capacity */, pad_capacity(0) /* init_capacity */);
_young_collection_counters);
// name "generation.0.space.2" // name "generation.0.space.2"
// See _old_space_counters for additional counters // See _old_space_counters for additional counters
_to_counters = new HSpaceCounters("s1", 2 /* ordinal */, _to_counters = new HSpaceCounters(young_collection_name_space,
"s1", 2 /* ordinal */,
pad_capacity(overall_reserved()) /* max_capacity */, pad_capacity(overall_reserved()) /* max_capacity */,
pad_capacity(survivor_space_committed()) /* init_capacity */, pad_capacity(survivor_space_committed()) /* init_capacity */);
_young_collection_counters);
if (UsePerfData) { if (UsePerfData) {
// Given that this survivor space is not used, we update it here // Given that this survivor space is not used, we update it here

View File

@ -25,9 +25,11 @@
#ifndef SHARE_VM_GC_G1_G1MONITORINGSUPPORT_HPP #ifndef SHARE_VM_GC_G1_G1MONITORINGSUPPORT_HPP
#define SHARE_VM_GC_G1_G1MONITORINGSUPPORT_HPP #define SHARE_VM_GC_G1_G1MONITORINGSUPPORT_HPP
#include "gc/g1/hSpaceCounters.hpp" #include "gc/shared/generationCounters.hpp"
class CollectorCounters;
class G1CollectedHeap; class G1CollectedHeap;
class HSpaceCounters;
// Class for monitoring logical spaces in G1. It provides data for // Class for monitoring logical spaces in G1. It provides data for
// both G1's jstat counters as well as G1's memory pools. // both G1's jstat counters as well as G1's memory pools.

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2011, 2017, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -23,22 +23,23 @@
*/ */
#include "precompiled.hpp" #include "precompiled.hpp"
#include "gc/g1/hSpaceCounters.hpp" #include "gc/shared/hSpaceCounters.hpp"
#include "gc/shared/generation.hpp" #include "memory/allocation.hpp"
#include "memory/resourceArea.hpp" #include "memory/resourceArea.hpp"
#include "runtime/perfData.hpp"
HSpaceCounters::HSpaceCounters(const char* name, HSpaceCounters::HSpaceCounters(const char* name_space,
const char* name,
int ordinal, int ordinal,
size_t max_size, size_t max_size,
size_t initial_capacity, size_t initial_capacity) {
GenerationCounters* gc) {
if (UsePerfData) { if (UsePerfData) {
EXCEPTION_MARK; EXCEPTION_MARK;
ResourceMark rm; ResourceMark rm;
const char* cns = const char* cns =
PerfDataManager::name_space(gc->name_space(), "space", ordinal); PerfDataManager::name_space(name_space, "space", ordinal);
_name_space = NEW_C_HEAP_ARRAY(char, strlen(cns)+1, mtGC); _name_space = NEW_C_HEAP_ARRAY(char, strlen(cns)+1, mtGC);
strcpy(_name_space, cns); strcpy(_name_space, cns);
@ -64,3 +65,33 @@ HSpaceCounters::HSpaceCounters(const char* name,
initial_capacity, CHECK); initial_capacity, CHECK);
} }
} }
HSpaceCounters::~HSpaceCounters() {
if (_name_space != NULL) {
FREE_C_HEAP_ARRAY(char, _name_space);
}
}
void HSpaceCounters::update_capacity(size_t v) {
_capacity->set_value(v);
}
void HSpaceCounters::update_used(size_t v) {
_used->set_value(v);
}
void HSpaceCounters::update_all(size_t capacity, size_t used) {
update_capacity(capacity);
update_used(used);
}
debug_only(
// for security reasons, we do not allow arbitrary reads from
// the counters as they may live in shared memory.
jlong HSpaceCounters::used() {
return _used->get_value();
}
jlong HSpaceCounters::capacity() {
return _used->get_value();
}
)

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2011, 2017, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -22,65 +22,47 @@
* *
*/ */
#ifndef SHARE_VM_GC_G1_HSPACECOUNTERS_HPP #ifndef SHARE_VM_GC_SHARED_HSPACECOUNTERS_HPP
#define SHARE_VM_GC_G1_HSPACECOUNTERS_HPP #define SHARE_VM_GC_SHARED_HSPACECOUNTERS_HPP
#include "gc/shared/generation.hpp" #include "memory/allocation.hpp"
#include "gc/shared/generationCounters.hpp"
#include "runtime/perfData.hpp" #include "runtime/perfData.hpp"
#include "utilities/macros.hpp" #include "utilities/macros.hpp"
// A HSpaceCounter is a holder class for performance counters // A HSpaceCounter is a holder class for performance counters
// that track a collections (logical spaces) in a heap; // that track a collections (logical spaces) in a heap;
class HeapSpaceUsedHelper;
class G1SpaceMonitoringSupport;
class HSpaceCounters: public CHeapObj<mtGC> { class HSpaceCounters: public CHeapObj<mtGC> {
friend class VMStructs; friend class VMStructs;
private: private:
PerfVariable* _capacity; PerfVariable* _capacity;
PerfVariable* _used; PerfVariable* _used;
// Constant PerfData types don't need to retain a reference. // Constant PerfData types don't need to retain a reference.
// However, it's a good idea to document them here. // However, it's a good idea to document them here.
char* _name_space; char* _name_space;
public: public:
HSpaceCounters(const char* name, int ordinal, size_t max_size, HSpaceCounters(const char* name_space, const char* name, int ordinal,
size_t initial_capacity, GenerationCounters* gc); size_t max_size, size_t initial_capacity);
~HSpaceCounters() { ~HSpaceCounters();
if (_name_space != NULL) FREE_C_HEAP_ARRAY(char, _name_space);
}
inline void update_capacity(size_t v) { void update_capacity(size_t v);
_capacity->set_value(v); void update_used(size_t v);
}
inline void update_used(size_t v) { void update_all(size_t capacity, size_t used);
_used->set_value(v);
}
debug_only( debug_only(
// for security reasons, we do not allow arbitrary reads from // for security reasons, we do not allow arbitrary reads from
// the counters as they may live in shared memory. // the counters as they may live in shared memory.
jlong used() { jlong used();
return _used->get_value(); jlong capacity();
}
jlong capacity() {
return _used->get_value();
}
) )
inline void update_all(size_t capacity, size_t used) {
update_capacity(capacity);
update_used(used);
}
const char* name_space() const { return _name_space; } const char* name_space() const { return _name_space; }
}; };
#endif // SHARE_VM_GC_G1_HSPACECOUNTERS_HPP #endif // SHARE_VM_GC_SHARED_HSPACECOUNTERS_HPP