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

[22438] Arithmetic overflow in fragment size calculations #5464

Merged
merged 12 commits into from
Dec 18, 2024

Conversation

EugenioCollado
Copy link
Contributor

@EugenioCollado EugenioCollado commented Dec 5, 2024

Description

This PR fixes an overflow in the WriterHistory and BaseWriter that occurred when the maximum message size was insufficient to accommodate the message's inherent headers.

@Mergifyio backport 3.1.x 3.0.x 2.14.x 2.10.x

Contributor Checklist

  • Commit messages follow the project guidelines.
  • The code follows the style guidelines of this project.
  • Tests that thoroughly check the new feature have been added/Regression tests checking the bug and its fix have been added; the added tests pass locally
  • N/A Any new/modified methods have been properly documented using Doxygen.
  • N/A Any new configuration API has an equivalent XML API (with the corresponding XSD extension)
  • Changes are backport compatible: they do NOT break ABI nor change library core behavior.
  • Changes are API compatible.
  • N/A New feature has been added to the versions.md file (if applicable).
  • N/A New feature has been documented/Current behavior is correctly described in the documentation.
  • Applicable backports have been included in the description.

Reviewer Checklist

  • The PR has a milestone assigned.
  • The title and description correctly express the PR's purpose.
  • Check contributor checklist is correct.
  • If this is a critical bug fix, backports to the critical-only supported branches have been requested.
  • Check CI results: changes do not issue any warning.
  • Check CI results: failing tests are unrelated with the changes.

@github-actions github-actions bot added the ci-pending PR which CI is running label Dec 5, 2024
@EugenioCollado EugenioCollado requested review from richiprosima and removed request for richiprosima December 5, 2024 08:57
@EugenioCollado EugenioCollado added this to the v3.2.0 milestone Dec 5, 2024
@EugenioCollado EugenioCollado marked this pull request as ready for review December 5, 2024 09:34
@EugenioCollado EugenioCollado changed the title [21814] Arithmetic overflow in fragment size calculations [22438] Arithmetic overflow in fragment size calculations Dec 5, 2024
@EugenioCollado EugenioCollado requested review from MiguelCompany and removed request for richiprosima December 5, 2024 09:45
@EugenioCollado EugenioCollado force-pushed the fix/21814 branch 2 times, most recently from 7234fc3 to 549428a Compare December 9, 2024 14:49
@MiguelCompany MiguelCompany requested review from MiguelCompany and removed request for MiguelCompany December 9, 2024 15:18
@EugenioCollado EugenioCollado force-pushed the fix/21814 branch 2 times, most recently from 0422b3b to 07a4d8c Compare December 13, 2024 10:38
@EugenioCollado EugenioCollado requested review from richiprosima and removed request for richiprosima December 16, 2024 08:15
Signed-off-by: EugenioCollado <[email protected]>
@MiguelCompany MiguelCompany self-requested a review December 17, 2024 15:01
Copy link
Member

@MiguelCompany MiguelCompany left a comment

Choose a reason for hiding this comment

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

LGTM with green CI

@EugenioCollado
Copy link
Contributor Author

EugenioCollado commented Dec 18, 2024

@Mergifyio backport 3.1.x 3.0.x 2.14.x 2.10.x

Copy link
Contributor

mergify bot commented Dec 18, 2024

backport 3.1.x 3.0.x 2.14.x 2.10.x

✅ Backports have been created

@MiguelCompany MiguelCompany added ready-to-merge Ready to be merged. CI and changes have been reviewed and approved. and removed ci-pending PR which CI is running labels Dec 18, 2024
@MiguelCompany MiguelCompany merged commit bfc5a53 into master Dec 18, 2024
16 of 17 checks passed
@MiguelCompany MiguelCompany deleted the fix/21814 branch December 18, 2024 08:30
mergify bot pushed a commit that referenced this pull request Dec 18, 2024
* Tests arithmetic overflow in fragment size calculations

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in BaseWriter.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==max_data_size

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in WriterHistory.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==final_high_mark_for_frag

