C2 compiler gets SIGILL/ILL_ILLOPC

Sergey Nazarkin snazarkin at azul.com
Wed Feb 24 10:42:02 UTC 2021


Hi!

I’d just note this alias is for https://hg.openjdk.java.net/aarch32-port project.  jdk8 aarch32  and arm32 jdk11 projects contain completely different code base.  For the code that touches jdk11 and later special mail list need to be notified (https://mail.openjdk.java.net/pipermail/jdk-updates-dev/).

/Sergey


> On Feb 21, 2021, at 19:45, John Neffenger <john at status6.com> wrote:
> 
> On 2/19/21 1:14 AM, Matthias Klose wrote:
>> yes, but apparently JDK-8222825 is missing from jdk11u. Attaching a backport for
>> that.  Does this look reasonable?
> 
> I tested the back-ported patch, and Matthias asked me to post my results to the public mailing list. I tested the build on Ubuntu 14.04 LTS, the most recent release that can still run on my old ARM Cortex-A8 device.
> 
> Note: A long power outage prevented me from running the overnight test, but I'll try again today now that I have electricity again.
> 
> Below are the results I sent to Matthias, minus the large HotSpot error log attachments.
> 
>> see https://people.debian.org/~doko/tmp/trusty-armhf/
> 
> Looks good to me! Thank you, Matthias. It's great to see Ubuntu back-porting fixes like this to OpenJDK 11. What follows are the details of my tests.
> 
> My first test was to build and run the project below, which contains two simple "Hello World" programs -- a console application and a Java Swing application:
> 
>  Hello Java!
>  https://github.com/jgneff/hello-java
> 
> First, I reproduced the error in OpenJDK 11 using the following two builds:
> 
>  AdoptOpenJDK OpenJDK 11 for Linux on arm32
>  https://adoptopenjdk.net/releases.html
> 
>  BellSoft OpenJDK 11 for Linux on 32-bit ARM (Standard JDK)
>  https://bell-sw.com/pages/downloads/#/java-11-lts
> 
> Both builds failed to compile the programs. When I compiled on another system and copied over the JAR files, both builds ran the console application fine but failed to run the Java Swing application. I attached the HotSpot crash logs to this message in case we ever want to verify that a PLDW instruction caused the ILL_ILLOPC error.
> 
> For example, compiling with the BellSoft build:
> 
> ------------------------------------------------------------------------
> $ export JAVA_HOME=$HOME/opt/jdk-11.0.10
> $ make
> mkdir -p dist
> /home/ubuntu/opt/jdk-11.0.10/bin/javac --release 11 -d build/classes --module-source-path "./*/src/main/java" --module org.status6.hello.world
> #
> # A fatal error has been detected by the Java Runtime Environment:
> #
> #  SIGILL (0x4) at pc=0x2bc4c4a0, pid=4911, tid=4912
> #  ...
> ------------------------------------------------------------------------
> 
> And running with the AdoptOpenJDK build:
> 
> ------------------------------------------------------------------------
> $ export JAVA_HOME=$HOME/opt/jdk-11.0.10+9
> $ make run
> /home/ubuntu/opt/jdk-11.0.10+9/bin/java -jar dist/hello-world-1.0.0.jar
> Hello World!
> /home/ubuntu/opt/jdk-11.0.10+9/bin/java -jar dist/hello-swing-1.0.0.jar
> #
> # A fatal error has been detected by the Java Runtime Environment:
> #
> #  SIGILL (0x4) at pc=0x2bc5f34c, pid=5525, tid=5526
> #  ...
> ------------------------------------------------------------------------
> 
> Both of these builds of OpenJDK could build and run the sample programs when I added the "-XX:-AssumeMP" workaround to all of the JDK tools in the Makefile.
> 
> I installed the four Debian packages that you built as follows:
> 
>  $ sudo dpkg -i openjdk-11-jre-headless_11.0.11+3-3_armhf.deb
>  $ sudo dpkg -i openjdk-11-jdk-headless_11.0.11+3-3_armhf.deb
>  $ sudo dpkg -i openjdk-11-jre_11.0.11+3-3_armhf.deb
>  $ sudo dpkg -i openjdk-11-jdk_11.0.11+3-3_armhf.deb
> 
> Using those packages, everything built and ran just fine, with no need for the "-XX:-AssumeMP" workaround:
> 
> ------------------------------------------------------------------------
> $ export JAVA_HOME=/usr/lib/jvm/java-11-openjdk-armhf
> $ make
> mkdir -p dist
> /usr/lib/jvm/java-11-openjdk-armhf/bin/javac --release 11 -d build/classes --module-source-path "./*/src/main/java" --module org.status6.hello.world
> /usr/lib/jvm/java-11-openjdk-armhf/bin/jar --create --file dist/hello-world-1.0.0.jar --main-class org.status6.hello.world.Hello --module-version 1.0.0 -C build/classes/org.status6.hello.world .
> /usr/lib/jvm/java-11-openjdk-armhf/bin/javac --release 11 -d build/classes --module-source-path "./*/src/main/java" --module org.status6.hello.swing
> /usr/lib/jvm/java-11-openjdk-armhf/bin/jar --create --file dist/hello-swing-1.0.0.jar --main-class org.status6.hello.swing.Hello --module-version 1.0.0 -C build/classes/org.status6.hello.swing .
> 
> $ make run
> /usr/lib/jvm/java-11-openjdk-armhf/bin/java -jar dist/hello-world-1.0.0.jar
> Hello World!
> /usr/lib/jvm/java-11-openjdk-armhf/bin/java -jar dist/hello-swing-1.0.0.jar
> Hello World!
> Hello World!
> ------------------------------------------------------------------------
> 
> I then ran the JavaFX animation program from the following project using the new packages:
> 
>  JavaFX on E-Paper
>  https://github.com/jgneff/epd-javafx
> 
> And it works great:
> 
> ------------------------------------------------------------------------
> $ sudo bin/run.sh --pattern=3 --loops=0
> openjdk 11.0.11-ea 2021-04-20
> OpenJDK Runtime Environment (build 11.0.11-ea+3-post-Ubuntu-3)
> OpenJDK Server VM (build 11.0.11-ea+3-post-Ubuntu-3, mixed mode)
> FINE: EPD system properties: {monocle.epd.waveformMode=4}
> FINE: Frame buffer geometry: 800 600 800 640 32
> FINE: Frame buffer rgba: 8/16,8/8,8/0,8/24
> FINE: Frame buffer grayscale: 0
> FINE: Native screen geometry: 800 px x 600 px x 32 bpp
> FINE: Mapping frame buffer: 1,920,000 bytes
> FINE: Using native cursor: SoftwareCursor
> ...
> ------------------------------------------------------------------------
> 
> I'll let the animation program run overnight, just to be sure.
> 
> By the way, as I suspected, I cannot reproduce the error on my Raspberry Pi 2 Model B Rev 1.1 with its ARM Cortex-A7 processor. I can't find anything definitive, but it seems that only the Cortex-A8 is missing the Multiprocessor (MP) Extensions with the PLDW instruction.
> 
> Thank you again,
> John



More information about the aarch32-port-dev mailing list