Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
8242078: G1: Improve concurrent refinement analytics and logging
Unify data collection and reporting. Reviewed-by: tschatzl, sjohanss
- Loading branch information
Kim Barrett
committed
Apr 14, 2020
1 parent
b98e863
commit 4694da3
Showing
25 changed files
with
408 additions
and
219 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
/* | ||
* Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. | ||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. | ||
* | ||
* This code is free software; you can redistribute it and/or modify it | ||
* under the terms of the GNU General Public License version 2 only, as | ||
* published by the Free Software Foundation. | ||
* | ||
* This code is distributed in the hope that it will be useful, but WITHOUT | ||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | ||
* version 2 for more details (a copy is included in the LICENSE file that | ||
* accompanied this code). | ||
* | ||
* You should have received a copy of the GNU General Public License version | ||
* 2 along with this work; if not, write to the Free Software Foundation, | ||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | ||
* | ||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA | ||
* or visit www.oracle.com if you need additional information or have any | ||
* questions. | ||
* | ||
*/ | ||
|
||
#include "precompiled.hpp" | ||
#include "gc/g1/g1ConcurrentRefineStats.hpp" | ||
|
||
G1ConcurrentRefineStats::G1ConcurrentRefineStats() : | ||
_refinement_time(), | ||
_refined_cards(0), | ||
_precleaned_cards(0), | ||
_dirtied_cards(0) | ||
{} | ||
|
||
G1ConcurrentRefineStats& | ||
G1ConcurrentRefineStats::operator+=(const G1ConcurrentRefineStats& other) { | ||
_refinement_time += other._refinement_time; | ||
_refined_cards += other._refined_cards; | ||
_precleaned_cards += other._precleaned_cards; | ||
_dirtied_cards += other._dirtied_cards; | ||
return *this; | ||
} | ||
|
||
template<typename T> | ||
static T clipped_sub(T x, T y) { | ||
return (x < y) ? T() : (x - y); | ||
} | ||
|
||
G1ConcurrentRefineStats& | ||
G1ConcurrentRefineStats::operator-=(const G1ConcurrentRefineStats& other) { | ||
_refinement_time = clipped_sub(_refinement_time, other._refinement_time); | ||
_refined_cards = clipped_sub(_refined_cards, other._refined_cards); | ||
_precleaned_cards = clipped_sub(_precleaned_cards, other._precleaned_cards); | ||
_dirtied_cards = clipped_sub(_dirtied_cards, other._dirtied_cards); | ||
return *this; | ||
} | ||
|
||
void G1ConcurrentRefineStats::reset() { | ||
*this = G1ConcurrentRefineStats(); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
/* | ||
* Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. | ||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. | ||
* | ||
* This code is free software; you can redistribute it and/or modify it | ||
* under the terms of the GNU General Public License version 2 only, as | ||
* published by the Free Software Foundation. | ||
* | ||
* This code is distributed in the hope that it will be useful, but WITHOUT | ||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | ||
* version 2 for more details (a copy is included in the LICENSE file that | ||
* accompanied this code). | ||
* | ||
* You should have received a copy of the GNU General Public License version | ||
* 2 along with this work; if not, write to the Free Software Foundation, | ||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | ||
* | ||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA | ||
* or visit www.oracle.com if you need additional information or have any | ||
* questions. | ||
* | ||
*/ | ||
|
||
#ifndef SHARE_GC_G1_G1CONCURRENTREFINESTATS_HPP | ||
#define SHARE_GC_G1_G1CONCURRENTREFINESTATS_HPP | ||
|
||
#include "memory/allocation.hpp" | ||
#include "utilities/globalDefinitions.hpp" | ||
#include "utilities/ticks.hpp" | ||
|
||
// Collection of statistics for concurrent refinement processing. | ||
// Used for collecting per-thread statistics and for summaries over a | ||
// collection of threads. | ||
class G1ConcurrentRefineStats : public CHeapObj<mtGC> { | ||
Tickspan _refinement_time; | ||
size_t _refined_cards; | ||
size_t _precleaned_cards; | ||
size_t _dirtied_cards; | ||
|
||
public: | ||
G1ConcurrentRefineStats(); | ||
|
||
// Time spent performing concurrent refinement. | ||
Tickspan refinement_time() const { return _refinement_time; } | ||
|
||
// Number of refined cards. | ||
size_t refined_cards() const { return _refined_cards; } | ||
|
||
// Number of cards for which refinement was skipped because some other | ||
// thread had already refined them. | ||
size_t precleaned_cards() const { return _precleaned_cards; } | ||
|
||
// Number of cards marked dirty and in need of refinement. | ||
size_t dirtied_cards() const { return _dirtied_cards; } | ||
|
||
void inc_refinement_time(Tickspan t) { _refinement_time += t; } | ||
void inc_refined_cards(size_t cards) { _refined_cards += cards; } | ||
void inc_precleaned_cards(size_t cards) { _precleaned_cards += cards; } | ||
void inc_dirtied_cards(size_t cards) { _dirtied_cards += cards; } | ||
|
||
G1ConcurrentRefineStats& operator+=(const G1ConcurrentRefineStats& other); | ||
G1ConcurrentRefineStats& operator-=(const G1ConcurrentRefineStats& other); | ||
|
||
friend G1ConcurrentRefineStats operator+(G1ConcurrentRefineStats x, | ||
const G1ConcurrentRefineStats& y) { | ||
return x += y; | ||
} | ||
|
||
friend G1ConcurrentRefineStats operator-(G1ConcurrentRefineStats x, | ||
const G1ConcurrentRefineStats& y) { | ||
return x -= y; | ||
} | ||
|
||
void reset(); | ||
}; | ||
|
||
#endif // SHARE_GC_G1_G1CONCURRENTREFINESTATS_HPP |
Oops, something went wrong.