RFR(s): 8145000: TestOptionsWithRanges.java failure for XX:+UseNUMA -XX:+UseNUMAInterleaving -XX:NUMAInterleaveGranularity=65536
sangheon
sangheon.kim at oracle.com
Tue Dec 22 17:48:35 UTC 2015
Hi Jesper and Tom,
Thank you for reviewing this.
Sangheon
On 12/22/2015 07:33 AM, Tom Benson wrote:
> Looks OK to me as well.
> Tom
>
> On 12/22/2015 8:14 AM, Jesper Wilhelmsson wrote:
>> Den 22/12/15 kl. 02:36, skrev sangheon:
>>> Hi Jesper,
>>>
>>> On 12/21/2015 04:38 PM, Jesper Wilhelmsson wrote:
>>>> Hi Sangheon,
>>>>
>>>> Just a comment about the assert in protect_pages_individually(). To
>>>> me it
>>>> looks strange to have an assert and then on the next line handle
>>>> the case that
>>>> was just asserted that it can't happen. Either we assume it can
>>>> happen and
>>>> handle it, or we say that it can't happen and assert that it doesn't.
>>> I agree, assert is wrong.
>>> And looking at current usage of os::protect_memory(), caller is
>>> handling the
>>> situation.
>>> So I think 'warning' seems correct as the log is intended to show
>>> which chunk is
>>> making problem.
>>>
>>> - assert(ret, "Failed protecting chunk #%u", count);
>>> + warning("Failed protecting chunk #%u", count);
>>>
>>> What do you think?
>>
>> Yes, a warning seems appropriate.
>> Ship it!
>> /Jesper
>>
>>>
>>> Thanks,
>>> Sangheon
>>>
>>>
>>>>
>>>> It would be nice if you either remove the assert or add a comment that
>>>> explains why it is there. I do not need to re-review if you decide
>>>> to do either.
>>>>
>>>> Besides that, looks good!
>>>> /Jesper
>>>>
>>>> Den 21/12/15 kl. 22:43, skrev sangheon:
>>>>> Hi all,
>>>>>
>>>>> Tom and I did some discussion(previously I misunderstood Tom's
>>>>> comment) and
>>>>> here's the next webrev which includes:
>>>>>
>>>>> 1. Call protect_pages_individually() when UseNUMAInterleaving is
>>>>> enabled (Tom)
>>>>> 2. Added a comment why we need to call
>>>>> protect_pages_individually(). (Tom)
>>>>> 3. Changed VirtualQuery() handling code. (Tom)
>>>>>
>>>>> http://cr.openjdk.java.net/~sangheki/8145000/webrev.03
>>>>> http://cr.openjdk.java.net/~sangheki/8145000/webrev.03_to_02
>>>>>
>>>>> Thanks,
>>>>> Sangheon
>>>>>
>>>>>
>>>>> On 12/21/2015 11:19 AM, Tom Benson wrote:
>>>>>> Hi,
>>>>>>
>>>>>> On 12/21/2015 1:57 PM, Jesper Wilhelmsson wrote:
>>>>>>> Hi Sangheon,
>>>>>>>
>>>>>>> I was under the impression that Tom wanted to keep the
>>>>>>> UseNUMAInterleaving
>>>>>>> test and not always call protect_pages_individually().
>>>>>>
>>>>>> Yes, I'd said that was my vote, but wasn't adamant about it. If
>>>>>> we agree,
>>>>>> let's keep it. 8^)
>>>>>> Tom
>>>>>>
>>>>>>> At least that's what I would prefer. If you revert that change I
>>>>>>> think we
>>>>>>> have something here :)
>>>>>>> /Jesper
>>>>>>>
>>>>>>>
>>>>>>> Den 21/12/15 kl. 18:48, skrev sangheon:
>>>>>>>> Hi Jesper and Tom,
>>>>>>>>
>>>>>>>> Here's next webrev which includes below:
>>>>>>>> - Check return value of VirtualQuery. (Tom, Jesper)
>>>>>>>> - Always call protect_pages_individually() from
>>>>>>>> os::protect_memory(). (Tom)
>>>>>>>>
>>>>>>>> Webrev:
>>>>>>>> http://cr.openjdk.java.net/~sangheki/8145000/webrev.02
>>>>>>>> http://cr.openjdk.java.net/~sangheki/8145000/webrev.02_to_01/
>>>>>>>>
>>>>>>>> Test:
>>>>>>>> JPRT, RBT (hotspot/test/:hotspot_all,testlist,noncolo.testlist
>>>>>>>> --add-tonga-keyword quick for Windows only)
>>>>>>>>
>>>>>>>> Thanks,
>>>>>>>> Sangheon
>>>>>>>>
>>>>>>>>
>>>>>>>> On 12/21/2015 03:40 AM, Jesper Wilhelmsson wrote:
>>>>>>>>> Hi Sangheon,
>>>>>>>>>
>>>>>>>>> I like this version a lot better.
>>>>>>>>> I have no further comments except for what Tom already
>>>>>>>>> mentioned about
>>>>>>>>> checking VirtualQuery return value.
>>>>>>>>> /Jesper
>>>>>>>>>
>>>>>>>>>
>>>>>>>>> Den 19/12/15 kl. 00:39, skrev Tom Benson:
>>>>>>>>>> Hi Sangheon,
>>>>>>>>>>
>>>>>>>>>> On 12/18/2015 6:02 PM, sangheon wrote:
>>>>>>>>>>> Hi Tom,
>>>>>>>>>>>
>>>>>>>>>>> On 12/17/2015 04:23 PM, sangheon wrote:
>>>>>>>>>>>> Hi Tom,
>>>>>>>>>>>>
>>>>>>>>>>>> Thank you for reviewing this!
>>>>>>>>>>>>
>>>>>>>>>>>> On 12/17/2015 01:28 PM, Tom Benson wrote:
>>>>>>>>>>>>> Hi Sangheon,
>>>>>>>>>>>>> I like the new approach, but just have a couple of comments.
>>>>>>>>>>>> Thanks.
>>>>>>>>>>>>
>>>>>>>>>>>>>
>>>>>>>>>>>>> I think you should check the VirtualQuery return status
>>>>>>>>>>>>> and return false
>>>>>>>>>>>>> from protect_pages_individually if zero.
>>>>>>>>>>>> Right.
>>>>>>>>>>>> I will fix this.
>>>>>>>>>>>>
>>>>>>>>>>>>>
>>>>>>>>>>>>> I don't *think* you need to have the "!UseLargePages"
>>>>>>>>>>>>> restriction
>>>>>>>>>>>>> anymore
>>>>>>>>>>>>> with this approach, do you?
>>>>>>>>>>>> protect_pages_individually() doesn't have previous
>>>>>>>>>>>> restriction on its
>>>>>>>>>>>> usage.
>>>>>>>>>>>> However I wanted to remain the caller(os::protect_memory)
>>>>>>>>>>>> as is
>>>>>>>>>>>> because, as
>>>>>>>>>>>> you already mentioned below, I didn't want to have an
>>>>>>>>>>>> additional call of
>>>>>>>>>>>> VirtualQuery() for simpler code.
>>>>>>>>>>>> I don't have strong opinion on this.
>>>>>>>>>>>>
>>>>>>>>>>>> Let me post next webrev after concluding this.
>>>>>>>>>>> Tom, do you prefer to always use protect_pages_individually()?
>>>>>>>>>>> Does anyone have opinion on this?
>>>>>>>>>>>
>>>>>>>>>>
>>>>>>>>>> I'd vote for leaving the UseNUMAInterleaving test in.
>>>>>>>>>> Tom
>>>>>>>>>>
>>>>>>>>>>> Thanks,
>>>>>>>>>>> Sangheon
>>>>>>>>>>>
>>>>>>>>>>>
>>>>>>>>>>>>
>>>>>>>>>>>> Thanks,
>>>>>>>>>>>> Sangheon
>>>>>>>>>>>>
>>>>>>>>>>>>
>>>>>>>>>>>>>
>>>>>>>>>>>>> Actually, I think you could just always use
>>>>>>>>>>>>> protect_pages_individually
>>>>>>>>>>>>> regardless of whether UseNUMAInterleaving was enabled or
>>>>>>>>>>>>> not, and the
>>>>>>>>>>>>> right
>>>>>>>>>>>>> thing would happen. But this way, you save an unnecessary
>>>>>>>>>>>>> system call
>>>>>>>>>>>>> plus
>>>>>>>>>>>>> some overhead.
>>>>>>>>>>>>> Tom
>>>>>>>>>>>>>
>>>>>>>>>>>>>
>>>>>>>>>>
>>>>>>>>
>>>>>>
>>>>>
>>>
>
More information about the hotspot-gc-dev
mailing list