Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: mention bugginess of MarkCompact, update infrastructure section to account for Jenkins setup

NOTE: This page is a work-in-progress!

(incomplete) TODO list

...

General project status

Jikes RVM is currently the most popular platform for virtual machine research. It has received a SIGPLAN Software Award.However, the Jikes RVM is not state-of-the-art in some areas. In particular, Jikes RVM currently does not provide 64-bit Intel Support. It also does not support the OpenJDK class libraries. The project has received community contributions to improve those shortcomings but the code is not yet in the mainlineThis popularity is reflected in the particpation on the mailing lists where most questions can be answered.

Memory management research is a particular strength of the Jikes RVM. The Memory Management Toolkit (MMtk) provides a well-rounded selection of garbage collectors and the compiler replay feature enables researchers to control mutator variation. The MMTk test harness can be used to test collectors.

In contrast to this, the compilers are currently a weak spot in the Jikes RVM. For example, the Static Single Assignment (SSA) form in the compilers is currently disabled because of bugs.

The Jikes RVM is not state-of-the-art in some areas. In particular, Jikes RVM currently does not provide 64-bit Intel Support. Another big limitation is the lack of support for the OpenJDK class library. The project has received community contributions to improve those shortcomings but the code is not yet in the mainline. The Jikes RVM would also profit from efforts directed to stability improvements and bugfixes. For example, Jikes RVM currently cannot run all of the Dacapo 9.12 benchmarks.

The Jikes RVM team aims to provide at least one release every year.

Note: The information on this page refers to the status in the code repository and not to the status in the current release.

Note: If you want to help, please see How to Help or inquire via the mailing lists.

Near-term goals

  • Add support for the OpenJDK class libraries
  • Add Intel 64-bit support

Preliminary long-term goals (still need further discussion)

  • Improve stability
  • Improve compliance with JVM spec
  • Write unit tests for all classesadd
  • Improve and extend test suites
  • Add support for relevant new platforms (ARM?)
  • Merge relevant changes from MRP

Detailed project status

This section provides more detailed project status information for the components. If you think an important point is missing here, please contact us via the mailing lists.

Benchmarks

  • DaCapo 2006-MR-2 runs on Jikes RVM
  • Some benchmarks of DaCapo 9.12 work
  • Parts of SPECjvm2008 work (see RVM-484)

Community

  • Jikes RVM has a large community in its intended audience (researchers)
  • Core team consists wholly of volunteers: no paid developers
  • Jikes RVM is currently not packaged for any major distribution

Memory Management

  • GenImmix Generational Immix (the default collector) is very stable
  • The other collectors are reasonably stable but have some bugs (see as shown by the regression tests)
  • The MarkCompact collector is currently too buggy to use
  • Notable omissions in the collector choices include Baker-style collectors, the Compressor and on-the-fly collectors

Runtime

  • The runtime is reasonably modular but it doesn't make very good use of interfaces
  • Jikes RVM currently does not follow the JVM specification
  • Jikes RVM lacks an interpreter
  • strictfp is not implemented
  • JMX is not implemented
  • JVMTI is not implementedSeveral features normally found in commercial JVMs are not implemented: strictfp, JMX and JVMTI are currently unsupported

Adaptive Optimization System

  • the The AOS provides a good level of control via compiler replay
  • the The AOS provides clear extension points
  • Jikes RVM currently uses only one compilation thread at runtime and the current AOS model does not support multiple compilation threads

Compiler

  • The provided AOS models do not support Feedback-Directed Optimizations

Compilers

  • SSA form is disabled. Scalar SSA form may be fixable; Heap SSA form is probably considered too broken
  • Many optimizations are disabled because they rely on SSA or are considered too buggy
  • No support for polyhedral model
  • Some standard optimizations are missing, e.g. Global Array Bound check elimination is unimplemented
  • Java Memory Model (JMM) is not correctly implemented

Infrastructure

  • Need access to PowerPC machines for Bootimage compilation is single-threaded by default because it is too unrealiable with multiple threads

Infrastructure

  • Regression tests are run regulary and reports are sent to the regressions mailing list
  • Core team members have access to a Jenkins server to view test results in detail
  • More regression machines would be useful, in particular PowerPC machines that can be accessed by all team members
  • Regular regression tests with Cattrack
  • Currently no infrastructure for CICurrently no code review tools in use
  • Some unit tests (via JUnit) exist but most classes don't have unit tests