Signed-off-by: Eugenio Collado <[email protected]>

* Uncrustify

Signed-off-by: Eugenio Collado <[email protected]>

* Fix log error message

Signed-off-by: Eugenio Collado <[email protected]>

* Fix test fragments not been dropped

Signed-off-by: Eugenio Collado <[email protected]>

* Fix corner case RTPSParticipantImpl max_data_size < overhead

Signed-off-by: Eugenio Collado <[email protected]>

* Test refactor for windows compilation

Signed-off-by: Eugenio Collado <[email protected]>

* Fix blackbox test

Signed-off-by: Eugenio Collado <[email protected]>

* Applied review suggestions

Signed-off-by: EugenioCollado <[email protected]>

---------

Signed-off-by: Eugenio Collado <[email protected]>
Signed-off-by: Miguel Company <[email protected]>
Signed-off-by: EugenioCollado <[email protected]>
Co-authored-by: Miguel Company <[email protected]>
(cherry picked from commit bfc5a53)

# Conflicts:
#	src/cpp/rtps/writer/BaseWriter.cpp
#	test/blackbox/common/DDSBlackboxTestsListeners.cpp
mergify bot pushed a commit that referenced this pull request Dec 18, 2024
* Tests arithmetic overflow in fragment size calculations

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in BaseWriter.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==max_data_size

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in WriterHistory.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==final_high_mark_for_frag

Signed-off-by: Eugenio Collado <[email protected]>

* Uncrustify

Signed-off-by: Eugenio Collado <[email protected]>

* Fix log error message

Signed-off-by: Eugenio Collado <[email protected]>

* Fix test fragments not been dropped

Signed-off-by: Eugenio Collado <[email protected]>

* Fix corner case RTPSParticipantImpl max_data_size < overhead

Signed-off-by: Eugenio Collado <[email protected]>

* Test refactor for windows compilation

Signed-off-by: Eugenio Collado <[email protected]>

* Fix blackbox test

Signed-off-by: Eugenio Collado <[email protected]>

* Applied review suggestions

Signed-off-by: EugenioCollado <[email protected]>

---------

Signed-off-by: Eugenio Collado <[email protected]>
Signed-off-by: Miguel Company <[email protected]>
Signed-off-by: EugenioCollado <[email protected]>
Co-authored-by: Miguel Company <[email protected]>
(cherry picked from commit bfc5a53)
mergify bot pushed a commit that referenced this pull request Dec 18, 2024
* Tests arithmetic overflow in fragment size calculations

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in BaseWriter.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==max_data_size

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in WriterHistory.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==final_high_mark_for_frag

Signed-off-by: Eugenio Collado <[email protected]>

* Uncrustify

Signed-off-by: Eugenio Collado <[email protected]>

* Fix log error message

Signed-off-by: Eugenio Collado <[email protected]>

* Fix test fragments not been dropped

Signed-off-by: Eugenio Collado <[email protected]>

* Fix corner case RTPSParticipantImpl max_data_size < overhead

Signed-off-by: Eugenio Collado <[email protected]>

* Test refactor for windows compilation

Signed-off-by: Eugenio Collado <[email protected]>

* Fix blackbox test

Signed-off-by: Eugenio Collado <[email protected]>

* Applied review suggestions

Signed-off-by: EugenioCollado <[email protected]>

---------

Signed-off-by: Eugenio Collado <[email protected]>
Signed-off-by: Miguel Company <[email protected]>
Signed-off-by: EugenioCollado <[email protected]>
Co-authored-by: Miguel Company <[email protected]>
(cherry picked from commit bfc5a53)
mergify bot pushed a commit that referenced this pull request Dec 18, 2024
* Tests arithmetic overflow in fragment size calculations

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in BaseWriter.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==max_data_size

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in WriterHistory.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==final_high_mark_for_frag

Signed-off-by: Eugenio Collado <[email protected]>

* Uncrustify

Signed-off-by: Eugenio Collado <[email protected]>

* Fix log error message

Signed-off-by: Eugenio Collado <[email protected]>

* Fix test fragments not been dropped

