Dashboard > RVM > Home > News
RVM
News
Added by Peter Donald , last edited by Peter Donald on Mar 08, 2007  (view change) show comment
Labels: 
(None)

Last changed May 15, 2008 05:22 by Ian Rogers
Labels: frontpage

We're very proud to announce that Jikes RVM version 2.9.3 is now available for download! It's been a little bit longer than usual since the last release and there's been quite a bit of activity on the project and improvements to the system. The appended release notes capture many of the highlights; for more details see JIRA.

The release is available from SourceForge.
** Improvement
    * [RVM-81] - Annotations in java.lang classes through bytecode engineering
    * [RVM-195] - Enable inlining of @Pure methods
    * [RVM-274] - Remove OPT_ prefix from all opt compiler classes
    * [RVM-276] - opt compiler package structure
    * [RVM-304] - Improve performance of character encoder when encoding to and from arrays
    * [RVM-305] - Add final annotations to java.io.OutputStreamWriter
    * [RVM-308] - Greater use of StringBuilder rather than StringBuffer
    * [RVM-309] - Greater use of "<Number>.valueOf" rather than "new <Number>"
    * [RVM-310] - Class library fields that could be final aren't final
    * [RVM-311] - String toUpperCase and toLowerCase perform a String.equals to see if the Locale is Turkey per invocation
    * [RVM-322] - Intel assembler register naming improvement
    * [RVM-331] - Implement support for MMX registers
    * [RVM-343] - Support for hardware SQRT instruction
    * [RVM-344] - Simplifier rule for square root operator
    * [RVM-378] - Avoid replicating field and method vectors
    * [RVM-379] - Don't replicate OSR_EncodedOSRMaps
    * [RVM-381] - Upgrade to Classpath 0.97
    * [RVM-385] - Refactor reflection to use VM interface
    * [RVM-387] - Baseline compiler emits RegDisp instructions when the Disp is 0
    * [RVM-390] - VM_Statics/JTOC space saving has cost us single iteration fop performance
    * [RVM-391] - Assign CPU # to each VM_Processor to have more predictable performance results. 
    * [RVM-392] - Improvements to ZipEntry
    * [RVM-395] - Local common sub-expression elimination of Pure method calls
    * [RVM-408] - Simple elimination of stack traces
    * [RVM-417] - Switch performance runs to using a profiled image
    * [RVM-421] - Pre-allocate 1 set of exception registers for athrow
    * [RVM-422] - Update to latest Classpath j.u.c.CopyOnWriteArrayList
    * [RVM-431] - Fix processor JNI entry/collector rendezvous race
    * [RVM-433] - Increase final fields in java.nio
    * [RVM-435] - Don't allocate memory when converting C buffers to Strings or Classes
    * [RVM-437] - Integer.toString doesn't keep cache of common values
    * [RVM-451] - Structure of code in GNU Classpath java.util.Vector and java.util.Arraylist interacts poorly with inlining

** New Feature
    * [RVM-210] - Add Image sizes tracking to Regression report and mailout
    * [RVM-319] - Create X10 test harness
    * [RVM-406] - Add Immix garbage collector
    * [RVM-441] - Sticky mark bits collector
    * [RVM-457] - Immix Garbage Collectors
    * [RVM-266] - Provide preliminary support for a non-copying unsynchronised StringBuffer implementation

** Task and Sub-task
    * [RVM-425] - Implement 2d array helper for PPC baseline
    * [RVM-224] - Push OSR-specific fields in VM_NormalMethod to subclass/side data structure
    * [RVM-450] - Prevent compilation at max opt level before some dynamic call graph information has been gathered
    * [RVM-453] - Testing framework missing failures in basic tests that use diff for sanity.

