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

Ioi Lam ioi.lam at oracle.com
Mon Dec 7 19:32:39 UTC 2015


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