Lack of data validation In rust-zserio

Description

rust-zserio has Unbounded Memory Allocation

Impact

When deserializing arrays, strings or bytes (blob) types zserio first reads the size of the variable, and then allocates sufficient memory to load data. Since the size is always trusted this can be abused by creating a data file with a large size value, causing the zserio runtime to allocate large amounts of memory.

Patches

Please cherry-pick 57f5fb.

Workarounds

    Do not accept zserio-encoded messages from non-trusted sources.

    Allocate a maximum heap amount to rust-zerio to avoid impacting other applications.

Mitigation

Update Impact

Minimal update. May introduce new vulnerabilities or breaking changes.

Ecosystem
Package
Affected version
Patched versions