** Bug
    * [RVM-196] - VM_Processor not assignable with VM_GreenScheduler
    * [RVM-314] - Support for Java 1.4 assertions
    * [RVM-315] - java.lang.Method.invoke changes the parameters
    * [RVM-316] - A Null pointer for the UTF8CHARSET in java.util.zip.ZipFile$PartialInputStream
    * [RVM-326] - Failing basic tests don't signal failure
    * [RVM-330] - Thread.sleep() does not handle interrupts correctly
    * [RVM-339] - Image bloat (code +25% & data +5%)
    * [RVM-340] - Annotations don't handle arrays of primitive types correctly
    * [RVM-342] - NPE with advice files
    * [RVM-347] - PPC 64 regressions and Intel stress regressions since the introduction of read barriers
    * [RVM-351] - Javac regression
    * [RVM-352] - Running many iterations of _200_check fails floating point remainder test
    * [RVM-353] - Production Opt 0 builds broken
    * [RVM-355] - Complete SPEC JVM with 20 iterations dies in GC
    * [RVM-357] - Fatal error when synchronising on null objects
    * [RVM-365] - PPC (AIX) Stack Scanning Appears Broken
    * [RVM-368] - Compiler confusion over equal but non-identical objects
    * [RVM-374] - Static field allocation is non-deterministic
    * [RVM-380] - We create a lot (15909) optimization plan atomic elements using 572724bytes in the boot image
    * [RVM-383] - Branch likely and unlikely prefixes show up as LOCK prefixes in x86 disassembler output
    * [RVM-394] - Tune inlining of arraycopy
    * [RVM-412] - Latent branch optimization bug when maximizing blocks
    * [RVM-424] - Multianewarray confusion in opt compiler
    * [RVM-439] - OSR triggering code misuses suspend/resume
    * [RVM-447] - Inline size estimation reduction factor calculation over rates precise information causing bloat and slow down
    * [RVM-452] - Off-by-one error in "VMField.checkReadAccess" and "VM.checkWriteAccess"
    * [RVM-456] - Clean build broken
    * [RVM-464] - Opt compiler ldc_w for class literal broken
    * [RVM-466] - Four tests in test run "tiny" fail when compiled with -X:aos:initial_compiler=opt -X:aos:enable_recompilation=false
    * [RVM-467] - BURS performing illegal reordering to before PEI
    * [RVM-468] - Instanceof test differs in opt compiler from baseline for instanceof/checkcast of magic[][]
    * [RVM-478] - Redesign AIX native method Linkage conventions to protect CMID field from being smashed by native code saved CR

Posted at 10 May @ 8:16 PM by David Grove | 0 comments
Last changed May 08, 2008 09:03 by Ian Rogers
Labels: frontpage

Congratulations to Georgios Gousios (Athens University of Economics and Business), Byeongcheol Lee (University of Texas in Austin), Filip Pizlo (Purdue University) for being selected to work on Jikes RVM projects for the SoC. Georgios is working on Jikes RVM and JNode integration, Byeongcheol is working on extending debugger support, Filip is looking at extending the threading model.

Posted at 08 May @ 9:03 AM by Ian Rogers | 0 comments
Last changed Mar 17, 2008 16:54 by Ian Rogers
Labels: frontpage

I'm pleased to announce the Jikes RVM has been accepted into the Google Summer of Code for the 2nd year! We have a range of mentors bringing together experience from the Jikes RVM and related projects. Please have a look at our project proposals and our application template. As with last year, if you think there is an interesting project that should be listed but hasn't been then please feel free to propose it. To better integrate with our bug and feature tracking system we would much prefer if such proposals could also be added in to our issue tracker. We look forward to interest from prospective students! Don't forget the deadline for applications is March 31st.

Posted at 17 Mar @ 4:54 PM by Ian Rogers | 0 comments
Last changed Dec 01, 2007 10:35 by Ian Rogers
Labels: frontpage

Jikes RVM (nee Jalapeno) turned 10 years old last week!  The first lines of code in what became Jikes RVM were written by Derek Lieber on Nov 21, 1997.

Posted at 29 Nov @ 7:45 AM by David Grove | 0 comments
Last changed Oct 30, 2007 05:21 by Ian Rogers

We're very proud to announce that Jikes RVM version 2.9.2 is now available for download. As you can see from the appended release notes, there's been quite a bit of activity on the project since 2.9.1!
The release is available at http://downloads.sourceforge.net/jikesrvm/jikesrvm-2.9.2.tar.bz2.

