RFR 8030115: [parfait] warnings from b119 for jdk.src.share.native.sun.tracing.dtrace: JNI exception pending
Jaroslav Bachorik
jaroslav.bachorik at oracle.com
Mon Jul 28 13:20:02 UTC 2014
On 07/26/2014 01:16 AM, Dmitry Samersoff wrote:
> Serguei,
>
> Previous fix get offset to pointer passed as parameter without bounds
> check. It's safe here, but not the best solution in general and cause a
> warning.
>
> Also readProviderData checks for exceptions, so I see no reason to check
> it again.
>
> *In this version:*
>
> we don't need to count errors and can abort after first one.
The loop is aborted as soon as noErrors is set to 0.
>
> CHECK_(0)L at 204 cause the function to return, but left allocated memory.
Obviously, can't use the macro here. I've changed the code to work
directly with "(*env)->ExceptionOccurred(env)" here.
http://cr.openjdk.java.net/~jbachorik/8030115/webrev.02
-JB-
>
> -Dmitry
>
> On 2014-07-26 01:34, serguei.spitsyn at oracle.com wrote:
>> Previous fix was more elegant.
>> In fact, I do not like new one.
>>
>> Thanks,
>> Serguei
>>
>> On 7/25/14 6:04 AM, Jaroslav Bachorik wrote:
>>> On 07/25/2014 01:40 PM, Dmitry Samersoff wrote:
>>>> Jaroslav,
>>>>
>>>> readProviderData already use CHECK
>>>>
>>>> So it might be better to:
>>>>
>>>> 1. change readProviderData to return 0 on error and 1 on success.
>>>>
>>>> 2. add check for exception to ll 201 and abort the loop if at least
>>>> one of providers is not read.
>>>
>>> Ok, here is another attempt, now without introducing a new function.
>>>
>>> http://cr.openjdk.java.net/~jbachorik/8030115/webrev.01
>>>
>>> -JB-
>>>
>>>>
>>>>
>>>> -Dmitry
>>>>
>>>>
>>>> On 2014-07-24 15:07, Jaroslav Bachorik wrote:
>>>>> Please, review the change for the fix of the following problem
>>>>>
>>>>> In jdk/src/share/native/sun/tracing/dtrace/JVM.c the following code is
>>>>> invoked in loop
>>>>>
>>>>> 198 for (i = 0; i < num_providers; ++i) {
>>>>> 199 JVM_DTraceProvider* p = &(jvm_providers[i]);
>>>>> 200 jobject provider = (*env)->GetObjectArrayElement(
>>>>> 201 env, providers, i);
>>>>> 202 readProviderData(env, provider, p);
>>>>> 203 }
>>>>>
>>>>> The first problem is that GetGetObjectArrayElement() call on L200 may
>>>>> throw an exception which is not checked subsequently. On L202 the call
>>>>> to readProviderData() can also raise a Java exception without
>>>>> appropriate after-check. When getting back to the beginning of the loop
>>>>> GetObjectArrayElement() may be called with a pending exception which is
>>>>> deemed unsafe.
>>>>>
>>>>> The fix extracts the inner part of the loop into a separate function
>>>>> where the result of each step is properly checked for pending
>>>>> exceptions. If there is a pending exception the loop will be
>>>>> interrupted, resources cleaned and
>>>>> Java_sun_tracing_dtrace_JVM_activate0() function will return 0 with the
>>>>> pending exception recorded in env.
>>>>>
>>>>>
>>>>> Webrev: http://cr.openjdk.java.net/~jbachorik/8030115/webrev.00
>>>>>
>>>>> Thanks,
>>>>>
>>>>> -JB-
>>>>
>>>>
>>>
>>
>
>
More information about the serviceability-dev
mailing list