RFR (XS): JDK-8076614: Add comment to ClearNoncleanCardWrapper::do_MemRegion()

Bengt Rutisson bengt.rutisson at oracle.com
Thu Apr 2 20:53:17 UTC 2015


Hi all,

Can I have a couple of reviews to add this comment to cardTableRS.cpp?

https://bugs.openjdk.java.net/browse/JDK-8076614

This was discussed during the review of "JDK-8076241: Remove unused 
methods mod_card_iterate()    and non_clean_card_iterate_serial()", see:

http://mail.openjdk.java.net/pipermail/hotspot-gc-dev/2015-April/012661.html

For JDK-8076241 I removed this comment because it didn't make sense 
anymore at the place where it used to be. We now agree that a better 
place for
  it is close to the ClearNoncleanCardWrapper::do_MemRegion() method 
because that still does backwards iteration of the card table.

Since I am only adding a comment I think a diff is easier to review than 
a webrev:

diff --git a/src/share/vm/memory/cardTableRS.cpp 
b/src/share/vm/memory/cardTableRS.cpp
--- a/src/share/vm/memory/cardTableRS.cpp
+++ b/src/share/vm/memory/cardTableRS.cpp
@@ -176,7 +176,10 @@
bool ClearNoncleanCardWrapper::is_word_aligned(jbyte* entry) {
  return (((intptr_t)entry) & (BytesPerWord-1)) == 0;
}
-
+// The regions are visited in *decreasing* address order.
+// This order aids with imprecise card marking, where a dirty
+// card may cause scanning, and summarization marking, of objects
+// that extend onto subsequent cards.
void ClearNoncleanCardWrapper::do_MemRegion(MemRegion mr) {
  assert(mr.word_size() > 0, "Error");
  assert(_ct->is_aligned(mr.start()), "mr.start() should be card aligned”);


Thanks,
Bengt



More information about the hotspot-gc-dev mailing list