Signed-off-by: Eugenio Collado <[email protected]>

* Fix corner case RTPSParticipantImpl max_data_size < overhead

Signed-off-by: Eugenio Collado <[email protected]>

* Test refactor for windows compilation

Signed-off-by: Eugenio Collado <[email protected]>

* Fix blackbox test

Signed-off-by: Eugenio Collado <[email protected]>

* Applied review suggestions

Signed-off-by: EugenioCollado <[email protected]>

---------

Signed-off-by: Eugenio Collado <[email protected]>
Signed-off-by: Miguel Company <[email protected]>
Signed-off-by: EugenioCollado <[email protected]>
Co-authored-by: Miguel Company <[email protected]>
(cherry picked from commit bfc5a53)

# Conflicts:
#	src/cpp/rtps/writer/BaseWriter.cpp
#	test/blackbox/common/DDSBlackboxTestsListeners.cpp
#	test/unittest/rtps/history/CMakeLists.txt
EugenioCollado added a commit that referenced this pull request Dec 19, 2024
EugenioCollado added a commit that referenced this pull request Dec 20, 2024
* Tests arithmetic overflow in fragment size calculations

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in BaseWriter.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==max_data_size

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in WriterHistory.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==final_high_mark_for_frag

Signed-off-by: Eugenio Collado <[email protected]>

* Uncrustify

Signed-off-by: Eugenio Collado <[email protected]>

* Fix log error message

Signed-off-by: Eugenio Collado <[email protected]>

* Fix test fragments not been dropped

Signed-off-by: Eugenio Collado <[email protected]>

* Fix corner case RTPSParticipantImpl max_data_size < overhead

Signed-off-by: Eugenio Collado <[email protected]>

* Test refactor for windows compilation

Signed-off-by: Eugenio Collado <[email protected]>

* Fix blackbox test

Signed-off-by: Eugenio Collado <[email protected]>

* Applied review suggestions

Signed-off-by: EugenioCollado <[email protected]>

---------

Signed-off-by: Eugenio Collado <[email protected]>
Signed-off-by: Miguel Company <[email protected]>
Signed-off-by: EugenioCollado <[email protected]>
Co-authored-by: Miguel Company <[email protected]>
(cherry picked from commit bfc5a53)
EugenioCollado added a commit that referenced this pull request Dec 20, 2024
EugenioCollado added a commit that referenced this pull request Dec 27, 2024
Signed-off-by: Eugenio Collado <[email protected]>
Co-authored-by: Eugenio Collado <[email protected]>
MiguelCompany pushed a commit that referenced this pull request Jan 3, 2025
* Tests arithmetic overflow in fragment size calculations

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in BaseWriter.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==max_data_size

Signed-off-by: Eugenio Collado <[email protected]>

* Refs #21814. Fix code in WriterHistory.cpp.

Signed-off-by: Miguel Company <[email protected]>

* Fix corner case overhead==final_high_mark_for_frag

Signed-off-by: Eugenio Collado <[email protected]>

* Uncrustify

Signed-off-by: Eugenio Collado <[email protected]>

* Fix log error message

Signed-off-by: Eugenio Collado <[email protected]>

* Fix test fragments not been dropped

Signed-off-by: Eugenio Collado <[email protected]>

* Fix corner case RTPSParticipantImpl max_data_size < overhead

Signed-off-by: Eugenio Collado <[email protected]>

* Test refactor for windows compilation

Signed-off-by: Eugenio Collado <[email protected]>

* Fix blackbox test

Signed-off-by: Eugenio Collado <[email protected]>

* Applied review suggestions

Signed-off-by: EugenioCollado <[email protected]>

---------

Signed-off-by: Eugenio Collado <[email protected]>
Signed-off-by: Miguel Company <[email protected]>
Signed-off-by: EugenioCollado <[email protected]>
Co-authored-by: Miguel Company <[email protected]>
(cherry picked from commit bfc5a53)

Co-authored-by: EugenioCollado <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
ready-to-merge Ready to be merged. CI and changes have been reviewed and approved.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants