RFR (XS) 8144853: Print the names of callees in PrintAssembly/PrintInterprete

David Holmes david.holmes at oracle.com
Tue Dec 15 05:14:42 UTC 2015


Sorry for the delay. This looks fine to me.

Thanks,
David

On 14/12/2015 9:48 AM, Ioi Lam wrote:
> Hi David,
>
> I have updated the patch according to your feedback:
>
> http://cr.openjdk.java.net/~iklam/jdk9/8144853-print-interpreter-callee-names.v3/
>
>
> The buf[] variable is now allocated using NEW_RESOURCE_ARRAY, and the
> useless 'found' variable has been removed. The comment is also fixed.
>
> Thanks
> - Ioi
>
> On 12/8/15 8:47 PM, David Holmes wrote:
>> Hi Ioi,
>>
>> src/share/vm/code/nmethod.cpp
>>
>> Your use of the static buffer seems not thread-safe.
>>
>> Minor nit:
>>
>> 3057             bool found;
>> 3058             found = os::dll_address_to_function_name(dest, buf,
>> sizeof(buf), &offset);
>>
>> could be:
>>
>> 3057             bool found = os::dll_address_to_function_name(dest,
>> buf, sizeof(buf), &offset);
>>
>>
>> ---
>>
>> src/share/vm/compiler/disassembler.cpp
>>
>> Your use of the static buffer seems not thread-safe.
>>
>> 366   bool found;
>>
>> This variable seems unused.
>>
>> Typo:
>>
>> 369     // Don't do this for native methods, as the function name will
>> be printed in
>> 370     // by nmethod::reloc_string_for().
>>
>> delete 'in' or 'by'.
>>
>> Thanks,
>> David
>> -----
>>
>>
>> On 8/12/2015 5:32 AM, Ioi Lam wrote:
>>> Hi Vladimir,
>>>
>>> Thanks for the suggestion. I've changed the patch to handle the nmethods
>>> differently than PrintInterpreter:
>>>
>>> http://cr.openjdk.java.net/~iklam/jdk9/8144853-print-interpreter-callee-names.v2/
>>>
>>>
>>>
>>> The nmethod dump now looks like this:
>>>
>>>    0x00007f607940c657: callq    0x00007f607186bb60  ;
>>> ImmutableOopMap{[0]=Oop }
>>>                                                  ;*ifeq {reexecute=1
>>> rethrow=0 return_oop=0}
>>>                                                  ; -
>>> java.lang.String::charAt at 4 (line 685)
>>>                                                  ; {runtime_call
>>> UncommonTrapBlob}
>>>    0x00007f607940c65c: callq    0x00007f608b05eb00  ;*ifeq {reexecute=0
>>> rethrow=0 return_oop=0}
>>>                                                  ; -
>>> java.lang.String::charAt at 4 (line 685)
>>>                                                  ; {runtime_call
>>> os::breakpoint()}
>>>
>>>
>>> Thanks
>>> - Ioi
>>>
>>>
>>> On 12/7/15 10:58 AM, Vladimir Ivanov wrote:
>>>> Ioi,
>>>>
>>>> Nice improvement!
>>>>
>>>> Why don't you print "{runtime_call os::breakpoint()}" for
>>>> -XX:+PrintAssemble instead? It looks more natural w.r.t. current
>>>> format.
>>>>
>>>> Best regards,
>>>> Vladimir Ivanov
>>>>
>>>> On 12/7/15 9:18 PM, Ioi Lam wrote:
>>>>> Please review a very small fix:
>>>>>
>>>>> http://cr.openjdk.java.net/~iklam/jdk9/8144853-print-interpreter-callee-names/
>>>>>
>>>>>
>>>>>
>>>>>
>>>>> Bug: Print the names of callees in PrintAssembly/PrintInterprete
>>>>>
>>>>>      https://bugs.openjdk.java.net/browse/JDK-8144853
>>>>>
>>>>> Summary of fix:
>>>>>
>>>>>      In -XX:+PrintAssembly and -XX:+PrintInterpreter, sometimes only
>>>>>      the address of a callee is printed, and the name is missing.
>>>>>
>>>>>      The fix is to use os::dll_address_to_function_name() to find the
>>>>>      names of such functions and print them out if possible.
>>>>>
>>>>>      EXAMPLES:
>>>>>      -XX:+PrintInterpreter:
>>>>>      0x00007f1b018447c3: callq 0x00007f1b19b9bba0 =
>>>>> InterpreterRuntime::newarray(JavaThread*, BasicType, int)
>>>>>
>>>>>      -XX:+PrintAssembly
>>>>>      <....>
>>>>>      0x00007f75d87b9629: xchg %ax,%ax
>>>>>      0x00007f75d87b962b: callq 0x00007f75d0c11b60 ;
>>>>> ImmutableOopMap{rbp=Oop }
>>>>>                                                    ;*iflt {reexecute=1
>>>>> rethrow=0 return_oop=0}
>>>>>                                                    ; -
>>>>> java.lang.StringLatin1::charAt at 1 (line 43)
>>>>>                                                    ; {runtime_call
>>>>> UncommonTrapBlob}
>>>>>      0x00007f75d87b9630: callq 0x00007f75e8e41370 = os::breakpoint()
>>>>>                                                    ;*iflt {reexecute=0
>>>>> rethrow=0 return_oop=0}
>>>>>                                                    ; -
>>>>> java.lang.StringLatin1::charAt at 1 (line 43)
>>>>>                                                    ; {runtime_call}
>>>>>
>>>>>
>>>>> TESTS:
>>>>>      RBT hotspot/test/:hotspot_all (this includes tests cases with
>>>>> -XX:+PrintAssembly)
>>>>>
>>>>> Thanks
>>>>> - Ioi
>>>
>


More information about the hotspot-dev mailing list