Compact Coprocessor Acceleates Java On Embedded Processors

April 16, 2001
A new Java coprocessor architecture called JVXtreme takes a different approach to Java application acceleration. It works in cooperation and in parallel with the main processor, generating better performance than in-line conversion of Java bytecodes...

A new Java coprocessor architecture called JVXtreme takes a different approach to Java application acceleration. It works in cooperation and in parallel with the main processor, generating better performance than in-line conversion of Java bytecodes to native processor instructions (see the figure).

Produced by inSilicon, JVXtreme supercedes the company's earlier JVX architecture. Both speed up bytecode execution. JVXtreme, though, reduces instruction fetch time so most Java bytecodes execute in a single cycle. The Java Virtual Machine (JVM) is implemented on the native processor, but inSilicon's coprocessor handles substantial portions.

This architecture provides the speed and compact code advantages of a native Java processor while working with a native processor. It competes with Just-in-Time (JIT) native-code compilers and other Java hardware accelerators. Efficient fetch and execution of Java byte codes provide this performance. So do two key features.

The first is a large hardware stack. Its 64-entry default size is significantly larger than in-line bytecode conversion architectures that use a portion of the native processor's register block, like ARM's Jazelle. JVXtreme handles stack overflow and underflow automatically. The JVM uses this feature during a task switch.

The second, instruction folding, takes advantage of Java's stack architecture. Architectures usually push a constant onto the stack and then store the new top-of-stack entry in the variable. Instead, JVXtreme recognizes this pair of instructions and stores the constant in the variable without using the stack. Also, JVXtreme pushes the constant on the stack and then compares it to the variable in one step.

JVX and JVXtreme currently support the ARM7 and ARM9 processors. InSilicon's coprocessor has a small footprint at only 35 kgates and operates at clock speeds up to 200 MHz.

More information is available at www.insilicon.com.

About the Author

William G. Wong | Senior Content Director - Electronic Design and Microwaves & RF

I am Editor of Electronic Design focusing on embedded, software, and systems. As Senior Content Director, I also manage Microwaves & RF and I work with a great team of editors to provide engineers, programmers, developers and technical managers with interesting and useful articles and videos on a regular basis. Check out our free newsletters to see the latest content.

You can send press releases for new products for possible coverage on the website. I am also interested in receiving contributed articles for publishing on our website. Use our template and send to me along with a signed release form. 

Check out my blog, AltEmbedded on Electronic Design, as well as his latest articles on this site that are listed below. 

You can visit my social media via these links:

I earned a Bachelor of Electrical Engineering at the Georgia Institute of Technology and a Masters in Computer Science from Rutgers University. I still do a bit of programming using everything from C and C++ to Rust and Ada/SPARK. I do a bit of PHP programming for Drupal websites. I have posted a few Drupal modules.  

I still get a hand on software and electronic hardware. Some of this can be found on our Kit Close-Up video series. You can also see me on many of our TechXchange Talk videos. I am interested in a range of projects from robotics to artificial intelligence. 

Sponsored Recommendations

Comments

To join the conversation, and become an exclusive member of Electronic Design, create an account today!