-
Notifications
You must be signed in to change notification settings - Fork 66
8275638: GraphKit::combine_exception_states fails with "matching stack sizes" assert #29
Conversation
👋 Welcome back roland! A progress list of the required criteria for merging this PR into |
@rwestrel This change now passes all automated pre-integration checks. ℹ️ This project also has non-automated pre-integration requirements. Please see the file CONTRIBUTING.md for details. After integration, the commit message for the final commit will be:
You can use pull request commands such as /summary, /contributor and /issue to adjust it as needed. At the time when this comment was updated there had been 5 new commits pushed to the
Please see this link for an up-to-date comparison between the source branch of this pull request and the ➡️ To integrate this PR with the above commit message to the |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree with this conservative fix. John agreed with it too.
@dean-long please run testing for it before Roland pushed it. Also file RFE to clean these up - we will assign an engineer to look on it later.
I filed JDK-8278873 and started testing. |
Test results look good. |
@dean-long @vnkozlov thanks for the reviews. |
/integrate |
Going to push as commit b9a477b.
Your commit was automatically rebased without conflicts. |
I'm late to the party, but still would like to clarify one thing. It seems the root cause of the bug comes from the fact that the same JVM state is used by both
|
Wouldn't that only work if there's no uncommon trap in GraphKit::builtin_throw()? |
Good point. I overlooked the uncommon trap logic there. But my original point still stands: why can't So, instead of checking for local exception handlers and wiping the stack [1], the effects of [1]
[2]
|
Then what's on the stack doesn't matter so why not pop the stack instead? |
Yes, that's also an option. (And, probably, the cleanest one.) I agree with the summary in JDK-8278846. I don't see any reason why exception state should include stack state. Thanks for the clarifications. |
The bug and fix were discussed in a previous PR:
openjdk/jdk#6572
I pushed all commits from that PR on top of jdk 18 and added a couple
extra tests as suggested in:
openjdk/jdk#6572 (comment)
Progress
Issue
Reviewers
Reviewing
Using
git
Checkout this PR locally:
$ git fetch https://git.openjdk.java.net/jdk18 pull/29/head:pull/29
$ git checkout pull/29
Update a local copy of the PR:
$ git checkout pull/29
$ git pull https://git.openjdk.java.net/jdk18 pull/29/head
Using Skara CLI tools
Checkout this PR locally:
$ git pr checkout 29
View PR using the GUI difftool:
$ git pr show -t 29
Using diff file
Download this PR as a diff file:
https://git.openjdk.java.net/jdk18/pull/29.diff