[OpenJDK 2D-Dev] [9] JDK-8176287 :[macosx] The print test crashed with Nimbus L&F
Philip Race
philip.race at oracle.com
Tue Mar 14 05:17:45 UTC 2017
On 3/13/17, 10:14 PM, Prasanta Sadhukhan wrote:
>
>
>
> On 3/14/2017 10:24 AM, Philip Race wrote:
>> The problem seems to have been that you were allocating zero bytes in
>> the old code :
>> 950 CGFloat* colors= (CGFloat*)calloc(0, sizeof(CGFloat)*length);
>>
>> 960 qsdo->gradientInfo->colordata = (CGFloat*)calloc(0, sizeof(CGFloat)*4*length);
>>
>> Regarding the new code, whilst it seems like it fixes the problem I have a nit
>> 937 int i;
>> 938 for (i=0; i<length; i++)
>>
>> Since this code appears at the start of a block I'd expect all
>> compilers to be happy with
>> for (int i=0; i<length; i++)
>>
>> is this not so ? Assuming yes, pls fix before push.
> Yes, it should be ok. I got a problem with jdk8u JPRT build (during
> earlier backport) citing C99 compiler failure but I guess that was
> because variable was declared not at blockstart.
> Will again do a JPRT and if its ok, I will push with this change.
Testing the 8u backport via JPRT is good since that will use VS2010 which
wins the "most likely to barf" award on such an issue.
-phil
>>
>> Also I wonder if the regression test we created for LGP passes only
>> because it is "short".
>> Perhaps later we can improve on that.
>>
>> The fix will also need to be backported since the original fix was
>> backported.
>>
> ok.
>> So "+1" with those comments ..
>>
> Thanks
>
> Regards
> Prasanta
>> -phil.
>>
>> On 3/12/17, 11:49 PM, Prasanta Sadhukhan wrote:
>>> Hi All,
>>>
>>> Please review a jck print test crash fix for jdk9. The issue was
>>> seen with only Nimbus L&F which seems to use Linear gradient path
>>> and not in other L&F (such as Aqua) .
>>>
>>> Bug: https://bugs.openjdk.java.net/browse/JDK-8176287
>>> webrev: http://cr.openjdk.java.net/~psadhukhan/8176287/webrev.00/
>>>
>>> Linear Gradient path collects the gradient colors and fractions
>>> values in native obtained from Java and allocates several arrays to
>>> store the same in setupGradient() method.
>>> It seems even after being freed, in subsequent call to the same
>>> gradient path routine, it may get the same allocated pointer the
>>> next time the array is allocated causing it to crash citing "memory
>>> being modified after freed".
>>>
>>> Optimise setupGradient() method to allocate fewer pointer. The JCK
>>> test works now.
>>> Also, the JDK-8162796 testcase LinearGradientPrintingTest and
>>> RadialGradientPrintingTest works with this optimisation.
>>>
>>> Regards
>>> Prasanta
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.openjdk.java.net/pipermail/2d-dev/attachments/20170313/6c8745d4/attachment.html>
More information about the 2d-dev
mailing list