> The field access/modification events set interp only mode and compiled frame 
> is not expected. However JNI might call `post_field_access_by_jni` while the 
> last java frame is compiled. 
> 
> 1) The thread switched to interponly mode while it is in JNI code. The 
> deoptimization is triggered but each frame is really changed only execution 
> returns to it.  So last java frame was not executed and thus is still 
> compiled. 
> 2) The JNI accessed field from the thread where field events are not enabled. 
> So the `post_field_access_by_jni` is called in threads in interp_only mode. 
> 
> The original example doesn't reproduce issue because of JDK changes and I 
> don't know of it is 1) or 2)I. I implemented regression test for both 
> problems. 
> 
> The location should be zero for JNI access.

Leonid Mesnik has updated the pull request incrementally with two additional 
commits since the last revision:

 - fixed string
 - fixed after feedback from Alex

-------------

Changes:
  - all: https://git.openjdk.org/jdk/pull/27584/files
  - new: https://git.openjdk.org/jdk/pull/27584/files/423f5b13..41864984

Webrevs:
 - full: https://webrevs.openjdk.org/?repo=jdk&pr=27584&range=08
 - incr: https://webrevs.openjdk.org/?repo=jdk&pr=27584&range=07-08

  Stats: 26 lines in 1 file changed: 8 ins; 6 del; 12 mod
  Patch: https://git.openjdk.org/jdk/pull/27584.diff
  Fetch: git fetch https://git.openjdk.org/jdk.git pull/27584/head:pull/27584

PR: https://git.openjdk.org/jdk/pull/27584

Reply via email to