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

[zstd] Fix unneededly allocate large decompression buffer #120

Merged
merged 2 commits into from
Jun 6, 2022

Conversation

Viq111
Copy link
Collaborator

@Viq111 Viq111 commented Jun 2, 2022

Fix #118
With the introduction of #115 to prevent zipbombs, the check was too strict and was checking a too large size boundary. This fixes it and adds a test

Thanks to @XiaochenCui for reporting

Fix #118
With the introduction of #115 to prevent zipbombs, the check was too strict and was checking a too large size boundary. This fixes it and adds a test
@Viq111 Viq111 marked this pull request as ready for review June 2, 2022 15:16
@XiaochenCui
Copy link

LGTM

@@ -67,11 +67,14 @@ func decompressSizeHint(src []byte) int {
}

hint := upperBound
if len(src) >= zstdFrameHeaderSizeMax {
if len(src) >= zstdFrameHeaderSizeMin {
Copy link

Choose a reason for hiding this comment

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

why not check the upper bound as well?

len(src) >= zstdFrameHeaderSizeMin && len(src) <= zstdFrameHeaderSizeMax

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

I'm not sure what you mean ? That check if just to make sure the header is in the payload but src will 99% of the time be bigger than zstdFrameHeaderSizeMax (and that's fine)

Copy link

Choose a reason for hiding this comment

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

👍 sorry I thought that src would only be the header, I didn't realize it was the full payload.

@Viq111 Viq111 merged commit d64f463 into 1.x Jun 6, 2022
@Viq111 Viq111 deleted the viq111/fix-min-size branch June 6, 2022 17:17
@Viq111
Copy link
Collaborator Author

Viq111 commented Jun 6, 2022

Thanks for the report @XiaochenCui ! I'm still looking at #117 and once it's ready, I'll cut a new release

@XiaochenCui
Copy link

Thanks for the report @XiaochenCui ! I'm still looking at #117 and once it's ready, I'll cut a new release

Sure thing! It feels great to contribute to the open-source community.

kodiakhq bot referenced this pull request in cloudquery/cloudquery Jan 1, 2023
This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
| [github.com/DataDog/zstd](https://github.com/DataDog/zstd) | indirect | patch | `v1.5.0` -> `v1.5.2` |

---

### Release Notes

<details>
<summary>DataDog/zstd</summary>

### [`v1.5.2`](https://github.com/DataDog/zstd/releases/tag/v1.5.2): zstd 1.5.2

[Compare Source](https://github.com/DataDog/zstd/compare/v1.5.2...v1.5.2)

This release updates the upstream zstd version to [1.5.2](https://github.com/facebook/zstd/releases/tag/v1.5.2) ([https://github.com/DataDog/zstd/pull/116](https://github.com/DataDog/zstd/pull/116))

The update `1.5.0` -> `1.5.2` overall has a similar performance profile. Please note that depending on the workload, performance could vary by -10% / +10%

### [`v1.5.2+patch1`](https://github.com/DataDog/zstd/releases/tag/v1.5.2%2Bpatch1): zstd 1.5.2 - wrapper patches 1

[Compare Source](https://github.com/DataDog/zstd/compare/v1.5.0...v1.5.2)

#### What's Changed

-   Fix unneededly allocated large decompression buffer by [@&#8203;XiaochenCui](https://github.com/XiaochenCui) ([#&#8203;118](https://github.com/DataDog/zstd/issues/118)) & [@&#8203;Viq111](https://github.com/Viq111) in [https://github.com/DataDog/zstd/pull/120](https://github.com/DataDog/zstd/pull/120)
-   Add SetNbWorkers api to the writer code (see [#&#8203;108](https://github.com/DataDog/zstd/issues/108)) by [@&#8203;bsergean](https://github.com/bsergean) in [https://github.com/DataDog/zstd/pull/117](https://github.com/DataDog/zstd/pull/117)
    -   For large workloads, the performance can be improved by 3-6x (see [https://github.com/DataDog/zstd/pull/117#issuecomment-1147812767](https://github.com/DataDog/zstd/pull/117#issuecomment-1147812767))
    -   `Write()` becomes async with workers > 1, make sure you read the method documentation before using

#### New Contributors

-   [@&#8203;bsergean](https://github.com/bsergean) made their first contribution in [https://github.com/DataDog/zstd/pull/117](https://github.com/DataDog/zstd/pull/117)
-   [@&#8203;XiaochenCui](https://github.com/XiaochenCui) for his work on [https://github.com/DataDog/zstd/pull/118](https://github.com/DataDog/zstd/pull/118) that led to [#&#8203;120](https://github.com/DataDog/zstd/issues/120)

**Full Changelog**: DataDog/zstd@v1.5.2...v1.5.2+patch1

</details>

---

### Configuration

📅 **Schedule**: Branch creation - "before 3am on the first day of the month" (UTC), Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update again.

---

 - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box

---

This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate).
<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNC43Ny4wIiwidXBkYXRlZEluVmVyIjoiMzQuNzcuMCJ9-->
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants