RFR: Add support for ARMv6 to ARM JIT
Andrew Hughes
gnu.andrew at redhat.com
Wed Feb 11 16:39:02 UTC 2015
----- Original Message -----
> Hi,
>
> The following patch adds support for ARMv6 to the ARM JIT (previously known
> as the Thumb2 JIT).
>
> http://openjdk.linaro.org/arm32jit/patches/6046.patch
>
> The following ARM architectures are now supported
>
> ARMv6 - Vanilla ARMv6 as on Raspberry PI (No Thumb2, No LDREXD/STREXD)
> ARMv6K - ARMv6 with MP support (No Thumb2, but has LDREXD/STREXD)
> ARMV6T2 - ARMv6 with Thumb2 and LDREXD/STREXD
> ARMV7 - all variants supported
> ARMV8 - all variants supported (in AARCH32 mode)
>
> Note, because of the lack of properly working double/long atomic primitives
> on vanilla ARMv6 only non MP is supported on this. The Raspberry PI is
> single core so this is not a problem, it just uses LDM/STM or LDRD/STRD.
>
> I have based the patches on the icedtea7 tree at
> http://icedtea.classpath.org/hg/icedtea7-forest/hotspot Is this the correct
> location for the tip of the icedtea7 development?
>
> Because of the size of the changes I have introduced a new file arm32JIT.cpp
> rather than modifying the existing thumb2.cpp. This is switched on a symbol
> ARM32JIT. By default it will continue to build the Thumb2 JIT. To change it
> to build the ARM32 JIT by default add -DARM32JIT to CFLAGS in zeroshark.make
> as in the following patch.
>
> http://openjdk.linaro.org/arm32jit/patches/6047.patch
>
> I have put an image at
>
> http://openjdk.linaro.org/arm32jit/images/arm32jit.tgz
>
> I would be grateful if people could try out this image, especially on
> Raspberry PI.
>
> Some influential environment variables are
>
> T2_COMPILE_ARM
>
> Force it to compile for ARM32. By default it still compiles for Thumb2 on
> Thumb2 capable cores, setting this variable will force it to compile for
> ARM.
>
> T2_PRINT_STATISTICS
>
> Print some compilation statistics as it compiles
>
> T2_PRINT_COMPILATION (or -XX:+PrintCompilation)
>
> Print the name of each method as it compiles
>
> T2_PRINT_DISASS (or -XX:+UnlockDiagnosticVMOptions -XX:+PrintAssembly)
>
> Disassemble each method as it compiles.
>
> I have tested the original Thumb2 JIT and the new ARM v6 JIT with hotspot and
> langtools tests from JTreg. Here are the results I get:-
>
> Original Thumb2 JIT
>
> Hotspot: Test results: passed: 265; failed: 13; error: 7
> Langtools: Test results: passed: 1,957; failed: 1; error: 9
>
> ARMv6 JIT
>
> Hotspot: Test results: passed: 266; failed: 8; error: 11
> Langtools: Test results: passed: 1,957; failed: 1; error: 9
>
> All comments welcome!
> Ed.
>
>
>
You're more than welcome to commit this. Now would be a good time
to do so while things are still relatively quiet, before our
next release cycle in April.
I've opened a bug to track this:
http://icedtea.classpath.org/bugzilla/show_bug.cgi?id=2228
If you include the text 'PR2228' in the commit message when pushing
to http://icedtea.classpath.org/hg/icedtea7-forest/hotspot, the commit
will be recorded on the bug.
Thanks,
--
Andrew :)
Free Java Software Engineer
Red Hat, Inc. (http://www.redhat.com)
PGP Key: ed25519/35964222 (hkp://keys.gnupg.net)
Fingerprint = 5132 579D D154 0ED2 3E04 C5A0 CFDA 0F9B 3596 4222
PGP Key: rsa4096/248BDC07 (hkp://keys.gnupg.net)
Fingerprint = EC5A 1F5E C0AD 1D15 8F1F 8F91 3B96 A578 248B DC07
More information about the distro-pkg-dev
mailing list