Improving the performance of OpenJDK
Gary Benson
gbenson at redhat.com
Thu Feb 19 06:38:01 PST 2009
Gary Benson wrote:
> Andrew Haley wrote:
> > Gary Benson wrote:
> > > Edward Nevill wrote:
> > > > get_native_u2() and get_Java_u2() ... This seems to be a
> > > > misguided attempt of the original authors to optimised reading
> > > > of halfwords (judging by the comment immediate preceding the
> > > > code).
> > >
> > > It's not an optimization, it's to do unaligned access on
> > > hardware that doesn't support it. I'm guessing ARM does allow
> > > unaligned access by the fact that your code didn't segfault
> > > instantly ;)
> >
> > ARM doesn't support unaligned loads. The new ARM code as posted
> > is
> >
> > ldrsb r0, [java_pc, #0]
> > ldrb r1, [java_pc, #1]
> > orr r1, r1, r0, lsl #8
> >
> > i.e two byte loads.
>
> Ah, I didn't realise. Which is good, it means this optimization is
> generic :)
So I did a quick SPECjvm98 run of this change on amd64. A couple of
the times are improved, by 3-10%, but one of the times is *slower*
by 11%. See attached. I'm not sure what to make of that...
Cheers,
Gary
--
http://gbenson.net/
-------------- next part --------------
,times/zero-92c4cc753f06,times/zero-92c4cc753f06-u2
compress,231.02,255.489
jess,70.363,64.099
db,116.143,112.242
javac,72.624,69.744
mpegaudio,229.505,226.654
mtrt,59.302,59.274
jack,49.195,44.505
-------------- next part --------------
A non-text attachment was scrubbed...
Name: result.png
Type: image/png
Size: 2155 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/zero-dev/attachments/20090219/15362c33/attachment.png
More information about the zero-dev
mailing list