RFR (S): 8067469: G1 ignores AlwaysPreTouch
Thomas Schatzl
thomas.schatzl at oracle.com
Tue Dec 16 16:12:58 UTC 2014
Hi Erik,
thanks for the review.
On Tue, 2014-12-16 at 16:29 +0100, Erik Helin wrote:
> On 2014-12-16, Thomas Schatzl wrote:
> > Hi all,
> >
> > can I have reviews for the following small change?
> >
> > It adds pre-touching of allocated memory in G1, which has been forgotten
> > to be implemented when changing this code in JDK-8038423.
> >
> > This change adds this and refactors the pre-touch code to a single
> > method in the os class.
> >
> > CC'ed runtime since it changes code in os.hpp/cpp.
> >
> > CR:
> > https://bugs.openjdk.java.net/browse/JDK-8067469
> > Webrev:
> > http://cr.openjdk.java.net/~tschatzl/8067469/webrev/
>
> First of all, nice patch, I really like the introduction of
> os::pretouch_memory. I have one question about the patch: the code you
> removed in virtualspace.cpp did:
>
> *curr = 0;
>
> whereas the new code you added in os::pretouch_memory does:
>
> char t = *p; *p = t;
>
> Was this change intended or should os::pretouch_memory also write 0?
>
There is no code relying on particular values written. Pre-touch is done
as part of committing new memory. So in effect, the code reads a zero,
and writes it back.
It's just that there were two different pre-touching implementations and
I chose one of them to factor out into the new method.
Thanks,
Thomas
More information about the hotspot-gc-dev
mailing list