Is RegisterMap updated?
David Griffiths
david.griffiths at gmail.com
Tue Jan 29 15:41:22 UTC 2019
Oh, I'm looking at the jdk8u code which has the following code commented out:
/*
if (map.getUpdateMap()) {
// Tell GC to use argument oopmaps for some runtime stubs that need it.
// For C1, the runtime stub might not have oop maps, so set this flag
// outside of update_register_map.
map.setIncludeArgumentOops(cb.callerMustGCArguments());
if (cb.getOopMaps() != null) {
OopMapSet.updateRegisterMap(this, cb, map, true);
}
// Since the prolog does the save and restore of EBP there is no oopmap
// for it so we must fill in its location as if there was an oopmap entry
// since if our caller was compiled code there could be live jvm
state in it.
updateMapWithSavedLink(map, savedFPAddr);
}
*/
I see that is no longer commented out in jdk9 so maybe that's the
cause. (There is nothing else that calls setLocation).
Cheers,
David
On Tue, 29 Jan 2019 at 13:41, Andrew Haley <aph at redhat.com> wrote:
>
> On 1/29/19 11:24 AM, David Griffiths wrote:
> > Hi, in CompiledVFrame.createStackValue there is the following code:
> >
> > // First find address of value
> > Address valueAddr = loc.isRegister()
> > // Value was in a callee-save register
> > ? getRegisterMap().getLocation(new VMReg(loc.getRegisterNumber()))
> > // Else value was directly saved on the stack. The frame's
> > original stack pointer,
> > // before any extension by its callee (due to Compiler1
> > linkage on SPARC), must be used.
> > : ((Address)fr.getUnextendedSP()).addOffsetTo(loc.getStackOffset());
> >
> > It appears from what I can make out that for the register case the map
> > is not updated and so valueAddr is null. The only thing I can see that
> > calls setLocation is updateMapWithSavedLink. Seems like it should be
> > possible to return the register value for the frame at the top of the
> > stack though?
>
> It could be, but we don't do that. The registers in the map are those
> pushed onto the stack by generated Java code.
>
> --
> Andrew Haley
> Java Platform Lead Engineer
> Red Hat UK Ltd. <https://www.redhat.com>
> EAC8 43EB D3EF DB98 CC77 2FAD A5CD 6035 332F A671
More information about the serviceability-dev
mailing list