[22339] Fix tsan potential deadlock between StatefulWriter and FlowController#5432
Merged
MiguelCompany merged 4 commits intomasterfrom Dec 13, 2024
Merged
[22339] Fix tsan potential deadlock between StatefulWriter and FlowController#5432MiguelCompany merged 4 commits intomasterfrom
StatefulWriter and FlowController#5432MiguelCompany merged 4 commits intomasterfrom
Conversation
Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com>
Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com>
…d_status() Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com>
MiguelCompany
requested changes
Dec 11, 2024
Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com>
Member
|
@Mergifyio backport 3.1.x 3.0.x 2.14.x 2.10.x |
Contributor
✅ Backports have been createdDetails
|
mergify bot
pushed a commit
that referenced
this pull request
Dec 13, 2024
…ler` (#5432) * Refs #22339: Add BB test Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Fix tsan deadlock report Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Take writer's mutex before rproxy->stop() and check_acked_status() Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Apply Miguels suggestion Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> --------- Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> (cherry picked from commit 8fcd7ca)
mergify bot
pushed a commit
that referenced
this pull request
Dec 13, 2024
…ler` (#5432) * Refs #22339: Add BB test Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Fix tsan deadlock report Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Take writer's mutex before rproxy->stop() and check_acked_status() Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Apply Miguels suggestion Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> --------- Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> (cherry picked from commit 8fcd7ca)
mergify bot
pushed a commit
that referenced
this pull request
Dec 13, 2024
…ler` (#5432) * Refs #22339: Add BB test Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Fix tsan deadlock report Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Take writer's mutex before rproxy->stop() and check_acked_status() Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Apply Miguels suggestion Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> --------- Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> (cherry picked from commit 8fcd7ca) # Conflicts: # src/cpp/rtps/writer/StatefulWriter.cpp
mergify bot
pushed a commit
that referenced
this pull request
Dec 13, 2024
…ler` (#5432) * Refs #22339: Add BB test Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Fix tsan deadlock report Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Take writer's mutex before rproxy->stop() and check_acked_status() Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Apply Miguels suggestion Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> --------- Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> (cherry picked from commit 8fcd7ca) # Conflicts: # src/cpp/rtps/writer/StatefulWriter.cpp # test/blackbox/common/DDSBlackboxTestsBasic.cpp
MiguelCompany
pushed a commit
that referenced
this pull request
Dec 16, 2024
…ler` (#5432) (#5494) * Refs #22339: Add BB test Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Fix tsan deadlock report Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Take writer's mutex before rproxy->stop() and check_acked_status() Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Apply Miguels suggestion Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> --------- Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> (cherry picked from commit 8fcd7ca) Co-authored-by: Mario Domínguez López <116071334+Mario-DL@users.noreply.github.com>
EugenioCollado
pushed a commit
that referenced
this pull request
Jan 30, 2025
…ler` (#5432) * Refs #22339: Add BB test Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Fix tsan deadlock report Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Take writer's mutex before rproxy->stop() and check_acked_status() Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Apply Miguels suggestion Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> --------- Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> (cherry picked from commit 8fcd7ca) Fix conflicts Signed-off-by: Eugenio Collado <eugeniocollado@eprosima.com>
EugenioCollado
added a commit
that referenced
this pull request
Jan 30, 2025
…ler` (#5432) * Refs #22339: Add BB test Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Fix tsan deadlock report Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Take writer's mutex before rproxy->stop() and check_acked_status() Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Apply Miguels suggestion Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> --------- Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> (cherry picked from commit 8fcd7ca) Fix conflicts Signed-off-by: Eugenio Collado <eugeniocollado@eprosima.com>
EugenioCollado
added a commit
that referenced
this pull request
Jan 30, 2025
…ler` (#5432) * Refs #22339: Add BB test Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Fix tsan deadlock report Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Take writer's mutex before rproxy->stop() and check_acked_status() Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Apply Miguels suggestion Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> --------- Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> (cherry picked from commit 8fcd7ca) Fix conflicts Signed-off-by: Eugenio Collado <eugeniocollado@eprosima.com>
juanlofer-eprosima
pushed a commit
that referenced
this pull request
Feb 3, 2025
…ler` (#5432) (#5496) * Refs #22339: Add BB test * Refs #22339: Fix tsan deadlock report * Refs #22339: Take writer's mutex before rproxy->stop() and check_acked_status() * Refs #22339: Apply Miguels suggestion --------- (cherry picked from commit 8fcd7ca) Fix conflicts Signed-off-by: Eugenio Collado <eugeniocollado@eprosima.com> Co-authored-by: Eugenio Collado <eugeniocollado@eprosima.com>
MiguelCompany
pushed a commit
that referenced
this pull request
May 28, 2025
…ler` (#5432) * Refs #22339: Add BB test Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Fix tsan deadlock report Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Take writer's mutex before rproxy->stop() and check_acked_status() Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Apply Miguels suggestion Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> --------- Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> (cherry picked from commit 8fcd7ca) # Conflicts: # src/cpp/rtps/writer/StatefulWriter.cpp # test/blackbox/common/DDSBlackboxTestsBasic.cpp
MiguelCompany
added a commit
that referenced
this pull request
May 29, 2025
…ler` (#5432) (#5497) * Fix tsan potential deadlock between `StatefulWriter` and `FlowController` (#5432) * Refs #22339: Add BB test Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Fix tsan deadlock report Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Take writer's mutex before rproxy->stop() and check_acked_status() Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> * Refs #22339: Apply Miguels suggestion Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> --------- Signed-off-by: Mario Dominguez <mariodominguez@eprosima.com> (cherry picked from commit 8fcd7ca) # Conflicts: # src/cpp/rtps/writer/StatefulWriter.cpp # test/blackbox/common/DDSBlackboxTestsBasic.cpp * Fix conflicts Signed-off-by: Miguel Company <miguelcompany@eprosima.com> --------- Signed-off-by: Miguel Company <miguelcompany@eprosima.com> Co-authored-by: Mario Domínguez López <116071334+Mario-DL@users.noreply.github.com> Co-authored-by: Miguel Company <miguelcompany@eprosima.com>
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Description
This PR addresses a TSAN potential deadlock by lock inversion report between
StatefulWriter::matched_reader_remove()and (async)FlowController::run().@Mergifyio backport 3.1.x 3.0.x 2.14.x 2.10.x
Contributor Checklist
versions.mdfile (if applicable).Reviewer Checklist