New Features

  • [RVM-121] - Separate code space for dynamically generated code
  • [RVM-231] - Alignment checking (for IA32 and debugging purposes only)

Improvements

  • [RVM-16] - Constant folding values from TIBs produces failures
  • [RVM-27] - float/double to int/long conversions are overly expensive
  • [RVM-51] - Switch from pthread hijacking back to portable native sync for gtk AWT threading
  • [RVM-54] - Switch to Claspath's java.lang.Thread
  • [RVM-64] - Flexible thread model
  • [RVM-82] - Exceptions in Uninterruptible code should result in immediate fatal errors
  • [RVM-94] - Enable SSE C/C++ compiler flags
  • [RVM-164] - Use clock_gettime to implement sysNanoTime
  • [RVM-179] - Move java/lang/String out of libraryInterface and into a patch against Classpath
  • [RVM-185] - Reduce cost of ThreadLocal(s) to improve Jython performance
  • [RVM-189] - Use will never move information from MM_Interface when generating constant operands
  • [RVM-191] - Improve inline size estimator in VM_NormalMethod to account for getstatic of final primitive fields being folded by opt compiler
  • [RVM-218] - Use VM_Magic.pause in spinwait loops
  • [RVM-285] - Switch AOS call graph profiling to use CBS framework from Arnold & Grove 2005

Bug Fixes

  • [RVM-55] - A thread that is interrupted prior to being scheduled won't interrupt
  • [RVM-62] - Interrupted exceptions are generated in the caller of Thread.interrupt instead of by the thread throwing the interrupted exception
  • [RVM-63] - Unsafe.park time values are incorrectly scaled
  • [RVM-87] - NPE in ScanThread.setUpFrame:360
  • [RVM-99] - MeasureCompilation reporting broken in production/development builds on ia32-linux
  • [RVM-104] - eclipse occasionally fails with segmentation fault
  • [RVM-109] - Restore documentation to org.vmmagic.pragma.*
  • [RVM-112] - Verification error when building Jikes RVM 2.9.1 using HotSpot as host JVM.
  • [RVM-113] - MarkCompactLocal.compact():80 assertion failure
  • [RVM-114] - Ensure time is positive in test results
  • [RVM-125] - Waiting on a lock that should raise illegal monitor state exception will actual fail on an assert
  • [RVM-129] - GCTrace fails with "Cannot understand directive!"
  • [RVM-131] - Collection.joinCollection() called when thread switching disabled
  • [RVM-133] - Increase the amount of memory used during nightly tests
  • [RVM-140] - Conflicting virtual address request for space "trace" on ppc32-linux
  • [RVM-141] - SharedDeque assertion failure during exit for GCTrace
  • [RVM-143] - VM_BuildBB.determineTheBasicBlock may not be correct for goto_w operation
  • [RVM-144] - JikesRVM can't load certain classes e.g. GNU Classpath examples or its own Ant tasks
  • [RVM-150] - Unexpectedly large processor lock contention
  • [RVM-154] - A shutdown hook can hang RVM
  • [RVM-155] - SynchronizationBarrier.removeProcessor assertion failure
  • [RVM-159] - OSR-guarded inlining should not be allowed in uninterruptible code
  • [RVM-181] - ClassCastException in OPT_Simplifier when running antlr DaCapo
  • [RVM-183] - Thread sitting on >1 queue
  • [RVM-194] - Assertion failure in OSR State Extractor running chart
  • [RVM-198] - NPE when unlocking lock
  • [RVM-201] - Classpath AWT is broken
  • [RVM-203] - terminal not in grammar: new
  • [RVM-204] - Reduce wasted code space on inline allocation path
  • [RVM-206] - Stack walking in MMTk not correctly identifying not yet obsolete methods?
  • [RVM-209] - Bootimage bloat broke ppc64-aix images
  • [RVM-213] - jbb2005 performance regression
  • [RVM-216] - MMTk assertion failure during jbb large heap performance runs
  • [RVM-219] - Address.attempt*() compiles incorrectly on IA32 with Jikes 2.9.1
  • [RVM-220] - jbb2005 GC performance mode: Warning: number of GC phases exceeds MAX_PHASES
  • [RVM-242] - Build break: BaseBaseGCTrace
  • [RVM-245] - Change to deques appears to have significantly reduced hsqldb performance
  • [RVM-270] - NPEs from barrier code not working
  • [RVM-277] - lusearch fails on PPC32 due to validation error
  • [RVM-279] - Performance regression
  • [RVM-293] - Class loaders do not isolate packages with the same name
  • [RVM-297] - Classpath 0.96 configure problems with JDK 1.6
  • [RVM-298] - DaCapo chart broken on classpath 0.96
  • [RVM-299] - possible performance regression on xalan on classpath 0.96
  • [RVM-301] - JSR 166 failures

Tasks and Sub-tasks

  • [RVM-38] - VM_BaselineBootImageCompiler should use System.nanoTime rather than DNA for compilation time
  • [RVM-286] - _201_compress took a 10% hit when we switched to Arnold/Grove call graph profiling; investigate
  • [RVM-217] - Recode spin loop in org.mmtk.utility.deque.Deque spinWait to reduce frequency of nanoTime calls
  • [RVM-230] - Determine whether patching Classpath sources is preferable to bytecode engineering adding annotations
Posted at 20 Oct @ 7:58 PM by David Grove | 0 comments
Labels: frontpage

We are very happy to welcome Michael Bond and Andrew Hughes to the Jikes RVM core team! Both Michael and Andrew have made numerous contributions to the RVM and we look forward to their future efforts.

Posted at 20 Sep @ 11:16 AM by Ian Rogers | 0 comments
Labels: frontpage

We're very proud to announce that Jikes RVM version 2.9.1 is now available for download. There's been quite a bit of activity on the project since 2.9.0, and all kinds of good reasons to move up to this new version of Jikes RVM! 
 
The release is available at http://downloads.sourceforge.net/jikesrvm/jikesrvm-2.9.1.tar.bz2.

Jikes RVM 2.9.1 Release Notes (July 2, 2007)

Highlights

A major stability drive has resulted in Jikes RVM being able to reliably run the entire DaCapo benchmark suite on ia32-linux. The following issues were resolved to make this possible:

  • multiple benchmarks: 
    • r12809: Missed lock prefix (stack scanning failures). 
    • r12737: GC map iterator crashed on dynamic link frames. 
  • eclipse: 
    • r12302: Classpath RandomAccessFile incorrectly truncated. 
    • r12394: PLOS exhaustion bug in MMTk. 
    • r12375: ThinLock of interface from OPT code. 
    • r12815: Bad GC map in JNI methods. 
    • r12722: Fix for GC map bugs around expection throws. 
  • lusearch: 
    • r12602: Floating point precision (SSE2). 
    • r12633: Parallel hardware traps. 
  • hsqldb: 
    • r12683: Invalid assertion in VM_Thread. 
  • xalan: 
    • r12742: Missing static initializer broke jar caching (halves runtime). 
    • r12753: FileOutputStream wastefully copying arrays (halves runtime). 

New eclipse-project ant target to make it easy to get up and running in eclipse.

As part of the stability drive, many O2 optimizations in the optimizing compiler have been moved to O3 (and thus are not enabled by default). The performance impact of this has been mixed. For example, on ia32-linux SPECjvm98 performance actually improved by 29% due to massive improvements in mtrt and mpegaudio enabled by SSE2. Performance on SPECjbb2005 degraded by 3-10%. There were significant gains on some individual DaCapo benchmarks (most notably xalan). Re-building an aggressive O2 optimization package by stabilizing current O3 optimizations and by building new optimization passes will be one of the focus areas for the project going forward.

The recommended version of GNU classpath is 0.95. Earlier versions of GNU classpath are not supported.

SSA expression folding has been expanded to cover far more cases than previously. This leads to a > 1% speedup on benchmarks such as SpecJBB'05.

