what's John doing?
John Rose
John.Rose at Sun.COM
Mon Aug 4 14:51:07 PDT 2008
On Jul 31, 2008, at 2:35 PM, Charles Oliver Nutter wrote:
> At what point do you think
> it would be worth trying to do an experimental test with e.g. JRuby,
> wiring it in where reflection was being used previously?
Here are the upcoming points of development for the native (non-
emulated) JSR 292 RI:
1. direct emulation of invoke* instructions, interpreter only (first
cut done & pushed)
2. adapter and bound method handles, interpreter only (working on
this now)
3. invokedynamic (interpreter only)
4. compiler support for method handles
5. compiler support for invokedynamic
6. specialized call site optimizations (inlining)
7. specialized method handle optimizations (method handle compilation
and/or folding)
There are different advantages for integrating JRuby at each point.
1. can replace class generation for out-calls to Java (better
footprint and bootstrap, but missing full performance until 6, 7)
2. can replace class generation pertaining to accessors, Ruby
methods, linkage logic
3. can push linkage logic down into the JVM (more compact bytecode,
slightly better performance, but missing full performance until 6, 7)
4, 5. performance improvement from steps 2, 3
6. meet or exceed current performance for hot paths
7. meet or exceed current performance for warm paths
Early adoption is better, from my POV, but when you move in early you
have to be willing to live with non-working appliances, construction
noise, etc.
To answer your specific question, you can almost replace reflection
now, except for argument and return value transformations (adapting
boxed varargs to native calling sequences). You could either wire up
your own infrastructure for adapters to step 1 method handles, or
wait for step 2 to provide you with VM-native adapters.
I think the easiest way to do the adapters is to reflect argument
lists up to (privileged) Java code, which will edit them in place on
the interpreter stack. We'll see shortly if this works out. Backup
plan is to put tons of new code into the JVM to handle all the corner
cases of Integer.valueOf(int) and its dozens of cousins.
-- John
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://mail.openjdk.java.net/pipermail/mlvm-dev/attachments/20080804/d0d43546/attachment.html
More information about the mlvm-dev
mailing list