RFR(xs): 8145192: 'count' variable can overflow in PSMarkSweep::invoke on 64 bit JVM
sangheon
sangheon.kim at oracle.com
Sat Jan 23 00:02:18 UTC 2016
Hi Tom,
Thank you for reviewing this.
On 01/22/2016 12:52 PM, Tom Benson wrote:
> Hi,
> I think it would be *slightly* more logical to instead reduce
> MarkSweepAlwaysCompactCount to a uint, since there should be no need
> for it to be anywhere near even that large.
Okay, I will fix.
I considered change the flag to 'uint' as well but I selected this
approach as this is simpler. :)
> But I don't feel too strongly, and that would require changing the test.
I ran TestGCOld.java to trigger enough GCs and it was fine.
Let me post a new webrev after testing JPRT on Monday.
* I have one thing to note: JDK-8144578 is on review and its patch
contains to exclude testing this flag from TestOptionsWithRanges.java.
So if 8144578 is pushed earlier than this, I should revise this patch.
Thanks,
Sangheon
>
> So, the change looks OK to me.
> Tom
>
> On 1/22/2016 2:56 PM, sangheon wrote:
>> Hi all,
>>
>> Could I have reviews for this tiny change to avoid zero division?
>>
>> 'uintx' type flag 'MarkSweepAlwaysCompactCount' is used to set 'uint'
>> type local variable and this would result in an overflow for big
>> numbers(>max_juint).
>> As a solution, this local variable should be changed to 'uintx'.
>>
>> I didn't add a new test as JDK-8144578 enables to check this problem.
>>
>> CR: https://bugs.openjdk.java.net/browse/JDK-8145192
>> Webrev: http://cr.openjdk.java.net/~sangheki/8145192/webrev.00
>> Testing: JPRT, manual test[1]
>>
>> [1]: Call System.gc() with VM option of '-XX:+UseParallelGC
>> -XX:-UseParallelOldGC -XX:MarkSweepAlwaysCompactCount=4294967296'
>> (=max_juint + 1).
>>
>> Thanks,
>> Sangheon
>
More information about the hotspot-gc-dev
mailing list