Mercurial > hg > graal-compiler
view visualizer/nbproject/genfiles.properties @ 11825:463f51256c86
AMD64HotSpot: emit jump to IC miss handler directly instead of emitting it inside verfied_entry
for empty methods we emitted something like this if a inline cache is needed:
prefix:
00: < IC check >
...
0b: jne <ic_miss_call>
11: nop
...
verified_entry:
20: ret
ic_miss_call:
21: jmp <entry of runtime function>
when a method is deoptimized, HotSpot patches the verified_entry (0x20) with a
jump to a stub that handles call-sites that has been made non-entrant. since this jump
is 5 bytes long, it will overwrite ic_miss_call and blow up every caller that
calls this method via the unverified entry (prefix).
the fix is to emit the jump to the runtime function inside the unverfied entry:
prefix:
00: < IC check >
...
0b: je <verified_entry>
11: jeq <entry of runtime function>
16: nop
...
verified_entry:
20: ret
author | Bernhard Urban <bernhard.urban@jku.at> |
---|---|
date | Mon, 30 Sep 2013 09:32:18 +0200 |
parents | c1160de36474 |
children |
line wrap: on
line source
build.xml.data.CRC32=3c2c6126 build.xml.script.CRC32=48934e60 build.xml.stylesheet.CRC32=eaf9f76a@1.45.1 # This file is used by a NetBeans-based IDE to track changes in generated files such as build-impl.xml. # Do not edit this file. You may delete it but then the IDE will never regenerate such files for you. nbproject/build-impl.xml.data.CRC32=3077accc nbproject/build-impl.xml.script.CRC32=17b494f7 nbproject/build-impl.xml.stylesheet.CRC32=0f381476@2.47.1 nbproject/platform.xml.data.CRC32=3077accc nbproject/platform.xml.script.CRC32=db9e1f43 nbproject/platform.xml.stylesheet.CRC32=df8ac4dd@2.47.1