RFR(s): 8152182: Possible overflow in initialzation of _rescan_task_size and _marking_task_size

sangheon sangheon.kim at oracle.com
Thu Apr 7 22:08:23 UTC 2016


Thanks Jon and Jesper for the review.

Sangheon


On 04/07/2016 02:48 PM, Jesper Wilhelmsson wrote:
> Latest changes looks good to me as well.
> /Jesper
>
> Den 7/4/16 kl. 23:31, skrev Jon Masamitsu:
>>
>>
>> On 04/07/2016 11:22 AM, sangheon wrote:
>>> Hi Jon,
>>>
>>> On 04/07/2016 10:36 AM, Jon Masamitsu wrote:
>>>> Sangheon,
>>>>
>>>> Thanks for the changes. They look good.  A couple
>>>> of minor suggestions below.
>>>>
>>>> Jon
>>>>
>>>> On 04/06/2016 09:29 PM, sangheon wrote:
>>>>> Hi Jon,
>>>>>
>>>>> Thank you for the review.
>>>>>
>>>>> On 04/05/2016 05:02 PM, Jon Masamitsu wrote:
>>>>>> Sangheon,
>>>>>>
>>>>>> It occurs to me that if you created a function in CMS code
>>>>>> check_rescan_task_size_alignment()
>>>>>> to do the check
>>>>>>
>>>>>>> 506 const size_t rescan_task_size = 
>>>>>>> cms->cmsSpace()->rescan_task_size();
>>>>>>> 507 const size_t alignment = CardTableModRefBS::card_size * 
>>>>>>> BitsPerWord;
>>>>>>> 508
>>>>>>> 509 if ((size_t)round_to((intptr_t)rescan_task_size, alignment) !=
>>>>>>> rescan_task_size) {
>>>>>>
>>>>>> then you won't have to expose the particular alignment 
>>>>>> requirements in the
>>>>>> constraint function.  The code could look more like const int
>>>>>> HeapWordSize        = sizeof(HeapWord);
>>>>>>
>>>>>>
>>>>>> if ( check_rescan_task_size_alignment() ) {
>>>>>>
>>>>>> 513 CommandLineError::print(verbose,
>>>>>> 514 "Rescan task size (" SIZE_FORMAT " = CMSRescanMultiple * "
>>>>>> 515 "CardTableModRefBS::card_size_in_words * BitsPerWord) must be "
>>>>>> 516 "aligned to CardTableModRefBS::card_size * BitsPerWord (" 
>>>>>> SIZE_FORMAT
>>>>>> "). "
>>>>>> 517 "Round-down value for CMSRescanMultiple is " SIZE_FORMAT "\n",
>>>>>> 518 rescan_task_size, alignment, round_down_value);
>>>>>> 519 status = Flag::VIOLATES_CONSTRAINT;
>>>>>>
>>>>>> }
>>>>>>
>>>>>>
>>>>>> You might be able to do something similar in the other constraint 
>>>>>> function.
>>>>> Your suggestion especially not exposing the alignment inspired me 
>>>>> to make it
>>>>> simpler. :)
>>>>> Task size is 'flag *CardTableModRefBS::card_size_in_words * 
>>>>> BitsPerWord' and
>>>>> we have to check the alignment with CardTableModRefBS::card_size *
>>>>> BitsPerWord. As CardTableModRefBS::card_size_in_words =
>>>>> CardTableModRefBS::card_size / sizeof(HeapWord), if these flags are a
>>>>> multiple of sizeof(HeapWord), the task size will be aligned.
>>>>>
>>>>>>
>>>>>> Also for
>>>>>>
>>>>>> 472 if (value > addr_ergo_max) {
>>>>>> 473 CommandLineError::print(verbose,
>>>>>> 474 "%s (" SIZE_FORMAT ") must be "
>>>>>> 475 "less than or equal to ergonomic maximum (" SIZE_FORMAT ") "
>>>>>> 476 "based on start address corresponds to the old generation of 
>>>>>> the Java
>>>>>> heap\n",
>>>>>> 477 name, value, addr_ergo_max);
>>>>>> 478 return Flag::VIOLATES_CONSTRAINT;
>>>>>> 479 }
>>>>>>
>>>>>> Printing the addr_ergo_max might be confusing to the users since 
>>>>>> it will
>>>>>> be a very large
>>>>>> number.  Not sure what  to do unless you can print a maximum 
>>>>>> value of the
>>>>>> flag based
>>>>>> on the maximum heap size (instead of based on MAX_SIZE).
>>>>> I agree that using max heap will be better, so I fixed.
>>>>> Considering your comment above (not exposing alignment information 
>>>>> as it is
>>>>> not nice), I had to add a new method to get ergonomic maximum 
>>>>> values for
>>>>> these task sizes. We can check their constraint without this 
>>>>> function, but
>>>>> can't print out ergo max. Or have to use
>>>>> CardTableModRefBS::card_size_in_words * BitsPerWord on its 
>>>>> calculation.
>>>>>
>>>>> Webrev:
>>>>> http://cr.openjdk.java.net/~sangheki/8152182/webrev.02
>>>>> http://cr.openjdk.java.net/~sangheki/8152182/webrev.02_to_01
>>>> http://cr.openjdk.java.net/~sangheki/8152182/webrev.02_to_01/src/share/vm/runtime/commandLineFlagConstraintsGC.cpp.frames.html 
>>>>
>>>>
>>>> 469 "based on reserved area corresponds to the old generation of 
>>>> the Java
>>>> heap\n",
>>>> "reserved area" is correct but perhaps not understandable for the 
>>>> average
>>>> users. Maybe something like "which is based on the maximum size of 
>>>> the old
>>>> generation of the Java heap\n"
>>> Fixed.
>>>
>>>>
>>>> 492 value, sizeof(HeapWord)); From 
>>>> share/vm/utilities/globalDefinitions.hpp
>>>> you could use HeapWorkSize const int HeapWordSize = sizeof(HeapWord);
>>> I just repeated to use where it was calculated but I like is better.
>>>
>>> Updated webrev:
>>> http://cr.openjdk.java.net/~sangheki/8152182/webrev.03
>>> http://cr.openjdk.java.net/~sangheki/8152182/webrev.03_to_02
>>
>> Looks good.  Thanks. for the changes.
>>
>> Jon
>>>
>>> Thanks,
>>> Sangheon
>>>
>>>
>>>> Jon
>>>>>
>>>>> Testing: JPRT, runtime/commandline JTREG on all platforms.
>>>>>
>>>>> Thanks,
>>>>> Sangheon
>>>>>
>>>>>
>>>>>>
>>>>>> Ask if that's not clear.
>>>>>>
>>>>>> Jon
>>>>>>
>>>>>>
>>>>>>
>>>>>> On 4/5/2016 10:24 AM, sangheon wrote:
>>>>>>> Hi all,
>>>>>>>
>>>>>>> Please review this change for CMSRescanMultiple and 
>>>>>>> CMSConcMarkMultiple
>>>>>>> flags.
>>>>>>>
>>>>>>> Both flags are set by "CardTableModRefBS::card_size_in_words * 
>>>>>>> BitsPerWord
>>>>>>> * flag" which potentially would make an overflow with their 
>>>>>>> maximum value
>>>>>>> without setting range. And these flags also would make an 
>>>>>>> arithmetic
>>>>>>> overflow when calculating with the size and the start address of 
>>>>>>> reserved
>>>>>>> area. In addition, CMSRescanMultiple needs an alignment check.
>>>>>>>
>>>>>>> CR: https://bugs.openjdk.java.net/browse/JDK-8152182
>>>>>>> Webrev: http://cr.openjdk.java.net/~sangheki/8152182/webrev.00
>>>>>>> Testing: JPRT, runtime/commandline JTREG for all platforms
>>>>>>>
>>>>>>> Thanks,
>>>>>>> Sangheon
>>>>>>
>>>>>
>>>>
>>>
>>




More information about the hotspot-gc-dev mailing list