Merge
This commit is contained in:
commit
7b7aad5481
@ -336,13 +336,13 @@ char* os::build_agent_function_name(const char *sym_name, const char *lib_name,
|
|||||||
const char *start;
|
const char *start;
|
||||||
|
|
||||||
if (lib_name != NULL) {
|
if (lib_name != NULL) {
|
||||||
len = name_len = strlen(lib_name);
|
name_len = strlen(lib_name);
|
||||||
if (is_absolute_path) {
|
if (is_absolute_path) {
|
||||||
// Need to strip path, prefix and suffix
|
// Need to strip path, prefix and suffix
|
||||||
if ((start = strrchr(lib_name, *os::file_separator())) != NULL) {
|
if ((start = strrchr(lib_name, *os::file_separator())) != NULL) {
|
||||||
lib_name = ++start;
|
lib_name = ++start;
|
||||||
}
|
}
|
||||||
if (len <= (prefix_len + suffix_len)) {
|
if (strlen(lib_name) <= (prefix_len + suffix_len)) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
lib_name += prefix_len;
|
lib_name += prefix_len;
|
||||||
|
@ -951,11 +951,11 @@ bool os::getTimesSecs(double* process_real_time,
|
|||||||
FILETIME wt;
|
FILETIME wt;
|
||||||
GetSystemTimeAsFileTime(&wt);
|
GetSystemTimeAsFileTime(&wt);
|
||||||
jlong rtc_millis = windows_to_java_time(wt);
|
jlong rtc_millis = windows_to_java_time(wt);
|
||||||
jlong user_millis = windows_to_java_time(user_time);
|
|
||||||
jlong system_millis = windows_to_java_time(kernel_time);
|
|
||||||
*process_real_time = ((double) rtc_millis) / ((double) MILLIUNITS);
|
*process_real_time = ((double) rtc_millis) / ((double) MILLIUNITS);
|
||||||
*process_user_time = ((double) user_millis) / ((double) MILLIUNITS);
|
*process_user_time =
|
||||||
*process_system_time = ((double) system_millis) / ((double) MILLIUNITS);
|
(double) jlong_from(user_time.dwHighDateTime, user_time.dwLowDateTime) / (10 * MICROUNITS);
|
||||||
|
*process_system_time =
|
||||||
|
(double) jlong_from(kernel_time.dwHighDateTime, kernel_time.dwLowDateTime) / (10 * MICROUNITS);
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
@ -637,16 +637,19 @@ void CodeCache::blobs_do(CodeBlobClosure* f) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Walk the list of methods which might contain non-perm oops.
|
// Walk the list of methods which might contain non-perm oops.
|
||||||
void CodeCache::scavenge_root_nmethods_do(CodeBlobClosure* f) {
|
void CodeCache::scavenge_root_nmethods_do(CodeBlobToOopClosure* f) {
|
||||||
assert_locked_or_safepoint(CodeCache_lock);
|
assert_locked_or_safepoint(CodeCache_lock);
|
||||||
|
|
||||||
if (UseG1GC) {
|
if (UseG1GC) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const bool fix_relocations = f->fix_relocations();
|
||||||
debug_only(mark_scavenge_root_nmethods());
|
debug_only(mark_scavenge_root_nmethods());
|
||||||
|
|
||||||
for (nmethod* cur = scavenge_root_nmethods(); cur != NULL; cur = cur->scavenge_root_link()) {
|
nmethod* prev = NULL;
|
||||||
|
nmethod* cur = scavenge_root_nmethods();
|
||||||
|
while (cur != NULL) {
|
||||||
debug_only(cur->clear_scavenge_root_marked());
|
debug_only(cur->clear_scavenge_root_marked());
|
||||||
assert(cur->scavenge_root_not_marked(), "");
|
assert(cur->scavenge_root_not_marked(), "");
|
||||||
assert(cur->on_scavenge_root_list(), "else shouldn't be on this list");
|
assert(cur->on_scavenge_root_list(), "else shouldn't be on this list");
|
||||||
@ -659,6 +662,18 @@ void CodeCache::scavenge_root_nmethods_do(CodeBlobClosure* f) {
|
|||||||
// Perform cur->oops_do(f), maybe just once per nmethod.
|
// Perform cur->oops_do(f), maybe just once per nmethod.
|
||||||
f->do_code_blob(cur);
|
f->do_code_blob(cur);
|
||||||
}
|
}
|
||||||
|
nmethod* const next = cur->scavenge_root_link();
|
||||||
|
// The scavengable nmethod list must contain all methods with scavengable
|
||||||
|
// oops. It is safe to include more nmethod on the list, but we do not
|
||||||
|
// expect any live non-scavengable nmethods on the list.
|
||||||
|
if (fix_relocations) {
|
||||||
|
if (!is_live || !cur->detect_scavenge_root_oops()) {
|
||||||
|
unlink_scavenge_root_nmethod(cur, prev);
|
||||||
|
} else {
|
||||||
|
prev = cur;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
cur = next;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check for stray marks.
|
// Check for stray marks.
|
||||||
@ -678,6 +693,24 @@ void CodeCache::add_scavenge_root_nmethod(nmethod* nm) {
|
|||||||
print_trace("add_scavenge_root", nm);
|
print_trace("add_scavenge_root", nm);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CodeCache::unlink_scavenge_root_nmethod(nmethod* nm, nmethod* prev) {
|
||||||
|
assert_locked_or_safepoint(CodeCache_lock);
|
||||||
|
|
||||||
|
assert((prev == NULL && scavenge_root_nmethods() == nm) ||
|
||||||
|
(prev != NULL && prev->scavenge_root_link() == nm), "precondition");
|
||||||
|
|
||||||
|
assert(!UseG1GC, "G1 does not use the scavenge_root_nmethods list");
|
||||||
|
|
||||||
|
print_trace("unlink_scavenge_root", nm);
|
||||||
|
if (prev == NULL) {
|
||||||
|
set_scavenge_root_nmethods(nm->scavenge_root_link());
|
||||||
|
} else {
|
||||||
|
prev->set_scavenge_root_link(nm->scavenge_root_link());
|
||||||
|
}
|
||||||
|
nm->set_scavenge_root_link(NULL);
|
||||||
|
nm->clear_on_scavenge_root_list();
|
||||||
|
}
|
||||||
|
|
||||||
void CodeCache::drop_scavenge_root_nmethod(nmethod* nm) {
|
void CodeCache::drop_scavenge_root_nmethod(nmethod* nm) {
|
||||||
assert_locked_or_safepoint(CodeCache_lock);
|
assert_locked_or_safepoint(CodeCache_lock);
|
||||||
|
|
||||||
@ -686,20 +719,13 @@ void CodeCache::drop_scavenge_root_nmethod(nmethod* nm) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
print_trace("drop_scavenge_root", nm);
|
print_trace("drop_scavenge_root", nm);
|
||||||
nmethod* last = NULL;
|
nmethod* prev = NULL;
|
||||||
nmethod* cur = scavenge_root_nmethods();
|
for (nmethod* cur = scavenge_root_nmethods(); cur != NULL; cur = cur->scavenge_root_link()) {
|
||||||
while (cur != NULL) {
|
|
||||||
nmethod* next = cur->scavenge_root_link();
|
|
||||||
if (cur == nm) {
|
if (cur == nm) {
|
||||||
if (last != NULL)
|
unlink_scavenge_root_nmethod(cur, prev);
|
||||||
last->set_scavenge_root_link(next);
|
|
||||||
else set_scavenge_root_nmethods(next);
|
|
||||||
nm->set_scavenge_root_link(NULL);
|
|
||||||
nm->clear_on_scavenge_root_list();
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
last = cur;
|
prev = cur;
|
||||||
cur = next;
|
|
||||||
}
|
}
|
||||||
assert(false, "should have been on list");
|
assert(false, "should have been on list");
|
||||||
}
|
}
|
||||||
@ -728,11 +754,7 @@ void CodeCache::prune_scavenge_root_nmethods() {
|
|||||||
} else {
|
} else {
|
||||||
// Prune it from the list, so we don't have to look at it any more.
|
// Prune it from the list, so we don't have to look at it any more.
|
||||||
print_trace("prune_scavenge_root", cur);
|
print_trace("prune_scavenge_root", cur);
|
||||||
cur->set_scavenge_root_link(NULL);
|
unlink_scavenge_root_nmethod(cur, last);
|
||||||
cur->clear_on_scavenge_root_list();
|
|
||||||
if (last != NULL)
|
|
||||||
last->set_scavenge_root_link(next);
|
|
||||||
else set_scavenge_root_nmethods(next);
|
|
||||||
}
|
}
|
||||||
cur = next;
|
cur = next;
|
||||||
}
|
}
|
||||||
|
@ -116,6 +116,10 @@ class CodeCache : AllStatic {
|
|||||||
static int allocated_segments();
|
static int allocated_segments();
|
||||||
static size_t freelists_length();
|
static size_t freelists_length();
|
||||||
|
|
||||||
|
static void set_scavenge_root_nmethods(nmethod* nm) { _scavenge_root_nmethods = nm; }
|
||||||
|
static void prune_scavenge_root_nmethods();
|
||||||
|
static void unlink_scavenge_root_nmethod(nmethod* nm, nmethod* prev);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// Initialization
|
// Initialization
|
||||||
static void initialize();
|
static void initialize();
|
||||||
@ -153,13 +157,17 @@ class CodeCache : AllStatic {
|
|||||||
// to "true" iff some code got unloaded.
|
// to "true" iff some code got unloaded.
|
||||||
static void do_unloading(BoolObjectClosure* is_alive, bool unloading_occurred);
|
static void do_unloading(BoolObjectClosure* is_alive, bool unloading_occurred);
|
||||||
static void asserted_non_scavengable_nmethods_do(CodeBlobClosure* f = NULL) PRODUCT_RETURN;
|
static void asserted_non_scavengable_nmethods_do(CodeBlobClosure* f = NULL) PRODUCT_RETURN;
|
||||||
static void scavenge_root_nmethods_do(CodeBlobClosure* f);
|
|
||||||
|
// Apply f to every live code blob in scavengable nmethods. Prune nmethods
|
||||||
|
// from the list of scavengable nmethods if f->fix_relocations() and a nmethod
|
||||||
|
// no longer has scavengable oops. If f->fix_relocations(), then f must copy
|
||||||
|
// objects to their new location immediately to avoid fixing nmethods on the
|
||||||
|
// basis of the old object locations.
|
||||||
|
static void scavenge_root_nmethods_do(CodeBlobToOopClosure* f);
|
||||||
|
|
||||||
static nmethod* scavenge_root_nmethods() { return _scavenge_root_nmethods; }
|
static nmethod* scavenge_root_nmethods() { return _scavenge_root_nmethods; }
|
||||||
static void set_scavenge_root_nmethods(nmethod* nm) { _scavenge_root_nmethods = nm; }
|
|
||||||
static void add_scavenge_root_nmethod(nmethod* nm);
|
static void add_scavenge_root_nmethod(nmethod* nm);
|
||||||
static void drop_scavenge_root_nmethod(nmethod* nm);
|
static void drop_scavenge_root_nmethod(nmethod* nm);
|
||||||
static void prune_scavenge_root_nmethods();
|
|
||||||
|
|
||||||
// Printing/debugging
|
// Printing/debugging
|
||||||
static void print(); // prints summary
|
static void print(); // prints summary
|
||||||
|
@ -1381,7 +1381,6 @@ void nmethod::make_unloaded(BoolObjectClosure* is_alive, oop cause) {
|
|||||||
assert(_method == NULL, "Tautology");
|
assert(_method == NULL, "Tautology");
|
||||||
|
|
||||||
set_osr_link(NULL);
|
set_osr_link(NULL);
|
||||||
//set_scavenge_root_link(NULL); // done by prune_scavenge_root_nmethods
|
|
||||||
NMethodSweeper::report_state_change(this);
|
NMethodSweeper::report_state_change(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2329,9 +2329,13 @@ void G1CollectedHeap::register_concurrent_cycle_end() {
|
|||||||
GCIdMarkAndRestore conc_gc_id_mark(_cmThread->gc_id());
|
GCIdMarkAndRestore conc_gc_id_mark(_cmThread->gc_id());
|
||||||
if (_cm->has_aborted()) {
|
if (_cm->has_aborted()) {
|
||||||
_gc_tracer_cm->report_concurrent_mode_failure();
|
_gc_tracer_cm->report_concurrent_mode_failure();
|
||||||
|
|
||||||
|
// ConcurrentGCTimer will be ended as well.
|
||||||
|
_cm->register_concurrent_gc_end_and_stop_timer();
|
||||||
|
} else {
|
||||||
|
_gc_timer_cm->register_gc_end();
|
||||||
}
|
}
|
||||||
|
|
||||||
_gc_timer_cm->register_gc_end();
|
|
||||||
_gc_tracer_cm->report_gc_end(_gc_timer_cm->gc_end(), _gc_timer_cm->time_partitions());
|
_gc_tracer_cm->report_gc_end(_gc_timer_cm->gc_end(), _gc_timer_cm->time_partitions());
|
||||||
|
|
||||||
// Clear state variables to prepare for the next concurrent cycle.
|
// Clear state variables to prepare for the next concurrent cycle.
|
||||||
|
@ -269,6 +269,8 @@ G1CollectorPolicy::G1CollectorPolicy() :
|
|||||||
_reserve_regions = 0;
|
_reserve_regions = 0;
|
||||||
|
|
||||||
_cset_chooser = new CollectionSetChooser();
|
_cset_chooser = new CollectionSetChooser();
|
||||||
|
|
||||||
|
_ihop_control = create_ihop_control();
|
||||||
}
|
}
|
||||||
|
|
||||||
G1CollectorPolicy::~G1CollectorPolicy() {
|
G1CollectorPolicy::~G1CollectorPolicy() {
|
||||||
@ -469,8 +471,6 @@ void G1CollectorPolicy::post_heap_initialize() {
|
|||||||
if (max_young_size != MaxNewSize) {
|
if (max_young_size != MaxNewSize) {
|
||||||
FLAG_SET_ERGO(size_t, MaxNewSize, max_young_size);
|
FLAG_SET_ERGO(size_t, MaxNewSize, max_young_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
_ihop_control = create_ihop_control();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void G1CollectorPolicy::initialize_flags() {
|
void G1CollectorPolicy::initialize_flags() {
|
||||||
@ -565,6 +565,8 @@ void G1CollectorPolicy::record_new_heap_size(uint new_number_of_regions) {
|
|||||||
_reserve_regions = (uint) ceil(reserve_regions_d);
|
_reserve_regions = (uint) ceil(reserve_regions_d);
|
||||||
|
|
||||||
_young_gen_sizer->heap_size_changed(new_number_of_regions);
|
_young_gen_sizer->heap_size_changed(new_number_of_regions);
|
||||||
|
|
||||||
|
_ihop_control->update_target_occupancy(new_number_of_regions * HeapRegion::GrainBytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint G1CollectorPolicy::calculate_young_list_desired_min_length(
|
uint G1CollectorPolicy::calculate_young_list_desired_min_length(
|
||||||
@ -1234,13 +1236,11 @@ void G1CollectorPolicy::record_collection_pause_end(double pause_time_ms, size_t
|
|||||||
G1IHOPControl* G1CollectorPolicy::create_ihop_control() const {
|
G1IHOPControl* G1CollectorPolicy::create_ihop_control() const {
|
||||||
if (G1UseAdaptiveIHOP) {
|
if (G1UseAdaptiveIHOP) {
|
||||||
return new G1AdaptiveIHOPControl(InitiatingHeapOccupancyPercent,
|
return new G1AdaptiveIHOPControl(InitiatingHeapOccupancyPercent,
|
||||||
G1CollectedHeap::heap()->max_capacity(),
|
|
||||||
&_predictor,
|
&_predictor,
|
||||||
G1ReservePercent,
|
G1ReservePercent,
|
||||||
G1HeapWastePercent);
|
G1HeapWastePercent);
|
||||||
} else {
|
} else {
|
||||||
return new G1StaticIHOPControl(InitiatingHeapOccupancyPercent,
|
return new G1StaticIHOPControl(InitiatingHeapOccupancyPercent);
|
||||||
G1CollectedHeap::heap()->max_capacity());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -441,7 +441,7 @@ G1ConcurrentMark::G1ConcurrentMark(G1CollectedHeap* g1h, G1RegionToSpaceMapper*
|
|||||||
_has_aborted(false),
|
_has_aborted(false),
|
||||||
_restart_for_overflow(false),
|
_restart_for_overflow(false),
|
||||||
_concurrent_marking_in_progress(false),
|
_concurrent_marking_in_progress(false),
|
||||||
_concurrent_phase_started(false),
|
_concurrent_phase_status(ConcPhaseNotStarted),
|
||||||
|
|
||||||
// _verbose_level set below
|
// _verbose_level set below
|
||||||
|
|
||||||
@ -1008,16 +1008,43 @@ void G1ConcurrentMark::scanRootRegions() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void G1ConcurrentMark::register_concurrent_phase_start(const char* title) {
|
void G1ConcurrentMark::register_concurrent_phase_start(const char* title) {
|
||||||
assert(!_concurrent_phase_started, "Sanity");
|
uint old_val = 0;
|
||||||
_concurrent_phase_started = true;
|
do {
|
||||||
|
old_val = Atomic::cmpxchg(ConcPhaseStarted, &_concurrent_phase_status, ConcPhaseNotStarted);
|
||||||
|
} while (old_val != ConcPhaseNotStarted);
|
||||||
_g1h->gc_timer_cm()->register_gc_concurrent_start(title);
|
_g1h->gc_timer_cm()->register_gc_concurrent_start(title);
|
||||||
}
|
}
|
||||||
|
|
||||||
void G1ConcurrentMark::register_concurrent_phase_end() {
|
void G1ConcurrentMark::register_concurrent_phase_end_common(bool end_timer) {
|
||||||
if (_concurrent_phase_started) {
|
if (_concurrent_phase_status == ConcPhaseNotStarted) {
|
||||||
_concurrent_phase_started = false;
|
return;
|
||||||
_g1h->gc_timer_cm()->register_gc_concurrent_end();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint old_val = Atomic::cmpxchg(ConcPhaseStopping, &_concurrent_phase_status, ConcPhaseStarted);
|
||||||
|
if (old_val == ConcPhaseStarted) {
|
||||||
|
_g1h->gc_timer_cm()->register_gc_concurrent_end();
|
||||||
|
// If 'end_timer' is true, we came here to end timer which needs concurrent phase ended.
|
||||||
|
// We need to end it before changing the status to 'ConcPhaseNotStarted' to prevent
|
||||||
|
// starting a new concurrent phase by 'ConcurrentMarkThread'.
|
||||||
|
if (end_timer) {
|
||||||
|
_g1h->gc_timer_cm()->register_gc_end();
|
||||||
|
}
|
||||||
|
old_val = Atomic::cmpxchg(ConcPhaseNotStarted, &_concurrent_phase_status, ConcPhaseStopping);
|
||||||
|
assert(old_val == ConcPhaseStopping, "Should not have changed since we entered this scope.");
|
||||||
|
} else {
|
||||||
|
do {
|
||||||
|
// Let other thread finish changing '_concurrent_phase_status' to 'ConcPhaseNotStarted'.
|
||||||
|
os::naked_short_sleep(1);
|
||||||
|
} while (_concurrent_phase_status != ConcPhaseNotStarted);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void G1ConcurrentMark::register_concurrent_phase_end() {
|
||||||
|
register_concurrent_phase_end_common(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
void G1ConcurrentMark::register_concurrent_gc_end_and_stop_timer() {
|
||||||
|
register_concurrent_phase_end_common(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void G1ConcurrentMark::markFromRoots() {
|
void G1ConcurrentMark::markFromRoots() {
|
||||||
@ -2605,9 +2632,6 @@ void G1ConcurrentMark::abort() {
|
|||||||
|
|
||||||
_g1h->trace_heap_after_concurrent_cycle();
|
_g1h->trace_heap_after_concurrent_cycle();
|
||||||
|
|
||||||
// Close any open concurrent phase timing
|
|
||||||
register_concurrent_phase_end();
|
|
||||||
|
|
||||||
_g1h->register_concurrent_cycle_end();
|
_g1h->register_concurrent_cycle_end();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -352,8 +352,17 @@ protected:
|
|||||||
// time of remark.
|
// time of remark.
|
||||||
volatile bool _concurrent_marking_in_progress;
|
volatile bool _concurrent_marking_in_progress;
|
||||||
|
|
||||||
// Keep track of whether we have started concurrent phase or not.
|
// There would be a race between ConcurrentMarkThread and VMThread(ConcurrentMark::abort())
|
||||||
bool _concurrent_phase_started;
|
// to call ConcurrentGCTimer::register_gc_concurrent_end().
|
||||||
|
// And this variable is used to keep track of concurrent phase.
|
||||||
|
volatile uint _concurrent_phase_status;
|
||||||
|
// Concurrent phase is not yet started.
|
||||||
|
static const uint ConcPhaseNotStarted = 0;
|
||||||
|
// Concurrent phase is started.
|
||||||
|
static const uint ConcPhaseStarted = 1;
|
||||||
|
// Caller thread of ConcurrentGCTimer::register_gc_concurrent_end() is ending concurrent phase.
|
||||||
|
// So other thread should wait until the status to be changed to ConcPhaseNotStarted.
|
||||||
|
static const uint ConcPhaseStopping = 2;
|
||||||
|
|
||||||
// All of these times are in ms
|
// All of these times are in ms
|
||||||
NumberSeq _init_times;
|
NumberSeq _init_times;
|
||||||
@ -485,6 +494,9 @@ protected:
|
|||||||
// Set to true when initialization is complete
|
// Set to true when initialization is complete
|
||||||
bool _completed_initialization;
|
bool _completed_initialization;
|
||||||
|
|
||||||
|
// end_timer, true to end gc timer after ending concurrent phase.
|
||||||
|
void register_concurrent_phase_end_common(bool end_timer);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// Manipulation of the global mark stack.
|
// Manipulation of the global mark stack.
|
||||||
// The push and pop operations are used by tasks for transfers
|
// The push and pop operations are used by tasks for transfers
|
||||||
@ -520,6 +532,8 @@ public:
|
|||||||
|
|
||||||
void register_concurrent_phase_start(const char* title);
|
void register_concurrent_phase_start(const char* title);
|
||||||
void register_concurrent_phase_end();
|
void register_concurrent_phase_end();
|
||||||
|
// Ends both concurrent phase and timer.
|
||||||
|
void register_concurrent_gc_end_and_stop_timer();
|
||||||
|
|
||||||
void update_accum_task_vtime(int i, double vtime) {
|
void update_accum_task_vtime(int i, double vtime) {
|
||||||
_accum_task_vtime[i] += vtime;
|
_accum_task_vtime[i] += vtime;
|
||||||
|
@ -29,15 +29,21 @@
|
|||||||
#include "gc/shared/gcTrace.hpp"
|
#include "gc/shared/gcTrace.hpp"
|
||||||
#include "logging/log.hpp"
|
#include "logging/log.hpp"
|
||||||
|
|
||||||
G1IHOPControl::G1IHOPControl(double initial_ihop_percent, size_t target_occupancy) :
|
G1IHOPControl::G1IHOPControl(double initial_ihop_percent) :
|
||||||
_initial_ihop_percent(initial_ihop_percent),
|
_initial_ihop_percent(initial_ihop_percent),
|
||||||
_target_occupancy(target_occupancy),
|
_target_occupancy(0),
|
||||||
_last_allocated_bytes(0),
|
_last_allocated_bytes(0),
|
||||||
_last_allocation_time_s(0.0)
|
_last_allocation_time_s(0.0)
|
||||||
{
|
{
|
||||||
assert(_initial_ihop_percent >= 0.0 && _initial_ihop_percent <= 100.0, "Initial IHOP value must be between 0 and 100 but is %.3f", initial_ihop_percent);
|
assert(_initial_ihop_percent >= 0.0 && _initial_ihop_percent <= 100.0, "Initial IHOP value must be between 0 and 100 but is %.3f", initial_ihop_percent);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void G1IHOPControl::update_target_occupancy(size_t new_target_occupancy) {
|
||||||
|
log_debug(gc, ihop)("Target occupancy update: old: " SIZE_FORMAT "B, new: " SIZE_FORMAT "B",
|
||||||
|
_target_occupancy, new_target_occupancy);
|
||||||
|
_target_occupancy = new_target_occupancy;
|
||||||
|
}
|
||||||
|
|
||||||
void G1IHOPControl::update_allocation_info(double allocation_time_s, size_t allocated_bytes, size_t additional_buffer_size) {
|
void G1IHOPControl::update_allocation_info(double allocation_time_s, size_t allocated_bytes, size_t additional_buffer_size) {
|
||||||
assert(allocation_time_s >= 0.0, "Allocation time must be positive but is %.3f", allocation_time_s);
|
assert(allocation_time_s >= 0.0, "Allocation time must be positive but is %.3f", allocation_time_s);
|
||||||
|
|
||||||
@ -46,6 +52,7 @@ void G1IHOPControl::update_allocation_info(double allocation_time_s, size_t allo
|
|||||||
}
|
}
|
||||||
|
|
||||||
void G1IHOPControl::print() {
|
void G1IHOPControl::print() {
|
||||||
|
assert(_target_occupancy > 0, "Target occupancy still not updated yet.");
|
||||||
size_t cur_conc_mark_start_threshold = get_conc_mark_start_threshold();
|
size_t cur_conc_mark_start_threshold = get_conc_mark_start_threshold();
|
||||||
log_debug(gc, ihop)("Basic information (value update), threshold: " SIZE_FORMAT "B (%1.2f), target occupancy: " SIZE_FORMAT "B, current occupancy: " SIZE_FORMAT "B, "
|
log_debug(gc, ihop)("Basic information (value update), threshold: " SIZE_FORMAT "B (%1.2f), target occupancy: " SIZE_FORMAT "B, current occupancy: " SIZE_FORMAT "B, "
|
||||||
"recent allocation size: " SIZE_FORMAT "B, recent allocation duration: %1.2fms, recent old gen allocation rate: %1.2fB/s, recent marking phase length: %1.2fms",
|
"recent allocation size: " SIZE_FORMAT "B, recent allocation duration: %1.2fms, recent old gen allocation rate: %1.2fB/s, recent marking phase length: %1.2fms",
|
||||||
@ -60,6 +67,7 @@ void G1IHOPControl::print() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void G1IHOPControl::send_trace_event(G1NewTracer* tracer) {
|
void G1IHOPControl::send_trace_event(G1NewTracer* tracer) {
|
||||||
|
assert(_target_occupancy > 0, "Target occupancy still not updated yet.");
|
||||||
tracer->report_basic_ihop_statistics(get_conc_mark_start_threshold(),
|
tracer->report_basic_ihop_statistics(get_conc_mark_start_threshold(),
|
||||||
_target_occupancy,
|
_target_occupancy,
|
||||||
G1CollectedHeap::heap()->used(),
|
G1CollectedHeap::heap()->used(),
|
||||||
@ -68,10 +76,9 @@ void G1IHOPControl::send_trace_event(G1NewTracer* tracer) {
|
|||||||
last_marking_length_s());
|
last_marking_length_s());
|
||||||
}
|
}
|
||||||
|
|
||||||
G1StaticIHOPControl::G1StaticIHOPControl(double ihop_percent, size_t target_occupancy) :
|
G1StaticIHOPControl::G1StaticIHOPControl(double ihop_percent) :
|
||||||
G1IHOPControl(ihop_percent, target_occupancy),
|
G1IHOPControl(ihop_percent),
|
||||||
_last_marking_length_s(0.0) {
|
_last_marking_length_s(0.0) {
|
||||||
assert(_target_occupancy > 0, "Target occupancy must be larger than zero.");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
@ -85,7 +92,8 @@ static void test_update(G1IHOPControl* ctrl, double alloc_time, size_t alloc_amo
|
|||||||
void G1StaticIHOPControl::test() {
|
void G1StaticIHOPControl::test() {
|
||||||
size_t const initial_ihop = 45;
|
size_t const initial_ihop = 45;
|
||||||
|
|
||||||
G1StaticIHOPControl ctrl(initial_ihop, 100);
|
G1StaticIHOPControl ctrl(initial_ihop);
|
||||||
|
ctrl.update_target_occupancy(100);
|
||||||
|
|
||||||
size_t threshold = ctrl.get_conc_mark_start_threshold();
|
size_t threshold = ctrl.get_conc_mark_start_threshold();
|
||||||
assert(threshold == initial_ihop,
|
assert(threshold == initial_ihop,
|
||||||
@ -115,11 +123,10 @@ void G1StaticIHOPControl::test() {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
G1AdaptiveIHOPControl::G1AdaptiveIHOPControl(double ihop_percent,
|
G1AdaptiveIHOPControl::G1AdaptiveIHOPControl(double ihop_percent,
|
||||||
size_t initial_target_occupancy,
|
|
||||||
G1Predictions const* predictor,
|
G1Predictions const* predictor,
|
||||||
size_t heap_reserve_percent,
|
size_t heap_reserve_percent,
|
||||||
size_t heap_waste_percent) :
|
size_t heap_waste_percent) :
|
||||||
G1IHOPControl(ihop_percent, initial_target_occupancy),
|
G1IHOPControl(ihop_percent),
|
||||||
_predictor(predictor),
|
_predictor(predictor),
|
||||||
_marking_times_s(10, 0.95),
|
_marking_times_s(10, 0.95),
|
||||||
_allocation_rate_s(10, 0.95),
|
_allocation_rate_s(10, 0.95),
|
||||||
@ -130,6 +137,7 @@ G1AdaptiveIHOPControl::G1AdaptiveIHOPControl(double ihop_percent,
|
|||||||
}
|
}
|
||||||
|
|
||||||
size_t G1AdaptiveIHOPControl::actual_target_threshold() const {
|
size_t G1AdaptiveIHOPControl::actual_target_threshold() const {
|
||||||
|
guarantee(_target_occupancy > 0, "Target occupancy still not updated yet.");
|
||||||
// The actual target threshold takes the heap reserve and the expected waste in
|
// The actual target threshold takes the heap reserve and the expected waste in
|
||||||
// free space into account.
|
// free space into account.
|
||||||
// _heap_reserve is that part of the total heap capacity that is reserved for
|
// _heap_reserve is that part of the total heap capacity that is reserved for
|
||||||
@ -227,7 +235,8 @@ void G1AdaptiveIHOPControl::test() {
|
|||||||
// target_size - (young_size + alloc_amount/alloc_time * marking_time)
|
// target_size - (young_size + alloc_amount/alloc_time * marking_time)
|
||||||
|
|
||||||
G1Predictions pred(0.95);
|
G1Predictions pred(0.95);
|
||||||
G1AdaptiveIHOPControl ctrl(initial_threshold, target_size, &pred, 0, 0);
|
G1AdaptiveIHOPControl ctrl(initial_threshold, &pred, 0, 0);
|
||||||
|
ctrl.update_target_occupancy(target_size);
|
||||||
|
|
||||||
// First "load".
|
// First "load".
|
||||||
size_t const alloc_time1 = 2;
|
size_t const alloc_time1 = 2;
|
||||||
@ -288,5 +297,6 @@ void G1AdaptiveIHOPControl::test() {
|
|||||||
|
|
||||||
void IHOP_test() {
|
void IHOP_test() {
|
||||||
G1StaticIHOPControl::test();
|
G1StaticIHOPControl::test();
|
||||||
|
G1AdaptiveIHOPControl::test();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -38,7 +38,8 @@ class G1IHOPControl : public CHeapObj<mtGC> {
|
|||||||
protected:
|
protected:
|
||||||
// The initial IHOP value relative to the target occupancy.
|
// The initial IHOP value relative to the target occupancy.
|
||||||
double _initial_ihop_percent;
|
double _initial_ihop_percent;
|
||||||
// The target maximum occupancy of the heap.
|
// The target maximum occupancy of the heap. The target occupancy is the number
|
||||||
|
// of bytes when marking should be finished and reclaim started.
|
||||||
size_t _target_occupancy;
|
size_t _target_occupancy;
|
||||||
|
|
||||||
// Most recent complete mutator allocation period in seconds.
|
// Most recent complete mutator allocation period in seconds.
|
||||||
@ -46,10 +47,9 @@ class G1IHOPControl : public CHeapObj<mtGC> {
|
|||||||
// Amount of bytes allocated during _last_allocation_time_s.
|
// Amount of bytes allocated during _last_allocation_time_s.
|
||||||
size_t _last_allocated_bytes;
|
size_t _last_allocated_bytes;
|
||||||
|
|
||||||
// Initialize an instance with the initial IHOP value in percent and the target
|
// Initialize an instance with the initial IHOP value in percent. The target
|
||||||
// occupancy. The target occupancy is the number of bytes when marking should
|
// occupancy will be updated at the first heap expansion.
|
||||||
// be finished and reclaim started.
|
G1IHOPControl(double initial_ihop_percent);
|
||||||
G1IHOPControl(double initial_ihop_percent, size_t target_occupancy);
|
|
||||||
|
|
||||||
// Most recent time from the end of the initial mark to the start of the first
|
// Most recent time from the end of the initial mark to the start of the first
|
||||||
// mixed gc.
|
// mixed gc.
|
||||||
@ -60,6 +60,8 @@ class G1IHOPControl : public CHeapObj<mtGC> {
|
|||||||
// Get the current non-young occupancy at which concurrent marking should start.
|
// Get the current non-young occupancy at which concurrent marking should start.
|
||||||
virtual size_t get_conc_mark_start_threshold() = 0;
|
virtual size_t get_conc_mark_start_threshold() = 0;
|
||||||
|
|
||||||
|
// Adjust target occupancy.
|
||||||
|
virtual void update_target_occupancy(size_t new_target_occupancy);
|
||||||
// Update information about time during which allocations in the Java heap occurred,
|
// Update information about time during which allocations in the Java heap occurred,
|
||||||
// how large these allocations were in bytes, and an additional buffer.
|
// how large these allocations were in bytes, and an additional buffer.
|
||||||
// The allocations should contain any amount of space made unusable for further
|
// The allocations should contain any amount of space made unusable for further
|
||||||
@ -86,9 +88,12 @@ class G1StaticIHOPControl : public G1IHOPControl {
|
|||||||
protected:
|
protected:
|
||||||
double last_marking_length_s() const { return _last_marking_length_s; }
|
double last_marking_length_s() const { return _last_marking_length_s; }
|
||||||
public:
|
public:
|
||||||
G1StaticIHOPControl(double ihop_percent, size_t target_occupancy);
|
G1StaticIHOPControl(double ihop_percent);
|
||||||
|
|
||||||
size_t get_conc_mark_start_threshold() { return (size_t) (_initial_ihop_percent * _target_occupancy / 100.0); }
|
size_t get_conc_mark_start_threshold() {
|
||||||
|
guarantee(_target_occupancy > 0, "Target occupancy must have been initialized.");
|
||||||
|
return (size_t) (_initial_ihop_percent * _target_occupancy / 100.0);
|
||||||
|
}
|
||||||
|
|
||||||
virtual void update_marking_length(double marking_length_s) {
|
virtual void update_marking_length(double marking_length_s) {
|
||||||
assert(marking_length_s > 0.0, "Marking length must be larger than zero but is %.3f", marking_length_s);
|
assert(marking_length_s > 0.0, "Marking length must be larger than zero but is %.3f", marking_length_s);
|
||||||
@ -132,7 +137,6 @@ class G1AdaptiveIHOPControl : public G1IHOPControl {
|
|||||||
virtual double last_marking_length_s() const { return _marking_times_s.last(); }
|
virtual double last_marking_length_s() const { return _marking_times_s.last(); }
|
||||||
public:
|
public:
|
||||||
G1AdaptiveIHOPControl(double ihop_percent,
|
G1AdaptiveIHOPControl(double ihop_percent,
|
||||||
size_t initial_target_occupancy,
|
|
||||||
G1Predictions const* predictor,
|
G1Predictions const* predictor,
|
||||||
size_t heap_reserve_percent, // The percentage of total heap capacity that should not be tapped into.
|
size_t heap_reserve_percent, // The percentage of total heap capacity that should not be tapped into.
|
||||||
size_t heap_waste_percent); // The percentage of the free space in the heap that we think is not usable for allocation.
|
size_t heap_waste_percent); // The percentage of the free space in the heap that we think is not usable for allocation.
|
||||||
|
@ -171,14 +171,7 @@ inline void G1UpdateRSOrPushRefOopClosure::do_oop_work(T* p) {
|
|||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
// can't do because of races
|
// can't do because of races
|
||||||
// assert(obj == NULL || obj->is_oop(), "expected an oop");
|
// assert(obj == NULL || obj->is_oop(), "expected an oop");
|
||||||
|
assert(check_obj_alignment(obj), "not oop aligned");
|
||||||
// Do the safe subset of is_oop
|
|
||||||
#ifdef CHECK_UNHANDLED_OOPS
|
|
||||||
oopDesc* o = obj.obj();
|
|
||||||
#else
|
|
||||||
oopDesc* o = obj;
|
|
||||||
#endif // CHECK_UNHANDLED_OOPS
|
|
||||||
assert((intptr_t)o % MinObjAlignmentInBytes == 0, "not oop aligned");
|
|
||||||
assert(_g1->is_in_reserved(obj), "must be in heap");
|
assert(_g1->is_in_reserved(obj), "must be in heap");
|
||||||
#endif // ASSERT
|
#endif // ASSERT
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2016, 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
|
||||||
@ -44,14 +44,7 @@ inline void G1RemSet::par_write_ref(HeapRegion* from, T* p, uint tid) {
|
|||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
// can't do because of races
|
// can't do because of races
|
||||||
// assert(obj == NULL || obj->is_oop(), "expected an oop");
|
// assert(obj == NULL || obj->is_oop(), "expected an oop");
|
||||||
|
assert(check_obj_alignment(obj), "not oop aligned");
|
||||||
// Do the safe subset of is_oop
|
|
||||||
#ifdef CHECK_UNHANDLED_OOPS
|
|
||||||
oopDesc* o = obj.obj();
|
|
||||||
#else
|
|
||||||
oopDesc* o = obj;
|
|
||||||
#endif // CHECK_UNHANDLED_OOPS
|
|
||||||
assert((intptr_t)o % MinObjAlignmentInBytes == 0, "not oop aligned");
|
|
||||||
assert(_g1->is_in_reserved(obj), "must be in heap");
|
assert(_g1->is_in_reserved(obj), "must be in heap");
|
||||||
#endif // ASSERT
|
#endif // ASSERT
|
||||||
|
|
||||||
|
@ -125,14 +125,14 @@ inline void oop_pc_follow_contents_specialized(objArrayOop obj, int index, ParCo
|
|||||||
T* const beg = base + beg_index;
|
T* const beg = base + beg_index;
|
||||||
T* const end = base + end_index;
|
T* const end = base + end_index;
|
||||||
|
|
||||||
|
if (end_index < len) {
|
||||||
|
cm->push_objarray(obj, end_index); // Push the continuation.
|
||||||
|
}
|
||||||
|
|
||||||
// Push the non-NULL elements of the next stride on the marking stack.
|
// Push the non-NULL elements of the next stride on the marking stack.
|
||||||
for (T* e = beg; e < end; e++) {
|
for (T* e = beg; e < end; e++) {
|
||||||
cm->mark_and_push<T>(e);
|
cm->mark_and_push<T>(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (end_index < len) {
|
|
||||||
cm->push_objarray(obj, end_index); // Push the continuation.
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void ParCompactionManager::follow_contents(objArrayOop obj, int index) {
|
inline void ParCompactionManager::follow_contents(objArrayOop obj, int index) {
|
||||||
|
@ -1483,17 +1483,6 @@ void PSParallelCompact::fill_dense_prefix_end(SpaceId id)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
PSParallelCompact::clear_source_region(HeapWord* beg_addr, HeapWord* end_addr)
|
|
||||||
{
|
|
||||||
RegionData* const beg_ptr = _summary_data.addr_to_region_ptr(beg_addr);
|
|
||||||
HeapWord* const end_aligned_up = _summary_data.region_align_up(end_addr);
|
|
||||||
RegionData* const end_ptr = _summary_data.addr_to_region_ptr(end_aligned_up);
|
|
||||||
for (RegionData* cur = beg_ptr; cur < end_ptr; ++cur) {
|
|
||||||
cur->set_source_region(0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
PSParallelCompact::summarize_space(SpaceId id, bool maximum_compaction)
|
PSParallelCompact::summarize_space(SpaceId id, bool maximum_compaction)
|
||||||
{
|
{
|
||||||
|
@ -1065,9 +1065,6 @@ class PSParallelCompact : AllStatic {
|
|||||||
// non-empty.
|
// non-empty.
|
||||||
static void fill_dense_prefix_end(SpaceId id);
|
static void fill_dense_prefix_end(SpaceId id);
|
||||||
|
|
||||||
// Clear the summary data source_region field for the specified addresses.
|
|
||||||
static void clear_source_region(HeapWord* beg_addr, HeapWord* end_addr);
|
|
||||||
|
|
||||||
static void summarize_spaces_quick();
|
static void summarize_spaces_quick();
|
||||||
static void summarize_space(SpaceId id, bool maximum_compaction);
|
static void summarize_space(SpaceId id, bool maximum_compaction);
|
||||||
static void summary_phase(ParCompactionManager* cm, bool maximum_compaction);
|
static void summary_phase(ParCompactionManager* cm, bool maximum_compaction);
|
||||||
|
@ -600,12 +600,6 @@ bool PSScavenge::invoke_no_policy() {
|
|||||||
|
|
||||||
NOT_PRODUCT(reference_processor()->verify_no_references_recorded());
|
NOT_PRODUCT(reference_processor()->verify_no_references_recorded());
|
||||||
|
|
||||||
{
|
|
||||||
GCTraceTime(Debug, gc, phases) tm("Prune Scavenge Root Methods", &_gc_timer);
|
|
||||||
|
|
||||||
CodeCache::prune_scavenge_root_nmethods();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Re-verify object start arrays
|
// Re-verify object start arrays
|
||||||
if (VerifyObjectStartArray &&
|
if (VerifyObjectStartArray &&
|
||||||
VerifyAfterGC) {
|
VerifyAfterGC) {
|
||||||
|
@ -561,7 +561,7 @@ void GenCollectedHeap::process_roots(StrongRootsScope* scope,
|
|||||||
OopClosure* weak_roots,
|
OopClosure* weak_roots,
|
||||||
CLDClosure* strong_cld_closure,
|
CLDClosure* strong_cld_closure,
|
||||||
CLDClosure* weak_cld_closure,
|
CLDClosure* weak_cld_closure,
|
||||||
CodeBlobClosure* code_roots) {
|
CodeBlobToOopClosure* code_roots) {
|
||||||
// General roots.
|
// General roots.
|
||||||
assert(Threads::thread_claim_parity() != 0, "must have called prologue code");
|
assert(Threads::thread_claim_parity() != 0, "must have called prologue code");
|
||||||
assert(code_roots != NULL, "code root closure should always be set");
|
assert(code_roots != NULL, "code root closure should always be set");
|
||||||
@ -578,7 +578,7 @@ void GenCollectedHeap::process_roots(StrongRootsScope* scope,
|
|||||||
// Don't process them if they will be processed during the ClassLoaderDataGraph phase.
|
// Don't process them if they will be processed during the ClassLoaderDataGraph phase.
|
||||||
CLDClosure* roots_from_clds_p = (strong_cld_closure != weak_cld_closure) ? strong_cld_closure : NULL;
|
CLDClosure* roots_from_clds_p = (strong_cld_closure != weak_cld_closure) ? strong_cld_closure : NULL;
|
||||||
// Only process code roots from thread stacks if we aren't visiting the entire CodeCache anyway
|
// Only process code roots from thread stacks if we aren't visiting the entire CodeCache anyway
|
||||||
CodeBlobClosure* roots_from_code_p = (so & SO_AllCodeCache) ? NULL : code_roots;
|
CodeBlobToOopClosure* roots_from_code_p = (so & SO_AllCodeCache) ? NULL : code_roots;
|
||||||
|
|
||||||
bool is_par = scope->n_threads() > 1;
|
bool is_par = scope->n_threads() > 1;
|
||||||
Threads::possibly_parallel_oops_do(is_par, strong_roots, roots_from_clds_p, roots_from_code_p);
|
Threads::possibly_parallel_oops_do(is_par, strong_roots, roots_from_clds_p, roots_from_code_p);
|
||||||
|
@ -399,7 +399,7 @@ public:
|
|||||||
OopClosure* weak_roots,
|
OopClosure* weak_roots,
|
||||||
CLDClosure* strong_cld_closure,
|
CLDClosure* strong_cld_closure,
|
||||||
CLDClosure* weak_cld_closure,
|
CLDClosure* weak_cld_closure,
|
||||||
CodeBlobClosure* code_roots);
|
CodeBlobToOopClosure* code_roots);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static const bool StrongAndWeakRoots = false;
|
static const bool StrongAndWeakRoots = false;
|
||||||
|
@ -107,18 +107,25 @@ class Log VALUE_OBJ_CLASS_SPEC {
|
|||||||
return LogTagSetMapping<T0, T1, T2, T3, T4>::tagset().is_level(level);
|
return LogTagSetMapping<T0, T1, T2, T3, T4>::tagset().is_level(level);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ATTRIBUTE_PRINTF(2, 3)
|
||||||
|
static void write(LogLevelType level, const char* fmt, ...) {
|
||||||
|
va_list args;
|
||||||
|
va_start(args, fmt);
|
||||||
|
vwrite(level, fmt, args);
|
||||||
|
va_end(args);
|
||||||
|
};
|
||||||
|
|
||||||
template <LogLevelType Level>
|
template <LogLevelType Level>
|
||||||
ATTRIBUTE_PRINTF(1, 2)
|
ATTRIBUTE_PRINTF(1, 2)
|
||||||
static void write(const char* fmt, ...) {
|
static void write(const char* fmt, ...) {
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, fmt);
|
va_start(args, fmt);
|
||||||
vwrite<Level>(fmt, args);
|
vwrite(Level, fmt, args);
|
||||||
va_end(args);
|
va_end(args);
|
||||||
};
|
};
|
||||||
|
|
||||||
template <LogLevelType Level>
|
ATTRIBUTE_PRINTF(2, 0)
|
||||||
ATTRIBUTE_PRINTF(1, 0)
|
static void vwrite(LogLevelType level, const char* fmt, va_list args) {
|
||||||
static void vwrite(const char* fmt, va_list args) {
|
|
||||||
char buf[LogBufferSize];
|
char buf[LogBufferSize];
|
||||||
va_list saved_args; // For re-format on buf overflow.
|
va_list saved_args; // For re-format on buf overflow.
|
||||||
va_copy(saved_args, args);
|
va_copy(saved_args, args);
|
||||||
@ -132,27 +139,26 @@ class Log VALUE_OBJ_CLASS_SPEC {
|
|||||||
prefix_len = LogPrefix<T0, T1, T2, T3, T4>::prefix(newbuf, newbuf_len);
|
prefix_len = LogPrefix<T0, T1, T2, T3, T4>::prefix(newbuf, newbuf_len);
|
||||||
ret = os::log_vsnprintf(newbuf + prefix_len, newbuf_len - prefix_len, fmt, saved_args);
|
ret = os::log_vsnprintf(newbuf + prefix_len, newbuf_len - prefix_len, fmt, saved_args);
|
||||||
assert(ret >= 0, "Log message buffer issue");
|
assert(ret >= 0, "Log message buffer issue");
|
||||||
puts<Level>(newbuf);
|
puts(level, newbuf);
|
||||||
FREE_C_HEAP_ARRAY(char, newbuf);
|
FREE_C_HEAP_ARRAY(char, newbuf);
|
||||||
} else {
|
} else {
|
||||||
puts<Level>(buf);
|
puts(level, buf);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <LogLevelType Level>
|
static void puts(LogLevelType level, const char* string) {
|
||||||
static void puts(const char* string) {
|
LogTagSetMapping<T0, T1, T2, T3, T4>::tagset().log(level, string);
|
||||||
LogTagSetMapping<T0, T1, T2, T3, T4>::tagset().log(Level, string);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#define LOG_LEVEL(level, name) ATTRIBUTE_PRINTF(2, 0) \
|
#define LOG_LEVEL(level, name) ATTRIBUTE_PRINTF(2, 0) \
|
||||||
Log& v##name(const char* fmt, va_list args) { \
|
Log& v##name(const char* fmt, va_list args) { \
|
||||||
vwrite<LogLevel::level>(fmt, args); \
|
vwrite(LogLevel::level, fmt, args); \
|
||||||
return *this; \
|
return *this; \
|
||||||
} \
|
} \
|
||||||
Log& name(const char* fmt, ...) ATTRIBUTE_PRINTF(2, 3) { \
|
Log& name(const char* fmt, ...) ATTRIBUTE_PRINTF(2, 3) { \
|
||||||
va_list args; \
|
va_list args; \
|
||||||
va_start(args, fmt); \
|
va_start(args, fmt); \
|
||||||
vwrite<LogLevel::level>(fmt, args); \
|
vwrite(LogLevel::level, fmt, args); \
|
||||||
va_end(args); \
|
va_end(args); \
|
||||||
return *this; \
|
return *this; \
|
||||||
} \
|
} \
|
||||||
|
@ -285,9 +285,12 @@ class CodeBlobToOopClosure : public CodeBlobClosure {
|
|||||||
protected:
|
protected:
|
||||||
void do_nmethod(nmethod* nm);
|
void do_nmethod(nmethod* nm);
|
||||||
public:
|
public:
|
||||||
|
// If fix_relocations(), then cl must copy objects to their new location immediately to avoid
|
||||||
|
// patching nmethods with the old locations.
|
||||||
CodeBlobToOopClosure(OopClosure* cl, bool fix_relocations) : _cl(cl), _fix_relocations(fix_relocations) {}
|
CodeBlobToOopClosure(OopClosure* cl, bool fix_relocations) : _cl(cl), _fix_relocations(fix_relocations) {}
|
||||||
virtual void do_code_blob(CodeBlob* cb);
|
virtual void do_code_blob(CodeBlob* cb);
|
||||||
|
|
||||||
|
bool fix_relocations() const { return _fix_relocations; }
|
||||||
const static bool FixRelocations = true;
|
const static bool FixRelocations = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -295,7 +295,7 @@ address* oopDesc::address_field_addr(int offset) const { return (address*) f
|
|||||||
// in inner GC loops so these are separated.
|
// in inner GC loops so these are separated.
|
||||||
|
|
||||||
inline bool check_obj_alignment(oop obj) {
|
inline bool check_obj_alignment(oop obj) {
|
||||||
return cast_from_oop<intptr_t>(obj) % MinObjAlignmentInBytes == 0;
|
return (cast_from_oop<intptr_t>(obj) & MinObjAlignmentInBytesMask) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
oop oopDesc::decode_heap_oop_not_null(narrowOop v) {
|
oop oopDesc::decode_heap_oop_not_null(narrowOop v) {
|
||||||
|
@ -158,9 +158,21 @@ void Symbol::print_utf8_on(outputStream* st) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Symbol::print_symbol_on(outputStream* st) const {
|
void Symbol::print_symbol_on(outputStream* st) const {
|
||||||
ResourceMark rm;
|
char *s;
|
||||||
st = st ? st : tty;
|
st = st ? st : tty;
|
||||||
st->print("%s", as_quoted_ascii());
|
{
|
||||||
|
// ResourceMark may not affect st->print(). If st is a string
|
||||||
|
// stream it could resize, using the same resource arena.
|
||||||
|
ResourceMark rm;
|
||||||
|
s = as_quoted_ascii();
|
||||||
|
s = os::strdup(s);
|
||||||
|
}
|
||||||
|
if (s == NULL) {
|
||||||
|
st->print("(null)");
|
||||||
|
} else {
|
||||||
|
st->print("%s", s);
|
||||||
|
os::free(s);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
char* Symbol::as_quoted_ascii() const {
|
char* Symbol::as_quoted_ascii() const {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, 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
|
||||||
@ -247,6 +247,9 @@ void emit_range_size_t(const char* /*name*/) { /* NOP */ }
|
|||||||
void emit_range_double(const char* /*name*/) { /* NOP */ }
|
void emit_range_double(const char* /*name*/) { /* NOP */ }
|
||||||
|
|
||||||
// CommandLineFlagRange emitting code functions if range arguments are provided
|
// CommandLineFlagRange emitting code functions if range arguments are provided
|
||||||
|
void emit_range_int(const char* name, int min, int max) {
|
||||||
|
CommandLineFlagRangeList::add(new CommandLineFlagRange_int(name, min, max));
|
||||||
|
}
|
||||||
void emit_range_intx(const char* name, intx min, intx max) {
|
void emit_range_intx(const char* name, intx min, intx max) {
|
||||||
CommandLineFlagRangeList::add(new CommandLineFlagRange_intx(name, min, max));
|
CommandLineFlagRangeList::add(new CommandLineFlagRange_intx(name, min, max));
|
||||||
}
|
}
|
||||||
|
@ -891,9 +891,6 @@ public:
|
|||||||
notproduct(bool, VerifyLastFrame, false, \
|
notproduct(bool, VerifyLastFrame, false, \
|
||||||
"Verify oops on last frame on entry to VM") \
|
"Verify oops on last frame on entry to VM") \
|
||||||
\
|
\
|
||||||
develop(bool, TraceHandleAllocation, false, \
|
|
||||||
"Print out warnings when suspiciously many handles are allocated")\
|
|
||||||
\
|
|
||||||
product(bool, FailOverToOldVerifier, true, \
|
product(bool, FailOverToOldVerifier, true, \
|
||||||
"Fail over to old verifier when split verifier fails") \
|
"Fail over to old verifier when split verifier fails") \
|
||||||
\
|
\
|
||||||
@ -1603,10 +1600,10 @@ public:
|
|||||||
product(bool, ResizePLAB, true, \
|
product(bool, ResizePLAB, true, \
|
||||||
"Dynamically resize (survivor space) promotion LAB's") \
|
"Dynamically resize (survivor space) promotion LAB's") \
|
||||||
\
|
\
|
||||||
product(intx, ParGCArrayScanChunk, 50, \
|
product(int, ParGCArrayScanChunk, 50, \
|
||||||
"Scan a subset of object array and push remainder, if array is " \
|
"Scan a subset of object array and push remainder, if array is " \
|
||||||
"bigger than this") \
|
"bigger than this") \
|
||||||
range(1, max_intx) \
|
range(1, max_jint/3) \
|
||||||
\
|
\
|
||||||
product(bool, ParGCUseLocalOverflow, false, \
|
product(bool, ParGCUseLocalOverflow, false, \
|
||||||
"Instead of a global overflow list, use local overflow stacks") \
|
"Instead of a global overflow list, use local overflow stacks") \
|
||||||
@ -3024,14 +3021,6 @@ public:
|
|||||||
notproduct(ccstrlist, SuppressErrorAt, "", \
|
notproduct(ccstrlist, SuppressErrorAt, "", \
|
||||||
"List of assertions (file:line) to muzzle") \
|
"List of assertions (file:line) to muzzle") \
|
||||||
\
|
\
|
||||||
notproduct(size_t, HandleAllocationLimit, 1024, \
|
|
||||||
"Threshold for HandleMark allocation when +TraceHandleAllocation "\
|
|
||||||
"is used") \
|
|
||||||
\
|
|
||||||
develop(size_t, TotalHandleAllocationLimit, 1024, \
|
|
||||||
"Threshold for total handle allocation when " \
|
|
||||||
"+TraceHandleAllocation is used") \
|
|
||||||
\
|
|
||||||
develop(intx, StackPrintLimit, 100, \
|
develop(intx, StackPrintLimit, 100, \
|
||||||
"number of stack frames to print in VM-level stack dump") \
|
"number of stack frames to print in VM-level stack dump") \
|
||||||
\
|
\
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2016, 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
|
||||||
@ -129,14 +129,6 @@ void HandleArea::oops_do(OopClosure* f) {
|
|||||||
k = k->next();
|
k = k->next();
|
||||||
}
|
}
|
||||||
|
|
||||||
// The thread local handle areas should not get very large
|
|
||||||
if (TraceHandleAllocation && (size_t)handles_visited > TotalHandleAllocationLimit) {
|
|
||||||
#ifdef ASSERT
|
|
||||||
warning("%d: Visited in HandleMark : " SIZE_FORMAT, _nof_handlemarks, handles_visited);
|
|
||||||
#else
|
|
||||||
warning("Visited in HandleMark : " SIZE_FORMAT, handles_visited);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
if (_prev != NULL) _prev->oops_do(f);
|
if (_prev != NULL) _prev->oops_do(f);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -165,31 +157,6 @@ HandleMark::~HandleMark() {
|
|||||||
assert(area->_handle_mark_nesting > 0, "must stack allocate HandleMarks" );
|
assert(area->_handle_mark_nesting > 0, "must stack allocate HandleMarks" );
|
||||||
debug_only(area->_handle_mark_nesting--);
|
debug_only(area->_handle_mark_nesting--);
|
||||||
|
|
||||||
// Debug code to trace the number of handles allocated per mark/
|
|
||||||
#ifdef ASSERT
|
|
||||||
if (TraceHandleAllocation) {
|
|
||||||
size_t handles = 0;
|
|
||||||
Chunk *c = _chunk->next();
|
|
||||||
if (c == NULL) {
|
|
||||||
handles = area->_hwm - _hwm; // no new chunk allocated
|
|
||||||
} else {
|
|
||||||
handles = _max - _hwm; // add rest in first chunk
|
|
||||||
while(c != NULL) {
|
|
||||||
handles += c->length();
|
|
||||||
c = c->next();
|
|
||||||
}
|
|
||||||
handles -= area->_max - area->_hwm; // adjust for last trunk not full
|
|
||||||
}
|
|
||||||
handles /= sizeof(void *); // Adjust for size of a handle
|
|
||||||
if (handles > HandleAllocationLimit) {
|
|
||||||
// Note: _nof_handlemarks is only set in debug mode
|
|
||||||
warning("%d: Allocated in HandleMark : " SIZE_FORMAT, _nof_handlemarks, handles);
|
|
||||||
}
|
|
||||||
|
|
||||||
tty->print_cr("Handles " SIZE_FORMAT, handles);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Delete later chunks
|
// Delete later chunks
|
||||||
if( _chunk->next() ) {
|
if( _chunk->next() ) {
|
||||||
// reset arena size before delete chunks. Otherwise, the total
|
// reset arena size before delete chunks. Otherwise, the total
|
||||||
|
@ -313,7 +313,7 @@ inline size_t pointer_delta(const MetaWord* left, const MetaWord* right) {
|
|||||||
// ANSI C++ does not allow casting from one pointer type to a function pointer
|
// ANSI C++ does not allow casting from one pointer type to a function pointer
|
||||||
// directly without at best a warning. This macro accomplishes it silently
|
// directly without at best a warning. This macro accomplishes it silently
|
||||||
// In every case that is present at this point the value be cast is a pointer
|
// In every case that is present at this point the value be cast is a pointer
|
||||||
// to a C linkage function. In somecase the type used for the cast reflects
|
// to a C linkage function. In some case the type used for the cast reflects
|
||||||
// that linkage and a picky compiler would not complain. In other cases because
|
// that linkage and a picky compiler would not complain. In other cases because
|
||||||
// there is no convenient place to place a typedef with extern C linkage (i.e
|
// there is no convenient place to place a typedef with extern C linkage (i.e
|
||||||
// a platform dependent header file) it doesn't. At this point no compiler seems
|
// a platform dependent header file) it doesn't. At this point no compiler seems
|
||||||
@ -678,7 +678,7 @@ extern const char* type2name_tab[T_CONFLICT+1]; // Map a BasicType to a jcha
|
|||||||
inline const char* type2name(BasicType t) { return (uint)t < T_CONFLICT+1 ? type2name_tab[t] : NULL; }
|
inline const char* type2name(BasicType t) { return (uint)t < T_CONFLICT+1 ? type2name_tab[t] : NULL; }
|
||||||
extern BasicType name2type(const char* name);
|
extern BasicType name2type(const char* name);
|
||||||
|
|
||||||
// Auxilary math routines
|
// Auxiliary math routines
|
||||||
// least common multiple
|
// least common multiple
|
||||||
extern size_t lcm(size_t a, size_t b);
|
extern size_t lcm(size_t a, size_t b);
|
||||||
|
|
||||||
@ -801,7 +801,7 @@ class JavaValue {
|
|||||||
|
|
||||||
// TosState describes the top-of-stack state before and after the execution of
|
// TosState describes the top-of-stack state before and after the execution of
|
||||||
// a bytecode or method. The top-of-stack value may be cached in one or more CPU
|
// a bytecode or method. The top-of-stack value may be cached in one or more CPU
|
||||||
// registers. The TosState corresponds to the 'machine represention' of this cached
|
// registers. The TosState corresponds to the 'machine representation' of this cached
|
||||||
// value. There's 4 states corresponding to the JAVA types int, long, float & double
|
// value. There's 4 states corresponding to the JAVA types int, long, float & double
|
||||||
// as well as a 5th state in case the top-of-stack value is actually on the top
|
// as well as a 5th state in case the top-of-stack value is actually on the top
|
||||||
// of stack (in memory) and thus not cached. The atos state corresponds to the itos
|
// of stack (in memory) and thus not cached. The atos state corresponds to the itos
|
||||||
@ -876,7 +876,7 @@ TosState as_TosState(BasicType type);
|
|||||||
// a transition from one state to another. These extra states makes it possible for the safepoint code to
|
// a transition from one state to another. These extra states makes it possible for the safepoint code to
|
||||||
// handle certain thread_states without having to suspend the thread - making the safepoint code faster.
|
// handle certain thread_states without having to suspend the thread - making the safepoint code faster.
|
||||||
//
|
//
|
||||||
// Given a state, the xxx_trans state can always be found by adding 1.
|
// Given a state, the xxxx_trans state can always be found by adding 1.
|
||||||
//
|
//
|
||||||
enum JavaThreadState {
|
enum JavaThreadState {
|
||||||
_thread_uninitialized = 0, // should never happen (missing initialization)
|
_thread_uninitialized = 0, // should never happen (missing initialization)
|
||||||
@ -1425,7 +1425,7 @@ template<class T> static void swap(T& a, T& b) {
|
|||||||
// operations.
|
// operations.
|
||||||
|
|
||||||
// The goal of this code to avoid undefined or implementation-defined
|
// The goal of this code to avoid undefined or implementation-defined
|
||||||
// behaviour. The use of an lvalue to reference cast is explicitly
|
// behavior. The use of an lvalue to reference cast is explicitly
|
||||||
// permitted by Lvalues and rvalues [basic.lval]. [Section 3.10 Para
|
// permitted by Lvalues and rvalues [basic.lval]. [Section 3.10 Para
|
||||||
// 15 in C++03]
|
// 15 in C++03]
|
||||||
#define JAVA_INTEGER_OP(OP, NAME, TYPE, UNSIGNED_TYPE) \
|
#define JAVA_INTEGER_OP(OP, NAME, TYPE, UNSIGNED_TYPE) \
|
||||||
|
@ -338,7 +338,9 @@ void stringStream::write(const char* s, size_t len) {
|
|||||||
}
|
}
|
||||||
char* oldbuf = buffer;
|
char* oldbuf = buffer;
|
||||||
assert(rm == NULL || Thread::current()->current_resource_mark() == rm,
|
assert(rm == NULL || Thread::current()->current_resource_mark() == rm,
|
||||||
"stringStream is re-allocated with a different ResourceMark");
|
"StringStream is re-allocated with a different ResourceMark. Current: "
|
||||||
|
PTR_FORMAT " original: " PTR_FORMAT,
|
||||||
|
p2i(Thread::current()->current_resource_mark()), p2i(rm));
|
||||||
buffer = NEW_RESOURCE_ARRAY(char, end);
|
buffer = NEW_RESOURCE_ARRAY(char, end);
|
||||||
if (buffer_pos > 0) {
|
if (buffer_pos > 0) {
|
||||||
memcpy(buffer, oldbuf, buffer_pos);
|
memcpy(buffer, oldbuf, buffer_pos);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2013, 2016, 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
|
||||||
@ -230,8 +230,10 @@ compact1_minimal = \
|
|||||||
#
|
#
|
||||||
needs_g1gc = \
|
needs_g1gc = \
|
||||||
compiler/regalloc/C1ObjectSpillInLogicOp.java \
|
compiler/regalloc/C1ObjectSpillInLogicOp.java \
|
||||||
|
gc/TestSmallHeap.java \
|
||||||
gc/TestSystemGC.java \
|
gc/TestSystemGC.java \
|
||||||
gc/arguments/TestAlignmentToUseLargePages.java \
|
gc/arguments/TestAlignmentToUseLargePages.java \
|
||||||
|
gc/arguments/TestG1ConcRefinementThreads.java \
|
||||||
gc/arguments/TestG1HeapRegionSize.java \
|
gc/arguments/TestG1HeapRegionSize.java \
|
||||||
gc/arguments/TestG1HeapSizeFlags.java \
|
gc/arguments/TestG1HeapSizeFlags.java \
|
||||||
gc/arguments/TestG1PercentageOptions.java \
|
gc/arguments/TestG1PercentageOptions.java \
|
||||||
@ -242,11 +244,11 @@ needs_g1gc = \
|
|||||||
gc/class_unloading/TestG1ClassUnloadingHWM.java \
|
gc/class_unloading/TestG1ClassUnloadingHWM.java \
|
||||||
gc/ergonomics/TestDynamicNumberOfGCThreads.java \
|
gc/ergonomics/TestDynamicNumberOfGCThreads.java \
|
||||||
gc/g1/ \
|
gc/g1/ \
|
||||||
|
gc/logging/TestGCId.java \
|
||||||
gc/metaspace/G1AddMetaspaceDependency.java \
|
gc/metaspace/G1AddMetaspaceDependency.java \
|
||||||
gc/metaspace/TestMetaspacePerfCounters.java \
|
gc/metaspace/TestMetaspacePerfCounters.java \
|
||||||
gc/startup_warnings/TestG1.java \
|
gc/startup_warnings/TestG1.java \
|
||||||
gc/whitebox/TestConcMarkCycleWB.java \
|
gc/whitebox/TestConcMarkCycleWB.java
|
||||||
gc/arguments/TestG1ConcRefinementThreads.java
|
|
||||||
|
|
||||||
hotspot_native_sanity = \
|
hotspot_native_sanity = \
|
||||||
native_sanity
|
native_sanity
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, 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
|
||||||
@ -31,6 +31,7 @@ import jdk.test.lib.Platform;
|
|||||||
* @key gc
|
* @key gc
|
||||||
* @bug 8059066
|
* @bug 8059066
|
||||||
* @summary Tests that the card table does not commit the same page twice
|
* @summary Tests that the card table does not commit the same page twice
|
||||||
|
* @requires vm.gc=="Parallel" | vm.gc=="null"
|
||||||
* @library /testlibrary
|
* @library /testlibrary
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
* java.management
|
* java.management
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2013, 2016, 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
|
||||||
@ -25,6 +25,7 @@
|
|||||||
* @test TestCMSHeapSizeFlags
|
* @test TestCMSHeapSizeFlags
|
||||||
* @key gc
|
* @key gc
|
||||||
* @bug 8006088
|
* @bug 8006088
|
||||||
|
* @requires vm.gc=="ConcMarkSweep" | vm.gc=="null"
|
||||||
* @summary Tests argument processing for initial and maximum heap size for the CMS collector
|
* @summary Tests argument processing for initial and maximum heap size for the CMS collector
|
||||||
* @library /testlibrary /test/lib
|
* @library /testlibrary /test/lib
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, 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
|
||||||
@ -25,6 +25,7 @@
|
|||||||
* @test TestG1ConcRefinementThreads
|
* @test TestG1ConcRefinementThreads
|
||||||
* @key gc
|
* @key gc
|
||||||
* @bug 8047976
|
* @bug 8047976
|
||||||
|
* @requires vm.gc=="G1" | vm.gc=="null"
|
||||||
* @summary Tests argument processing for G1ConcRefinementThreads
|
* @summary Tests argument processing for G1ConcRefinementThreads
|
||||||
* @library /testlibrary
|
* @library /testlibrary
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2013, 2016, 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
|
||||||
@ -25,6 +25,7 @@
|
|||||||
* @test TestG1HeapSizeFlags
|
* @test TestG1HeapSizeFlags
|
||||||
* @key gc
|
* @key gc
|
||||||
* @bug 8006088
|
* @bug 8006088
|
||||||
|
* @requires vm.gc=="G1" | vm.gc=="null"
|
||||||
* @summary Tests argument processing for initial and maximum heap size for the G1 collector
|
* @summary Tests argument processing for initial and maximum heap size for the G1 collector
|
||||||
* @library /testlibrary /test/lib
|
* @library /testlibrary /test/lib
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2016, 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
|
||||||
@ -25,6 +25,7 @@
|
|||||||
* @test TestG1PercentageOptions
|
* @test TestG1PercentageOptions
|
||||||
* @key gc
|
* @key gc
|
||||||
* @bug 8068942
|
* @bug 8068942
|
||||||
|
* @requires vm.gc=="G1" | vm.gc=="null"
|
||||||
* @summary Test argument processing of various percentage options
|
* @summary Test argument processing of various percentage options
|
||||||
* @library /testlibrary
|
* @library /testlibrary
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2013, 2016, 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
|
||||||
@ -27,6 +27,7 @@
|
|||||||
* @bug 8006088
|
* @bug 8006088
|
||||||
* @summary Tests argument processing for initial and maximum heap size for the
|
* @summary Tests argument processing for initial and maximum heap size for the
|
||||||
* parallel collectors.
|
* parallel collectors.
|
||||||
|
* @requires vm.gc=="null"
|
||||||
* @library /testlibrary /test/lib
|
* @library /testlibrary /test/lib
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
* java.management
|
* java.management
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, 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
|
||||||
@ -27,6 +27,7 @@
|
|||||||
* @summary Checks that decommitment occurs for JVM with different
|
* @summary Checks that decommitment occurs for JVM with different
|
||||||
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
||||||
* @requires vm.gc=="G1" | vm.gc=="null"
|
* @requires vm.gc=="G1" | vm.gc=="null"
|
||||||
|
* @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null"
|
||||||
* @library /testlibrary /test/lib
|
* @library /testlibrary /test/lib
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
* java.management
|
* java.management
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, 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
|
||||||
@ -27,6 +27,7 @@
|
|||||||
* @summary Checks that decommitment occurs for JVM with different
|
* @summary Checks that decommitment occurs for JVM with different
|
||||||
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
||||||
* @requires vm.gc=="G1" | vm.gc=="null"
|
* @requires vm.gc=="G1" | vm.gc=="null"
|
||||||
|
* @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null"
|
||||||
* @library /testlibrary /test/lib
|
* @library /testlibrary /test/lib
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
* java.management
|
* java.management
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, 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
|
||||||
@ -27,6 +27,7 @@
|
|||||||
* @summary Checks that decommitment occurs for JVM with different
|
* @summary Checks that decommitment occurs for JVM with different
|
||||||
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
||||||
* @requires vm.gc=="G1" | vm.gc=="null"
|
* @requires vm.gc=="G1" | vm.gc=="null"
|
||||||
|
* @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null"
|
||||||
* @library /testlibrary /test/lib
|
* @library /testlibrary /test/lib
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
* java.management
|
* java.management
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, 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
|
||||||
@ -27,6 +27,7 @@
|
|||||||
* @summary Checks that decommitment occurs for JVM with different
|
* @summary Checks that decommitment occurs for JVM with different
|
||||||
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
||||||
* @requires vm.gc=="G1" | vm.gc=="null"
|
* @requires vm.gc=="G1" | vm.gc=="null"
|
||||||
|
* @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null"
|
||||||
* @library /testlibrary /test/lib
|
* @library /testlibrary /test/lib
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
* java.management
|
* java.management
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, 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
|
||||||
@ -27,6 +27,7 @@
|
|||||||
* @summary Checks that decommitment occurs for JVM with different
|
* @summary Checks that decommitment occurs for JVM with different
|
||||||
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
||||||
* @requires vm.gc=="G1" | vm.gc=="null"
|
* @requires vm.gc=="G1" | vm.gc=="null"
|
||||||
|
* @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null"
|
||||||
* @library /testlibrary /test/lib
|
* @library /testlibrary /test/lib
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
* java.management
|
* java.management
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, 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
|
||||||
@ -27,6 +27,7 @@
|
|||||||
* @summary Checks that decommitment occurs for JVM with different
|
* @summary Checks that decommitment occurs for JVM with different
|
||||||
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
||||||
* @requires vm.gc=="G1" | vm.gc=="null"
|
* @requires vm.gc=="G1" | vm.gc=="null"
|
||||||
|
* @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null"
|
||||||
* @library /testlibrary /test/lib
|
* @library /testlibrary /test/lib
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
* java.management
|
* java.management
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, 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
|
||||||
@ -27,6 +27,7 @@
|
|||||||
* @summary Checks that decommitment occurs for JVM with different
|
* @summary Checks that decommitment occurs for JVM with different
|
||||||
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
* G1ConcRSLogCacheSize and ObjectAlignmentInBytes options values
|
||||||
* @requires vm.gc=="G1" | vm.gc=="null"
|
* @requires vm.gc=="G1" | vm.gc=="null"
|
||||||
|
* @requires vm.opt.AggressiveOpts=="false" | vm.opt.AggressiveOpts=="null"
|
||||||
* @library /testlibrary /test/lib
|
* @library /testlibrary /test/lib
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
* java.management
|
* java.management
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, 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
|
||||||
@ -25,6 +25,7 @@
|
|||||||
* @test TestGCId
|
* @test TestGCId
|
||||||
* @bug 8043607
|
* @bug 8043607
|
||||||
* @summary Ensure that the GCId is logged
|
* @summary Ensure that the GCId is logged
|
||||||
|
* @requires vm.gc=="null"
|
||||||
* @key gc
|
* @key gc
|
||||||
* @library /testlibrary
|
* @library /testlibrary
|
||||||
* @modules java.base/sun.misc
|
* @modules java.base/sun.misc
|
||||||
|
@ -83,13 +83,6 @@ public class TestOptionsWithRanges {
|
|||||||
setAllowedExitCodes("SharedMiscDataSize", 2);
|
setAllowedExitCodes("SharedMiscDataSize", 2);
|
||||||
setAllowedExitCodes("SharedMiscCodeSize", 2);
|
setAllowedExitCodes("SharedMiscCodeSize", 2);
|
||||||
|
|
||||||
/*
|
|
||||||
* JDK-8145204
|
|
||||||
* Temporarily remove testing of max range for ParGCArrayScanChunk because
|
|
||||||
* JVM can hang when ParGCArrayScanChunk=4294967296 and ParallelGC is used
|
|
||||||
*/
|
|
||||||
excludeTestMaxRange("ParGCArrayScanChunk");
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Remove CICompilerCount from testing because currently it can hang system
|
* Remove CICompilerCount from testing because currently it can hang system
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user