RFR (S): 8079208: gc/g1/TestLargePageUseForAuxMemory.java fails due to not considering page allocation granularity for setup
Thomas Schatzl
thomas.schatzl at oracle.com
Wed May 13 22:17:11 UTC 2015
Hi,
On Wed, 2015-05-13 at 14:50 -0700, Jon Masamitsu wrote:
>
> On 5/13/2015 8:03 AM, Thomas Schatzl wrote:
> > Hi all,
> >
> > can I have reviews for the following test fix: the problem is that
> > during test setup, when trying to find the heap size where large pages
> > are just not used, the code subtracts a fixed value from the one known
> > to use large pages for the card table.
> >
> > The problem is that this fixed value is too small to have an impact on
> > the actual size of the card table, i.e. the code rounds up by the OS'es
> > allocation granularity. That causes it to use the same size as before,
> > where it will then use large pages anyway and fail the test.
> >
> > That fixed value has been just large enough to cover regular page size.
> >
> > Also, the only OS that has different allocation granularities and
> > (small) page sizes is Windows. Further on Windows, large pages (and the
> > test is only executed then) are only available when the user runs as
> > Administrator (or has the corresponding capability to lock pages in
> > memory).
> Thomas,
>
> Is there a change for this need to run the test with sufficient privileges?
There is no way I know of to specify the requirement of this privilege
anywhere in jprt. Any idea?
In other test frameworks you could require large-page support for the
machine.
> > In this case the test fails.
> >
> > The change fixes this by making sure that this value to subtract from
> > the original heap size is exactly the size that avoids this rounding.
>
> The fix to the test looks good.
>
> Is it important to the test that the amount subtracted be the minimum
> needed to disable large pages? I mean, is the test less useful if
> twice that minimum was subtracted?
It will not test that the expected cross-over between using large pages
and small pages is at exactly at that particular heap size. This seems
to test more than when subtracting any random value.
However I can add this test case too.
> For
>
> > 119 final long heapSizeDiffForCardTable = Math.max(Math.max(allocGranularity * cardSize, HEAP_REGION_SIZE), largePageSize);
>
> would this description be correct?
>
> // Minimum change in heap size that will disable large pages for the
> card table if subtracted from
> // the heap size. Increasing the heap by this amount should not change
> the use of large pages
> // for the card table.
>
> If yes, would you mind adding it.
Will do, thanks.
Thomas
More information about the hotspot-gc-dev
mailing list