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

Fix continuation stacks when breakpointing #18413

Merged
merged 1 commit into from
Nov 14, 2023

Conversation

gacholio
Copy link
Contributor

@gacholio gacholio commented Nov 7, 2023

The breakpoint handling code was only fixing stacks actively running on
a thread. The stacks for continuations also need to be fixed.

Fixes: #18088

Signed-off-by: Graham Chapman [email protected]

@gacholio gacholio changed the title Fix continutation stacks when breakpointing Fix continuation stacks when breakpointing Nov 7, 2023
@gacholio gacholio force-pushed the break branch 5 times, most recently from c76af27 to e5c2ee9 Compare November 8, 2023 21:39
@gacholio gacholio requested a review from babsingh November 9, 2023 05:51
@gacholio
Copy link
Contributor Author

gacholio commented Nov 9, 2023

@babsingh I'm looking into the JVMTI test failures. Please do an initial review of my use of the continuations.

Copy link
Contributor

@babsingh babsingh left a comment

Choose a reason for hiding this comment

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

  • Is exclusive VM access acquired for all j9mm_iterate_all_continuation_objects calls?
  • Should j9gc_flush_nonAllocationCaches_for_walk and j9mm_iterate_all_continuation_objects be invoked together?
  • Need to pass the correct threadObject to walkContinuationStackFrames.

runtime/jvmti/jvmtiHelpers.c Outdated Show resolved Hide resolved
runtime/codert_vm/decomp.cpp Show resolved Hide resolved
@babsingh
Copy link
Contributor

babsingh commented Nov 9, 2023

++ @fengxue-IS for a second set of eyes.

@babsingh babsingh requested a review from fengxue-IS November 9, 2023 15:17
@gacholio gacholio force-pushed the break branch 2 times, most recently from aa66bbe to 88cbd28 Compare November 9, 2023 16:01
Copy link
Contributor

@fengxue-IS fengxue-IS left a comment

Choose a reason for hiding this comment

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

code lgtm, few minor format picks

runtime/jvmti/jvmtiHelpers.c Outdated Show resolved Hide resolved
runtime/codert_vm/decomp.cpp Outdated Show resolved Hide resolved
runtime/codert_vm/decomp.cpp Outdated Show resolved Hide resolved
runtime/codert_vm/decomp.cpp Outdated Show resolved Hide resolved
@gacholio gacholio force-pushed the break branch 2 times, most recently from 7ac5535 to 2c3dddc Compare November 9, 2023 16:55
@gacholio gacholio force-pushed the break branch 2 times, most recently from 371257d to c38e8e0 Compare November 9, 2023 21:08
@gacholio
Copy link
Contributor Author

gacholio commented Nov 9, 2023

I found more places that need the flush, so I've helperized acquiring exclusive in JVMTI (some of the callers don't strictly need the flush, but it's a tiny amount of time compared to acquiring exclusive).

@gacholio gacholio force-pushed the break branch 2 times, most recently from 0b5d0b8 to 854e613 Compare November 9, 2023 21:54
@gacholio
Copy link
Contributor Author

On reflection, I don't like the exclusive/flush solution. I think @babsingh initial idea is best - do the flush before the iterate. I'll update tomorrow.

@gacholio gacholio force-pushed the break branch 4 times, most recently from 075368a to 2506ab6 Compare November 10, 2023 12:35
@gacholio
Copy link
Contributor Author

@dmitripivkine Please confirm it's OK to call j9gc_flush_nonAllocationCaches_for_walk multiple times in the same exclusive VM access.

@dmitripivkine
Copy link
Contributor

@dmitripivkine Please confirm it's OK to call j9gc_flush_nonAllocationCaches_for_walk multiple times in the same exclusive VM access.

Yes, I believe so. However it might be not optimum because once threads local buffers are flushed nothing should be added under the same exclusive.

@gacholio gacholio force-pushed the break branch 6 times, most recently from 6d84cca to 29a20a6 Compare November 11, 2023 13:19
Copy link
Contributor

@babsingh babsingh left a comment

Choose a reason for hiding this comment

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

accidentally approved while juggling through multiple PRs.

@gacholio gacholio requested a review from babsingh November 12, 2023 09:54
@gacholio gacholio marked this pull request as ready for review November 13, 2023 11:44
@gacholio
Copy link
Contributor Author

@babsingh Ready for final review.

Copy link
Contributor

@babsingh babsingh left a comment

Choose a reason for hiding this comment

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

minor formatting nits; otherwise, lgtm.

runtime/codert_vm/decomp.cpp Outdated Show resolved Hide resolved
runtime/codert_vm/decomp.cpp Outdated Show resolved Hide resolved
runtime/codert_vm/decomp.cpp Outdated Show resolved Hide resolved
runtime/codert_vm/decomp.cpp Outdated Show resolved Hide resolved
The breakpoint handling code was only fixing stacks actively running on
a thread. The stacks for continuations also need to be fixed.

Fixes: eclipse-openj9#18088

Signed-off-by: Graham Chapman <[email protected]>
@babsingh
Copy link
Contributor

jenkins test sanity zlinux jdk8,jdk21

@babsingh
Copy link
Contributor

jenkins compile win jdk8,jdk21

Copy link
Contributor

@babsingh babsingh left a comment

Choose a reason for hiding this comment

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

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
4 participants