Source code analysis of the code base has been enabled using PMD (http://pmd.sourceforge.net/). Basic analysis is enabled by default and this will expand over time.

Methods in VM_Type that duplicated functionality in VM_TypeReference now delegate to associated VM_TypeReference.

The ability to force a garbage collection after N allocations or at every exception delivery has been revived and is controlled by the configuration variable config.stress-gc-interval which should be set to non-zero value to enable.

Simplistic debug symbols to show boot image method entry points in gdb. Resolved issues with rvm script so this works with rvm -gdb now.

New faster primary regression machine (Core 2 Duo) for ia32-linux at ANU. Resolved performance issues with previous regression machine.

Introduced the capability to patch against classpath versions. This allows us to keep backported performance optimizations and/or bug fixes.

Implementation of returning global JNI references from C to Java.

VM_ prefix added to classes that must be included in the primordial class list. Classes affected include; PrintLN, PrintContainer, ApplicationClassLoader, DebuggerThread, FinalizerThread, MainThread, PPC_Disassembler, opcode_tab and opcodeXX.

Classes in the adaptive package have been reorganized into packages to match the directory layout in 2.4.6 release.

Classes that resided in the objectmodel directory in 2.4.6 have been moved in to the "org.jikesrvm.objectmodel" package.

Classes that resided in the scheduler directory in 2.4.6 have been moved in to the "org.jikesrvm.scheduler" package.

Classes that resided in the runtime directory in 2.4.6 have been moved in to the "org.jikesrvm.runtime" package.

Bug fixes

Baseline GC map bug for handler blocks affecting SPECjbb2000 (r12685).

Classpath race in cloning of XML Node affecting SPECjbb2005 (r12395).

Fix final field chasing in OPT_Simplifier and re-enable constant folding for fields.

A GC map generation problem caused by casting Address to Objects and has been eliminated.

Posted at 03 Jul @ 2:57 PM by David Grove | 0 comments
Labels: frontpage

The Google SoC has started and the six successful projects are underway. The projects cover a range of issues in the RVM:

  • implementing that Java management extensions (JMX) in the Jikes RVM will allow greater monitoring with the use of standard tools
  • JDWP and JVMTI will add greater debugability to the RVM
  • the implementation of new register allocator techniques will improve the performance of the RVM
  • implementing new garbage collectors for MMTk will increase its usefulness
  • vectorization will enable the RVM to become a test bed for dynamic compilation for vectorization
  • instruction scheduling will add greater flexibility and performance to the optimizing compiler

We look forward to these great contributions to the RVM and thank the SoC project applicants for working on them!

Posted at 28 May @ 6:53 PM by Ian Rogers | 0 comments

Google has announced the successful applicants to work on the Jikes RVM for the summer of code (SoC). The mentors were surprised at the number of applicants, their diverse geographic locations, their excellent knowledge and willingness to bring contributions to the Jikes RVM. We'd really like to thank all of the applicants for applying and we're sorry that we couldn't accept more. We hope unsuccessful applicants will continue to participate with the Jikes RVM, file bug reports, talk on the mailing lists and hopefully there will be a new opportunity to take part in the SoC next year! We're now very excited now by the contributions (and hard work ) to be brought by the successful SoC applicants.

Posted at 12 Apr @ 2:59 AM by Ian Rogers | 0 comments
Last changed Mar 04, 2008 07:24 by Ian Rogers

Be quick! Students only have until Monday, March 26th to submit proposals for work they'd like to undertake with the Jikes RVM for the Google SoC. In our summer of code area we have a list of project ideas that should give you some ideas for project proposals. You can always come up with your own! For ideas on what the Jikes RVM has been used for in the past, browse these web pages. There really is an opportunity to write a project proposal that interests just about anybody with the Jikes RVM! As we say on the home page, the Jikes RVM is a flexible testbed for ideas. These ideas have ranged from binary translators (high performance emulators), to Java operating systems, to dynamically typed language support (for languages such as Perl), to aspect oriented programming, to state-of-the-art compiler, threading and garbage collection performance ideas.

Unsure about project ideas and your own ideas for things you can do with the Jikes RVM? The Jikes RVM community is an excellent sounding board. Why not subscribe and post your questions to the researchers mailing list. We welcome the opportunity to discuss your ideas, don't be afraid of the forum!

Posted at 16 Mar @ 5:17 AM by Ian Rogers | 0 comments
Last changed Mar 04, 2008 07:24 by Ian Rogers

The Google SoC 2007 is an opportunity for students to be paid to develop the JikesRVM! The Jikes RVM was one of only 131 organizations selected by Google. For more information on the Google SoC and the Jikes RVM, see our SoC pages.

Posted at 16 Mar @ 4:57 AM by Ian Rogers | 0 comments
Last changed May 22, 2007 23:11 by Peter Donald
Labels: frontpage

We're very happy to announce a new release of Jikes RVM: version 2.9.0.  Quite a bit has changed since 2.4.6 and we'd welcome feedback on the changes as we head towards a 3.0 release later this year. Thanks again to everyone who has pitched in to make this one of the most exciting Jikes RVM releases since our initial open source release in 2001!

The release is available at http://downloads.sourceforge.net/jikesrvm/jikesrvm-2.9.0.tar.bz2. The release notes are appended below:

Jikes RVM 2.9.0 Release Notes (March 15, 2007)

Highlights

  1. The five months since the release of 2.4.6 have been one of the most active periods in the open source history of the project.  A number of significant changes have been made to clean up and modernize the code base to enable future evolution. 
  2. We have made large scale changes to the structure of the source code to prepare for development of Jikes RVM from within standard Java IDEs.
  3. There is a new, ant-based, build and test system that have replaced jconfigure and RunSanityTests.
  4. We now use ecj (the Eclipse Java compiler) instead of jikes to compile our Java source files and have eliminated the preprocessor. 
  5. The userguide has been moved from latex into a wiki.  It has been updated to describe the new build and test systems. The release tarball contains a pdf and html version of the userguide.
  6. We now support Java5, we have switched to using the generics branch of GNU Classpath, and much of Jikes RVM has been rewritten to use Java 5 language features and generic types. 
  7. We have switched to using Java5 annotations for pragmas/magic. 
  8. The recommended version of GNU classpath is 0.93-generics. Earlier versions of GNU classpath are not supported.
  9. Support in the PPC baseline compiler for storing local variables in registers.
  10. Refactor of type system and JTOC.
  11. Support for packing subword sized fields in objects. Removal of hand packed fields. Various memory savings.
  12. System calls now supported in any file using SysCall annotation on a native method. VM_SysCall now generates implementation from annotation. VMMath now implemented using system calls.
  13. Support for chasing final fields reached from literal or static final fields. Greater optimization of object constant operands.
  14. Greater support for 387 constants. Simplification of 387 BURS rules.

Bug fixes

Yes...many   For details: svn log -r10915:11866

Other Notes

  1. The Quick compiler has been deleted.  It is now available as a patch on the research tracker, or via older releases (2.3.4 through 2.4.6).
  2. The HPM (Hardware Performance Monitor) code has been deleted. It is now available on the research tracker (item 1613215), by svn diff -r11162:11161, or in releases through 2.4.6.
  3. This release is known to not work on OS X.  We would like to get this platform working again;  if you use Jikes RVM on OS X and are willing to help fix it, please let us know.
Posted at 15 Mar @ 1:58 PM by David Grove | 0 comments
Last changed Mar 04, 2008 07:24 by Ian Rogers

The mentoring organization application deadline for the Google Summer of Code 2007 is March 12. This may lead to some really excellent work so please take the time to visit our Google Summer of Code 2007 page and possibly add yourself as a mentor on our application or add some project ideas.

Posted at 08 Mar @ 7:09 PM by Peter Donald | 0 comments

Past news can be accessed by Browse Space/News link.

Site running on a free Atlassian Confluence Open Source Project License granted to The Codehaus. Evaluate Confluence today.
Powered by Atlassian Confluence, the Enterprise Wiki. (Version: 2.6.2 Build:#919 Nov 26, 2007) - Bug/feature request - Contact Administrators