A question on endGroupNode

Gustavo Romero gromero at linux.vnet.ibm.com
Thu Feb 2 18:20:06 UTC 2017


Hi Martin,

On 01-02-2017 11:19, Doerr, Martin wrote:
> Hi Gustavo,
> 
> I can't see how endGroup nodes can get generated in the current jdk9 code.
> If I remember correctly, endgroup instructions were emitted in conditional long branches when the branch destination is near. But this code is gone in the current jdk9 code.
> Are you using an older version?

Yes, the ori r1,r1,0 on Hive was collected from 8. It's OpenJDK 8 on RHEL 7.2:

java -version
openjdk version "1.8.0_111"
OpenJDK Runtime Environment (build 1.8.0_111-b15)
OpenJDK 64-Bit Server VM (build 25.111-b15, mixed mode)

java-1.8.0-openjdk.ppc64le 1:1.8.0.111-1.b15.el7_2 @local-rhn-server-os
java-1.8.0-openjdk-devel.ppc64le 1:1.8.0.111-1.b15.el7_2 @local-rhn-server-os
java-1.8.0-openjdk-headless.ppc64le 1:1.8.0.111-1.b15.el7_2 @local-rhn-server-os

Red Hat packages OpenJDK 8 from:
http://hg.openjdk.java.net/aarch64-port/jdk8u/tags (tag: aarch64-jdk8u111-b15),
that by its turn derives from tag jdk8u102-b14 on jdk8u/jdk8u, so it brings at
least all the changes in jdk8u/jdk8u tag jdk8u102-b14.

When I used the SPECjvm2008 (plus -XX:+PrintOptoAssembly) to find out other
occurrences of ori r1,r1,0 (without success) I used jdk8u/jdk8u tip.

However I could not find a change on jdk8u/jdk8u regarding the endGroupNode
specifically.

On 9, your patch "8170991: PPC64: Bad code for initialization of short arrays"
removed the emission of it by removing the call to endgroup() in
MacroAssembler::clear_memory_doubleword() but in that case the ori r1,r1,0
would be preceded by a bdnz instruction and not beq or bge. But even so, it's
guarded by if (InsertEndGroupPPC64), which is by default false.

I don't know yet from which case the ori r1,r1,0 in question comes from. I'll
try to run Hive against a debug build with -XX:+PrintOptoAssembly to check if
the annotation revels its origin exactly. I understand it comes from a C2
compilation.


> The purpose of endgroup instructions is to optimize for Power6. They should get inserted before control flow merge points if the instruction group is not already completed. We have a special Power6 instruction scheduler which takes care of that, but we haven't contributed it. I guess Power6 optimization is not so relevant any more.
hm, right.

Thanks!


Best regards,
Gustavo

> 
> Best regards,
> Martin
> 
> 
> -----Original Message-----
> From: ppc-aix-port-dev [mailto:ppc-aix-port-dev-bounces at openjdk.java.net] On Behalf Of Gustavo Romero
> Sent: Dienstag, 31. Januar 2017 12:19
> To: ppc-aix-port-dev at openjdk.java.net
> Subject: A question on endGroupNode
> Importance: High
> 
> Hi,
> 
> Sometimes the JVM on PPC64 puts a group ending nop (ori r1,r1,0) after conditional branches, like, for instance, the following assembly sequence from
> C2 generated from Hive code:
> 
>    379 6.6e-04 :    10000980436c:       lwz     r14,16(r6)
>    816  0.0014 :    100009804370:       cmplw   cr6,r7,r14
>                :    100009804374:       bge     cr6,100009804ee8
>                :    100009804378:       ori     r1,r1,0   <=== endGroup
>    167 2.9e-04 :    10000980437c:       add     r15,r7,r8
>    892  0.0015 :    100009804380:       addi    r17,r15,-1
>                :    100009804384:       cmplw   cr5,r17,r14
>                :    100009804388:       bge     cr5,100009804ee8
>    262 4.5e-04 :    10000980438c:       ori     r1,r1,0   <=== endGroup
>    648  0.0011 :    100009804390:       li      r14,0
>                :    100009804394:       cmpld   cr6,r5,r14
>                :    100009804398:       beq     cr6,100009804ee8
>    267 4.6e-04 :    10000980439c:       ori     r1,r1,0   <=== endGroup
>    930  0.0016 :    1000098043a0:       addis   r20,r29,384
>                :    1000098043a4:       addi    r20,r20,16384
> 
> The (ori r1, r1, 0) seems to be emitted from a endGroupNode defined in:
> http://hg.openjdk.java.net/jdk9/hs/hotspot/file/6c1e79a99176/src/cpu/ppc/vm/ppc.ad#l13261
> 
> Nonetheless, I could not generated any endGroupNode using SPECjvm2008 (i.e.
> looking at the log from -XX:+PrintOptoAssembly there is no "End Bundle" anywhere).
> 
> Any idea why it exists primarily and if there is any option to control its emission or even a particular way to avoid the creation of an endGroupNode?
> 
> Thank you.
> 
> 
> Best regards,
> Gustavo
> 



More information about the ppc-aix-port-dev mailing list