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

Debugging MIRI deadlock #133

Closed
wants to merge 3 commits into from
Closed

Debugging MIRI deadlock #133

wants to merge 3 commits into from

Conversation

notgull
Copy link
Member

@notgull notgull commented May 16, 2024

Part of the aforementioned deep-dive. So far WIP

notgull added 2 commits May 19, 2024 20:50
On Miri this fails.

Signed-off-by: John Nunley <[email protected]>
Signed-off-by: John Nunley <[email protected]>
@notgull notgull force-pushed the notgull/rwlock-emulation branch from 18add13 to 9fdf047 Compare May 25, 2024 19:53
Signed-off-by: John Nunley <[email protected]>
notgull added a commit that referenced this pull request May 27, 2024
The notify() function contains two optimizations:

- If the `inner` field is not yet initialized (i.e. no listeners have been
  created yet), it returns `0` from the function early.
- If the atomic `notified` field indicates that the current notification would
  do nothing, it returns `0` early as well.

`loom` testing has exposed race conditions in these optimizations that can cause
notifications to be missed, leading to deadlocks. This commit removes these
optimizations in the hope of preventing these deadlocks. Ideally we can restore
them in the future.

Closes #138
cc #130 and #133

Signed-off-by: John Nunley <[email protected]>
@notgull notgull closed this May 27, 2024
@notgull notgull deleted the notgull/rwlock-emulation branch May 27, 2024 22:27
notgull added a commit that referenced this pull request May 28, 2024
The notify() function contains two optimizations:

- If the `inner` field is not yet initialized (i.e. no listeners have been
  created yet), it returns `0` from the function early.
- If the atomic `notified` field indicates that the current notification would
  do nothing, it returns `0` early as well.

`loom` testing has exposed race conditions in these optimizations that can cause
notifications to be missed, leading to deadlocks. This commit removes these
optimizations in the hope of preventing these deadlocks. Ideally we can restore
them in the future.

Closes #138
cc #130 and #133

Signed-off-by: John Nunley <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Development

Successfully merging this pull request may close these issues.

1 participant