Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

8341844: [lworld] Test crashing in genzgc in ZBarrier::mark_from_old_slow_path(zaddress)+0x4c #1321

Closed
wants to merge 4 commits into from

Conversation

MrSimms
Copy link
Member

@MrSimms MrSimms commented Dec 17, 2024

Generational zgc requires a store barrier in addition to the load barrier.
load barrier followed by bulk copy isn't enough


Progress

  • Change must not contain extraneous whitespace

Issue

  • JDK-8341844: [lworld] Test crashing in genzgc in ZBarrier::mark_from_old_slow_path(zaddress)+0x4c (Bug - P4)

Reviewers

Contributors

  • Erik Österlund <eosterlund@openjdk.org>

Reviewing

Using git

Checkout this PR locally:
$ git fetch https://git.openjdk.org/valhalla.git pull/1321/head:pull/1321
$ git checkout pull/1321

Update a local copy of the PR:
$ git checkout pull/1321
$ git pull https://git.openjdk.org/valhalla.git pull/1321/head

Using Skara CLI tools

Checkout this PR locally:
$ git pr checkout 1321

View PR using the GUI difftool:
$ git pr show -t 1321

Using diff file

Download this PR as a diff file:
https://git.openjdk.org/valhalla/pull/1321.diff

Using Webrev

Link to Webrev Comment

Sorry, something went wrong.

…slow_path(zaddress)+0x4c

Generational zgc requires a store barrier in addition to the load barrier.
load barrier followed by bulk copy isn't enough
@bridgekeeper
Copy link

bridgekeeper bot commented Dec 17, 2024

👋 Welcome back dsimms! A progress list of the required criteria for merging this PR into lworld will be added to the body of your pull request. There are additional pull request commands available for use with this pull request.

@openjdk
Copy link

openjdk bot commented Dec 17, 2024

@MrSimms 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:

8341844: [lworld] Test crashing in genzgc in ZBarrier::mark_from_old_slow_path(zaddress)+0x4c

Co-authored-by: Erik Österlund <eosterlund@openjdk.org>
Reviewed-by: eosterlund

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 2 new commits pushed to the lworld branch:

  • 137b0c2: 8346305: [lworld] Revert WeakHashMap POC for a value object policy
  • 5313fda: 8346467: [lworld] Value record cannot be implicitly constructible

Please see this link for an up-to-date comparison between the source branch of this pull request and the lworld branch.
As there are no conflicts, your changes will automatically be rebased on top of these commits when integrating. If you prefer to avoid this automatic rebasing, please check the documentation for the /integrate command for further details.

➡️ To integrate this PR with the above commit message to the lworld branch, type /integrate in a new comment.

@mlbridge
Copy link

mlbridge bot commented Dec 17, 2024

Webrevs

@MrSimms
Copy link
Member Author

MrSimms commented Dec 17, 2024

/contributor add @fisk

@openjdk
Copy link

openjdk bot commented Dec 17, 2024

@MrSimms
Contributor Erik Österlund <eosterlund@openjdk.org> successfully added.

Copy link
Contributor

@fisk fisk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good.

// 1) possibly raw copy for any primitive payload before each map
// 2) load and store barrier for each oop
// 3) possibly raw copy for any primitive payload trailer
assert(lk == NON_ATOMIC_FLAT || lk == PAYLOAD, "Cannot support layout other than NON_ATOMIC_FLAT"); // Note: PAYLOAD is incorrect, resolve when transistioned to new flattening
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why is PAYLOAD incorrect here?
And what about ATOMIC_FLAT? Even with ZGC, it can contain an oop.

Copy link
Member Author

@MrSimms MrSimms Dec 18, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You are correct there is a use single case under the md->contains_oops() condition with Z that is valid, a single oop (and only a single oop, no other data). Will adjust...

Given that we now have "LayoutKind", it would be useful to add an assert for the non-oops condition too, but that should probably go into RawAccessBarrier<decorators>::value_copy...I want fix that later (JDK-8346505) and get the merge work continued (could be baked into the "next gen" flattening work ?).

@MrSimms
Copy link
Member Author

MrSimms commented Dec 18, 2024

/integrate

@openjdk
Copy link

openjdk bot commented Dec 18, 2024

Going to push as commit 896cca5.
Since your change was applied there have been 2 commits pushed to the lworld branch:

  • 137b0c2: 8346305: [lworld] Revert WeakHashMap POC for a value object policy
  • 5313fda: 8346467: [lworld] Value record cannot be implicitly constructible

Your commit was automatically rebased without conflicts.

@openjdk openjdk bot added the integrated label Dec 18, 2024
@openjdk openjdk bot closed this Dec 18, 2024
@openjdk
Copy link

openjdk bot commented Dec 18, 2024

@MrSimms Pushed as commit 896cca5.

💡 You may see a message that your pull request was closed with unmerged commits. This can be safely ignored.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Development

Successfully merging this pull request may close these issues.

None yet

3 participants