Withdrawn: CODETOOLS-7902854: jcstress: Print generated code assembly (optionally)

Aleksey Shipilev shade at openjdk.java.net
Thu Mar 18 17:34:46 UTC 2021


On Thu, 18 Mar 2021 15:39:37 GMT, Aleksey Shipilev <shade at openjdk.org> wrote:

> Following up on test failures is hard without the generated code. Doing -XX:+PrintAssembly would print the generated code for everything, which would be unnecessarily noisy. Luckily, we can now instruct jcstress to dump the generated code for the hot loops only.
> 
> Sample output:
> 
> $ java -jar tests-custom/target/jcstress.jar -t UnfencedDekker -vv --jvmArgs "-XX:-TieredCompilation"
> Java Concurrency Stress Tests
> ---------------------------------------------------------------------------------
> Rev: 728c24c414d9b9c2, built by shade with 11.0.12-testing at 2021-03-18T15:36:51Z
> 
> Burning up to figure out the exact CPU count....... done!
> 
> Probing the target OS:
>  (all failures are non-fatal, but may affect testing accuracy)
> 
> ----- [OK] Trying to set affinity with taskset
> 
> Initializing and probing the target VM: 
>  (all failures are non-fatal, but may affect testing accuracy)
> 
> ----- [OK] Unlocking diagnostic VM options
> ----- [OK] Trimming down the default VM heap size to 1/64-th of max RAM
> ----- [OK] Trimming down the number of compiler threads
> ----- [OK] Trimming down the number of parallel GC threads
> ----- [OK] Trimming down the number of concurrent GC threads
> ----- [OK] Trimming down the number of G1 concurrent refinement GC threads
> ----- [OK] Testing @Contended works on all results and infra objects
> ----- [OK] Unlocking Whitebox API for online de-optimization: all methods
> ----- [OK] Unlocking Whitebox API for online de-optimization: selected methods
> ----- [OK] Unlocking C2 local code motion randomizer
> ----- [OK] Unlocking C2 global code motion randomizer
> ----- [OK] Unlocking C2 iterative global value numbering randomizer
> ----- [OK] Unlocking C2 conditional constant propagation randomizer
> ----- [OK] Testing allocation profiling
> ----- [OK] Testing Thread.onSpinWait
> ----- [OK] Testing PrintAssembly
> ----- [OK] Testing compiler directives
> 
> Probing what VM modes are available:
>  (failures are non-fatal, but may miss some interesting cases)
> 
> ----- [OK] [-XX:-TieredCompilation]
> 
>   Hardware CPUs in use: 64, using Thread.onSpinWait()
>   Test preset mode: "default"
>   Writing the test results to "jcstress-results-2021-03-18-16-37-38.bin.gz"
>   Parsing results to "results/"
>   Running each test matching "UnfencedDekker" for 1 forks, 5 iterations, 1000 ms each
>   Solo stride size will be autobalanced within [10, 10000] elements, but taking no more than 100 Mb.
> 
>   Attached the non-interactive output stream.
>   Printing the progress line at least every 15000 milliseconds.
> 
> 
>       [OK] o.o.j.t.fences.UnfencedDekkerTest
>     (fork: #1, JVM args: [-XX:-TieredCompilation])
>   Observed state   Occurrences              Expectation  Interpretation                                              
>             0, 0     8,376,544   ACCEPTABLE_INTERESTING  Acceptable with no sequential consistency enforced          
>             0, 1   476,317,773               ACCEPTABLE  Acceptable under sequential consistency                     
>             1, 0   218,828,395               ACCEPTABLE  Acceptable under sequential consistency                     
>             1, 1           799               ACCEPTABLE  Acceptable under sequential consistency                     
> 
>     VM output stream: 
>         
>         ============================= C2-compiled nmethod ==============================
>         ----------------------------------- Assembly -----------------------------------
>         
>         Compiled method (c2)     222  128 %           org.openjdk.jcstress.tests.fences.UnfencedDekkerTest_jcstress::run_actor1 @ 12 (55 bytes)
>          total in heap  [0x00007f783863b110,0x00007f783863b7a8] = 1688
>          relocation     [0x00007f783863b270,0x00007f783863b2a0] = 48
>          main code      [0x00007f783863b2a0,0x00007f783863b5e0] = 832
>          stub code      [0x00007f783863b5e0,0x00007f783863b5f8] = 24
>          oops           [0x00007f783863b5f8,0x00007f783863b600] = 8
>          metadata       [0x00007f783863b600,0x00007f783863b630] = 48
>          scopes data    [0x00007f783863b630,0x00007f783863b6f8] = 200
>          scopes pcs     [0x00007f783863b6f8,0x00007f783863b788] = 144
>          dependencies   [0x00007f783863b788,0x00007f783863b790] = 8
>          nul chk table  [0x00007f783863b790,0x00007f783863b7a8] = 24
>         
>         --------------------------------------------------------------------------------
>         [Constant Pool (empty)]
>         
>         --------------------------------------------------------------------------------
>         
>         [Verified Entry Point]
>           # {method} {0x00007f7825812658} 'run_actor1' '([Lorg/openjdk/jcstress/tests/fences/UnfencedDekkerTest;[Lorg/openjdk/jcstress/infra/results/II_Result;)V' in 'org/openjdk/jcstress/tests/fences/UnfencedDekkerTest_jcstress'
>           0x00007f783863b2a0:   callq  0x00007f784a5a1120           ;   {runtime_call os::breakpoint()}
>           0x00007f783863b2a5:   data16 data16 nopw 0x0(%rax,%rax,1)
>           0x00007f783863b2b0:   mov    %eax,-0x14000(%rsp)
>           0x00007f783863b2b7:   push   %rbp
>           0x00007f783863b2b8:   sub    $0x40,%rsp
>           0x00007f783863b2bc:   mov    0x40(%rsi),%r10
>           0x00007f783863b2c0:   mov    %r10,(%rsp)
>           0x00007f783863b2c4:   mov    0x28(%rsi),%rbp
>   ...

This pull request has been closed without being integrated.

-------------

PR: https://git.openjdk.java.net/jcstress/pull/14


More information about the jcstress-dev mailing list